:root {
  --indigo: #4f46e5;
  --indigo-d: #4338ca;
  --ink: #14161f;
  --muted: #5b6172;
  --line: #e7e9f2;
  --bg: #ffffff;
  --soft: #f6f7fc;
  --green: #059669;
  --red: #dc2626;
  --radius: 14px;
  --max: 1080px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: -apple-system, "Segoe UI", Roboto, Inter, Helvetica, Arial, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--indigo); text-decoration: none; }
a:hover { text-decoration: underline; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 20px; }
.btn {
  display: inline-block; background: var(--indigo); color: #fff !important; border: none;
  padding: 12px 22px; border-radius: 12px; font-weight: 600; font-size: 15px; cursor: pointer;
  text-decoration: none !important; transition: background .15s;
}
.btn:hover { background: var(--indigo-d); }
.btn.ghost { background: #fff; color: var(--indigo) !important; border: 1px solid var(--line); }
.btn.lg { padding: 14px 28px; font-size: 16px; }
.muted { color: var(--muted); }
.center { text-align: center; }

/* nav */
.nav { position: sticky; top: 0; background: rgba(255,255,255,.9); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); z-index: 20; }
.nav .wrap { display: flex; align-items: center; justify-content: space-between; height: 62px; }
.logo { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 18px; color: var(--ink); }
.logo img { width: 28px; height: 28px; }
.nav-links { display: flex; align-items: center; gap: 22px; }
.nav-links a { color: var(--ink); font-weight: 500; }

/* hero */
.hero { padding: 76px 0 40px; background: radial-gradient(900px 380px at 70% -10%, #eef0ff 0, #fff 60%); }
.hero h1 { font-size: 46px; line-height: 1.08; margin: 0 0 18px; letter-spacing: -.02em; }
.hero h1 .hl { color: var(--indigo); }
.hero p.sub { font-size: 19px; color: var(--muted); max-width: 620px; margin: 0 0 28px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.trust { margin-top: 18px; font-size: 13px; color: var(--muted); }

.grid2 { display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center; }
@media (max-width: 860px) { .grid2 { grid-template-columns: 1fr; } .hero h1 { font-size: 36px; } }

/* mock dashboard card */
.mock {
  background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 24px 60px -28px rgba(40,40,90,.4);
  overflow: hidden;
}
.mock-head { background: var(--indigo); color: #fff; padding: 12px 16px; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.mock-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 10px; }
.mrow { display: flex; align-items: center; justify-content: space-between; border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; }
.mrow .t { font-weight: 600; font-size: 14px; }
.mrow .u { font-size: 11px; color: var(--muted); }
.mrow .p { font-weight: 700; }
.tag { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; }
.tag.down { background: #e7f7ef; color: var(--green); }
.tag.out { background: #fdeaea; color: var(--red); }
.tag.in { background: #eef0fb; color: var(--indigo); }

/* sections */
section { padding: 64px 0; }
section h2 { font-size: 30px; margin: 0 0 10px; letter-spacing: -.01em; }
section .lead { color: var(--muted); font-size: 17px; max-width: 640px; margin: 0 0 36px; }
.alt { background: var(--soft); }

.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 860px) { .cards { grid-template-columns: 1fr; } }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; }
.card .ico { font-size: 22px; }
.card h3 { margin: 12px 0 6px; font-size: 18px; }
.card p { margin: 0; color: var(--muted); font-size: 14px; }

.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; counter-reset: s; }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr; } }
.step { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 22px; position: relative; }
.step .n { width: 30px; height: 30px; border-radius: 50%; background: var(--indigo); color:#fff; display:grid; place-items:center; font-weight:700; margin-bottom: 10px; }

/* pricing */
.plans { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; align-items: stretch; }
@media (max-width: 860px) { .plans { grid-template-columns: 1fr; } }
.plan { background:#fff; border:1px solid var(--line); border-radius: 16px; padding: 26px; display:flex; flex-direction: column; }
.plan.feat { border: 2px solid var(--indigo); box-shadow: 0 18px 50px -28px rgba(79,70,229,.6); }
.plan h3 { margin: 0; font-size: 18px; }
.price { font-size: 38px; font-weight: 800; margin: 10px 0 2px; }
.price small { font-size: 15px; font-weight: 500; color: var(--muted); }
.plan ul { list-style: none; padding: 0; margin: 16px 0 22px; display:flex; flex-direction: column; gap: 9px; }
.plan li { font-size: 14px; color: #2a2e3d; padding-left: 24px; position: relative; }
.plan li:before { content: "✓"; color: var(--green); position: absolute; left: 0; font-weight: 700; }
.plan .btn { margin-top: auto; }
.badge-pop { display:inline-block; background: var(--indigo); color:#fff; font-size: 11px; font-weight:700; padding: 3px 10px; border-radius: 999px; margin-bottom: 8px; }

/* faq */
.faq details { background:#fff; border:1px solid var(--line); border-radius: 12px; padding: 14px 18px; margin-bottom: 10px; }
.faq summary { font-weight: 600; cursor: pointer; }
.faq p { color: var(--muted); margin: 10px 0 0; }

/* cta band */
.band { background: linear-gradient(120deg, var(--indigo), #7c3aed); color: #fff; border-radius: 22px; padding: 46px; text-align: center; }
.band h2 { color: #fff; }
.band .btn { background: #fff; color: var(--indigo) !important; }

footer { border-top: 1px solid var(--line); padding: 30px 0; color: var(--muted); font-size: 14px; }
footer .wrap { display:flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }

/* simple inline form */
.inline-form { display:flex; gap: 8px; max-width: 440px; }
.inline-form input { flex:1; padding: 12px 14px; border:1px solid var(--line); border-radius: 12px; font-size: 15px; }
.note { font-size: 13px; margin-top: 8px; min-height: 18px; }
.note.ok { color: var(--green); } .note.err { color: var(--red); }

/* ── logo strip (social proof) ─────────────────────────────────────────── */
.logostrip { display:flex; align-items:center; justify-content:center; gap:34px; flex-wrap:wrap; padding:10px 0 0; opacity:.72; }
.logostrip span { font-weight:800; font-size:18px; color:#9aa0b4; letter-spacing:-.01em; }
.kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:30px; }
@media (max-width:860px){ .kpis{ grid-template-columns:1fr; } }
.kpi { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:20px; text-align:center; }
.kpi b { display:block; font-size:32px; font-weight:800; color:var(--indigo); letter-spacing:-.02em; }
.kpi span { color:var(--muted); font-size:14px; }

/* ── testimonials ──────────────────────────────────────────────────────── */
.quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:860px){ .quotes{ grid-template-columns:1fr; } }
.quote { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px; display:flex; flex-direction:column; }
.quote p { font-size:15px; color:#2a2e3d; margin:0 0 14px; }
.quote .who { display:flex; align-items:center; gap:10px; margin-top:auto; }
.quote .av { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--indigo),#7c3aed); color:#fff; display:grid; place-items:center; font-weight:700; font-size:15px; }
.quote .who b { font-size:14px; display:block; } .quote .who span { font-size:12px; color:var(--muted); }
.stars { color:#f5a623; font-size:14px; margin-bottom:10px; }

/* ── dashboard: stat row, onboarding, skeletons ────────────────────────── */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:18px; }
@media (max-width:680px){ .stats{ grid-template-columns:repeat(2,1fr); } }
.stat { background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px 16px; }
.stat .v { font-size:24px; font-weight:800; letter-spacing:-.02em; }
.stat .k { font-size:12px; color:var(--muted); margin-top:2px; }
.stat.good .v { color:var(--green); } .stat.warn .v { color:var(--red); }

.onb { background:linear-gradient(135deg,#eef0ff,#f7f5ff); border:1px solid #e0e3fb; border-radius:18px; padding:24px; margin-bottom:18px; position:relative; }
.onb h2 { margin:0 0 4px; font-size:22px; }
.onb .sub { color:var(--muted); margin:0 0 18px; font-size:14px; }
.onb-steps { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:18px; }
@media (max-width:760px){ .onb-steps{ grid-template-columns:1fr; } }
.onb-step { background:#fff; border:1px solid var(--line); border-radius:12px; padding:16px; }
.onb-step .n { width:26px; height:26px; border-radius:50%; background:var(--indigo); color:#fff; display:grid; place-items:center; font-weight:700; font-size:13px; margin-bottom:8px; }
.onb-step h4 { margin:0 0 4px; font-size:15px; }
.onb-step p { margin:0; font-size:13px; color:var(--muted); }
.onb-close { position:absolute; top:14px; right:16px; cursor:pointer; color:var(--muted); font-size:20px; line-height:1; background:none; border:none; }
.chips { display:flex; gap:8px; flex-wrap:wrap; }
.chip { background:#fff; border:1px solid var(--line); border-radius:999px; padding:7px 14px; font-size:13px; cursor:pointer; font-weight:600; color:var(--ink); transition:border-color .15s, background .15s; }
.chip:hover { border-color:var(--indigo); background:#fbfbff; }
.chip small { color:var(--muted); font-weight:500; }

.skel { background:linear-gradient(90deg,#eef0f4 25%,#f6f7fc 37%,#eef0f4 63%); background-size:400% 100%; animation:sh 1.3s ease infinite; border-radius:8px; }
@keyframes sh { 0%{background-position:100% 0} 100%{background-position:-100% 0} }
.skel-card { height:96px; border-radius:14px; margin-bottom:12px; }

/* ── suggest-competitors modal ─────────────────────────────────────────── */
.modal-bg { position:fixed; inset:0; background:rgba(20,22,31,.5); display:flex; align-items:flex-start; justify-content:center; padding:40px 16px; z-index:50; overflow:auto; }
.modal { background:#fff; border-radius:18px; max-width:580px; width:100%; padding:26px; box-shadow:0 30px 80px -20px rgba(20,20,50,.5); }
.modal h2 { margin:0 0 4px; font-size:22px; }
.modal .x { float:right; cursor:pointer; border:none; background:none; font-size:22px; color:var(--muted); line-height:1; }
.sug-list { display:flex; flex-direction:column; gap:10px; margin-top:6px; }
.sug { border:1px solid var(--line); border-radius:12px; padding:12px 14px; display:flex; gap:12px; align-items:flex-start; }
.sug .em { font-size:22px; }
.sug .b { min-width:0; flex:1; }
.sug .b b { font-size:14px; }
.sug .b p { margin:2px 0 0; font-size:12px; color:var(--muted); }
.sug a.go { white-space:nowrap; font-size:13px; font-weight:700; }
.seg { display:flex; gap:8px; flex-wrap:wrap; margin:14px 0; }
.seg button { border:1px solid var(--line); background:#fff; border-radius:999px; padding:7px 14px; font-size:13px; cursor:pointer; font-weight:600; }
.seg button.on { background:var(--indigo); color:#fff; border-color:var(--indigo); }
