/* ============================================================
   AEGISMESH — SUITE DESIGN SYSTEM (light premium)
   Single shared stylesheet for every page. Navy/indigo + teal on white.
   ============================================================ */

:root {
  /* canvas */
  --bg:        #FFFFFF;
  --bg-alt:    #F5F8FC;
  --bg-tint:   #EFF3FA;
  --deep:      #0A1B33;        /* dark CTA / stat / footer band */

  /* ink */
  --ink:       #0B1F3A;
  --ink-soft:  #28344A;
  --body:      #4A5468;
  --muted:     #717C92;
  --on-dark:   #E8EDF6;
  --on-dark-soft:#9FB0CC;

  /* brand */
  --indigo:    #4F46E5;
  --indigo-d:  #4338CA;
  --indigo-l:  #EEEFFE;
  --teal:      #0FB5AE;
  --teal-d:    #0C8F89;
  --teal-l:    #E4FAF7;

  /* lines */
  --line:      rgba(11,31,58,0.10);
  --line-soft: rgba(11,31,58,0.055);

  /* gradient family */
  --grad:      linear-gradient(135deg, #4F46E5 0%, #5B8DEF 50%, #0FB5AE 100%);
  --grad-soft: linear-gradient(135deg, rgba(79,70,229,0.10), rgba(15,181,174,0.10));

  /* radii + shadow */
  --r-sm: 10px; --r-md: 16px; --r-lg: 22px; --r-pill: 999px;
  --sh-1: 0 1px 2px rgba(11,31,58,0.05);
  --sh-2: 0 6px 20px rgba(11,31,58,0.07);
  --sh-3: 0 18px 48px rgba(11,31,58,0.10);
  --sh-4: 0 30px 70px rgba(11,31,58,0.13);

  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --maxw: 1180px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body { font-family:var(--font); background:var(--bg); color:var(--body); line-height:1.6; overflow-x:hidden; }

h1,h2,h3,h4 { color:var(--ink); font-weight:800; line-height:1.1; letter-spacing:-0.025em; }
a { color:inherit; text-decoration:none; }
::selection { background:rgba(79,70,229,0.18); }

/* ---------- layout ---------- */
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.narrow { max-width:780px; margin:0 auto; }
section { padding:104px 0; position:relative; }
.band { background:var(--bg-alt); }
.rule { border-top:1px solid var(--line-soft); }

.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:12.5px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--indigo); margin-bottom:18px; }
.eyebrow .tick { width:18px; height:1.5px; background:var(--teal); display:inline-block; }
h2.title, .title { font-size:clamp(30px,3.9vw,46px); margin-bottom:18px; }
.lead { font-size:18px; color:var(--body); max-width:680px; line-height:1.65; }
.center { text-align:center; }
.center .lead, .center .eyebrow { margin-left:auto; margin-right:auto; }
.center .eyebrow { display:inline-flex; }

.skip { position:absolute; left:16px; top:-50px; background:var(--indigo); color:#fff; padding:8px 16px; border-radius:0 0 8px 8px; font-size:13px; font-weight:600; z-index:300; }
.skip:focus { top:0; }

/* ---------- buttons ---------- */
.btn { display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:15px; padding:13px 24px; border-radius:var(--r-pill); transition:all .2s ease; cursor:pointer; border:1px solid transparent; white-space:nowrap; }
.btn-primary { background:var(--indigo); color:#fff; box-shadow:0 6px 18px rgba(79,70,229,0.28); }
.btn-primary:hover { background:var(--indigo-d); transform:translateY(-1px); box-shadow:0 10px 26px rgba(79,70,229,0.34); }
.btn-ghost { background:#fff; color:var(--ink); border-color:var(--line); box-shadow:var(--sh-1); }
.btn-ghost:hover { border-color:var(--indigo); color:var(--indigo); }
.btn-light { background:#fff; color:var(--ink); }
.btn-light:hover { transform:translateY(-1px); box-shadow:var(--sh-2); }
.btn-arrow svg { width:16px; height:16px; transition:transform .2s; }
.btn:hover .btn-arrow svg { transform:translateX(3px); }

/* ---------- nav ---------- */
.nav { position:fixed; inset:0 0 auto 0; z-index:1000; transition:all .3s ease; }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:70px; }
.nav.scrolled { background:rgba(255,255,255,0.82); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border-bottom:1px solid var(--line-soft); }
.brand { display:flex; align-items:center; gap:11px; }
.brand .mark { width:30px; height:30px; }
.brand .word { font-weight:800; font-size:19px; letter-spacing:-0.02em; color:var(--ink); }
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-links a.l { font-size:14.5px; font-weight:500; color:var(--ink-soft); padding:9px 14px; border-radius:8px; transition:all .15s; }
.nav-links a.l:hover, .nav-links a.l.active { color:var(--indigo); background:var(--indigo-l); }
.nav-cta { margin-left:8px; }
.hamb { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.hamb span { width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
.hamb.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamb.open span:nth-child(2){ opacity:0; }
.hamb.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- homepage hero (two-col) ---------- */
.hero { padding:152px 0 96px; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-280px; right:-180px; width:780px; height:780px; border-radius:50%;
  background:radial-gradient(circle, rgba(79,70,229,0.10), rgba(15,181,174,0.06) 45%, transparent 70%); pointer-events:none; }
.hero-grid { display:grid; grid-template-columns:1.12fr 0.88fr; gap:56px; align-items:center; position:relative; z-index:1; }
.hero h1 { font-size:clamp(36px,4.7vw,58px); letter-spacing:-0.035em; margin-bottom:22px; }
.hero h1 .g { background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.hero p.sub { font-size:19px; line-height:1.6; max-width:560px; margin-bottom:30px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px; }
.surfaces { display:flex; align-items:center; gap:9px; flex-wrap:wrap; font-size:13px; color:var(--muted); }
.surfaces b { color:var(--ink-soft); font-weight:600; }
.surf-chip { display:inline-flex; align-items:center; gap:6px; padding:5px 11px; background:#fff; border:1px solid var(--line); border-radius:var(--r-pill); font-weight:500; color:var(--ink-soft); box-shadow:var(--sh-1); }
.surf-chip svg { width:14px; height:14px; color:var(--indigo); }
.hero-visual { position:relative; }
.hero-visual svg { width:100%; height:auto; display:block; filter:drop-shadow(0 24px 48px rgba(11,31,58,0.12)); }

/* ---------- sub-page hero (single col, centered or left) ---------- */
.page-hero { padding:148px 0 64px; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; top:-300px; left:50%; transform:translateX(-50%); width:900px; height:760px; border-radius:50%;
  background:radial-gradient(circle, rgba(79,70,229,0.08), rgba(15,181,174,0.05) 45%, transparent 70%); pointer-events:none; }
.page-hero .inner { position:relative; z-index:1; }
.page-hero h1 { font-size:clamp(34px,4.6vw,56px); letter-spacing:-0.03em; margin-bottom:20px; max-width:840px; }
.page-hero h1 .g { background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.page-hero .lead { font-size:19px; }
.page-hero .hero-actions { margin-top:30px; }
.kicker { display:inline-flex; align-items:center; gap:8px; padding:6px 14px; border:1px solid var(--line); background:#fff; border-radius:var(--r-pill); font-size:12.5px; font-weight:600; color:var(--ink-soft); box-shadow:var(--sh-1); margin-bottom:22px; }
.kicker .d { width:7px; height:7px; border-radius:50%; background:var(--teal); }

/* ---------- stat band ---------- */
.stat-band { background:var(--deep); color:var(--on-dark); padding:60px 0; }
.stat-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:center; }
.stat-grid .big { font-size:clamp(24px,3vw,33px); font-weight:800; color:#fff; line-height:1.25; letter-spacing:-0.02em; }
.stat-grid .big em { font-style:normal; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.stat-grid .src { font-size:13px; color:var(--on-dark-soft); margin-top:14px; }
.stat-side { border-left:1px solid rgba(255,255,255,0.14); padding-left:32px; }
.stat-side .num { font-size:40px; font-weight:800; color:#fff; letter-spacing:-0.02em; }
.stat-side .lbl { font-size:14px; color:var(--on-dark-soft); margin-top:4px; line-height:1.5; }

/* ---------- grids + cards ---------- */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:46px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:46px; }
.card { background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:30px; box-shadow:var(--sh-1); transition:all .25s ease; }
.card:hover { box-shadow:var(--sh-3); transform:translateY(-3px); border-color:rgba(79,70,229,0.25); }
.card .ico { width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:var(--indigo-l); margin-bottom:18px; }
.card .ico svg { width:24px; height:24px; color:var(--indigo); }
.card h3 { font-size:18.5px; margin-bottom:9px; letter-spacing:-0.01em; }
.card p { font-size:14.5px; color:var(--body); line-height:1.62; }
.card .more { display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:14px; font-weight:600; color:var(--indigo); }
.card .more svg { width:15px; height:15px; transition:transform .2s; }
.card:hover .more svg { transform:translateX(3px); }

/* ---------- mini points ---------- */
.mini-row { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:42px; }
.mini { padding:24px; border:1px solid var(--line); border-radius:var(--r-md); background:#fff; }
.mini .k { font-size:13px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--teal-d); margin-bottom:9px; }
.mini h4 { font-size:16px; margin-bottom:7px; }
.mini p { font-size:14px; color:var(--body); }

/* ---------- pillars ---------- */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin:46px 0 0; }
.pillar { padding:8px 4px; }
.pillar .step { font-size:12px; font-weight:700; letter-spacing:0.12em; color:var(--indigo); text-transform:uppercase; }
.pillar h3 { font-size:21px; margin:10px 0 8px; }
.pillar p { font-size:14.5px; color:var(--body); }

/* ---------- product-UI mock ---------- */
.mock { margin-top:54px; border-radius:var(--r-lg); border:1px solid var(--line); background:#fff; box-shadow:var(--sh-4); overflow:hidden; }
.mock-top { display:flex; align-items:center; gap:8px; padding:13px 18px; border-bottom:1px solid var(--line-soft); background:var(--bg-alt); }
.mock-top .dot { width:10px; height:10px; border-radius:50%; background:#D4DAE6; }
.mock-top .mt-title { margin-left:10px; font-size:13px; font-weight:600; color:var(--ink-soft); }
.mock-top .mt-pill { margin-left:auto; font-size:11.5px; font-weight:600; color:var(--teal-d); background:var(--teal-l); padding:4px 10px; border-radius:var(--r-pill); }
table.agents { width:100%; border-collapse:collapse; font-size:13.5px; }
table.agents th { text-align:left; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--muted); font-weight:700; padding:14px 20px; border-bottom:1px solid var(--line-soft); }
table.agents td { padding:14px 20px; border-bottom:1px solid var(--line-soft); color:var(--ink-soft); }
table.agents tr:last-child td { border-bottom:none; }
.ag-name { display:flex; align-items:center; gap:10px; font-weight:600; color:var(--ink); }
.ag-dot { width:8px; height:8px; border-radius:50%; }
.pill { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:4px 10px; border-radius:var(--r-pill); }
.pill-allow { background:var(--teal-l); color:var(--teal-d); }
.pill-deny  { background:#FDE7EA; color:#B0303F; }
.pill-watch { background:#FEF4E0; color:#9A6B12; }
.surf-tag { font-size:12px; color:var(--muted); }
.owner { font-size:13px; color:var(--body); }

/* ---------- coverage ---------- */
.cov-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-top:46px; }
.cov { text-align:center; padding:28px 16px; border:1px solid var(--line); border-radius:var(--r-md); background:#fff; transition:all .2s; }
.cov:hover { box-shadow:var(--sh-2); transform:translateY(-2px); }
.cov .ci { width:48px; height:48px; margin:0 auto 14px; border-radius:12px; background:var(--grad-soft); display:flex; align-items:center; justify-content:center; }
.cov .ci svg { width:25px; height:25px; color:var(--indigo); }
.cov h4 { font-size:15.5px; margin-bottom:5px; }
.cov .st { font-size:12px; font-weight:600; }
.cov .st.live { color:var(--teal-d); }
.cov .st.soon { color:var(--muted); }

/* ---------- identity / quote ---------- */
.id-grid { display:grid; grid-template-columns:1fr 0.9fr; gap:48px; align-items:center; }
.idp-row { display:flex; gap:12px; flex-wrap:wrap; margin:26px 0 4px; }
.idp { display:inline-flex; align-items:center; gap:8px; padding:10px 16px; background:#fff; border:1px solid var(--line); border-radius:var(--r-pill); font-weight:600; font-size:14px; color:var(--ink-soft); box-shadow:var(--sh-1); }
.idp .d { width:9px; height:9px; border-radius:50%; background:var(--teal); }
.quote { background:var(--deep); color:#fff; border-radius:var(--r-lg); padding:40px 38px; box-shadow:var(--sh-3); position:relative; }
.quote .mark { font-size:64px; line-height:0.5; color:var(--teal); font-weight:800; opacity:.5; }
.quote p { font-size:20px; line-height:1.5; color:#fff; font-weight:600; letter-spacing:-0.01em; margin-top:12px; }
.quote p .hl { background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* ---------- callout note ---------- */
.why-note, .note { margin-top:34px; padding:22px 26px; border-left:3px solid var(--teal); background:var(--bg-alt); border-radius:0 var(--r-md) var(--r-md) 0; font-size:15.5px; color:var(--ink-soft); }
.why-note b, .note b { color:var(--ink); }

/* ---------- trust ---------- */
.trust-card h3 { font-size:13px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--indigo); margin-bottom:12px; }
.trust-card p { font-size:14.5px; color:var(--body); line-height:1.65; }
.trust-card a { color:var(--indigo); font-weight:600; }

/* ---------- feature rows (alternating text / visual) ---------- */
.feature { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; margin-top:72px; }
.feature:first-of-type { margin-top:46px; }
.feature.rev .ftext { order:2; }
.feature .ftext h3 { font-size:clamp(22px,2.6vw,30px); margin-bottom:14px; letter-spacing:-0.02em; }
.feature .ftext p { font-size:16px; color:var(--body); line-height:1.65; }
.feature .fvis { background:var(--bg-alt); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; min-height:240px; display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-2); }
.feature .fvis img, .feature .fvis svg { max-width:100%; height:auto; display:block; }

/* ---------- checklist ---------- */
.checklist { list-style:none; margin-top:18px; display:flex; flex-direction:column; gap:13px; }
.checklist li { display:flex; gap:12px; font-size:15.5px; color:var(--ink-soft); line-height:1.5; }
.checklist li svg { flex:0 0 22px; width:22px; height:22px; color:var(--teal); margin-top:1px; }
.checklist li b { color:var(--ink); }

/* ---------- numbered steps ---------- */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px; counter-reset:s; }
.step-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:28px; position:relative; box-shadow:var(--sh-1); }
.step-card .n { width:34px; height:34px; border-radius:50%; background:var(--indigo); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:15px; margin-bottom:16px; }
.step-card h4 { font-size:17px; margin-bottom:8px; }
.step-card p { font-size:14px; color:var(--body); line-height:1.6; }

/* ---------- logos / proof row ---------- */
.logos { display:flex; flex-wrap:wrap; gap:14px 28px; align-items:center; justify-content:center; margin-top:34px; }
.logos .lg { font-weight:700; font-size:15px; color:var(--muted); letter-spacing:-0.01em; opacity:.8; }

/* ---------- pricing ---------- */
.price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px; align-items:stretch; }
.price { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:32px; display:flex; flex-direction:column; box-shadow:var(--sh-1); }
.price.feat { border-color:var(--indigo); box-shadow:0 18px 48px rgba(79,70,229,0.16); position:relative; }
.price .ribbon { position:absolute; top:-12px; left:32px; background:var(--indigo); color:#fff; font-size:11px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:5px 12px; border-radius:var(--r-pill); }
.price .pname { font-size:13px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--indigo); }
.price .pdesc { font-size:14px; color:var(--body); margin:10px 0 18px; min-height:42px; }
.price .checklist { flex:1; }
.price .btn { margin-top:24px; justify-content:center; }

/* ---------- faq ---------- */
.faq { margin-top:40px; max-width:820px; }
.faq details { border-bottom:1px solid var(--line); padding:20px 0; }
.faq summary { font-size:17px; font-weight:600; color:var(--ink); cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; font-size:22px; color:var(--indigo); font-weight:400; line-height:1; }
.faq details[open] summary::after { content:'\2013'; }
.faq p { margin-top:12px; font-size:15px; color:var(--body); line-height:1.65; }

/* ---------- CTA ---------- */
.cta { background:var(--deep); color:#fff; text-align:center; padding:96px 0; position:relative; overflow:hidden; }
.cta::before { content:''; position:absolute; left:50%; top:-40%; width:760px; height:760px; transform:translateX(-50%); border-radius:50%; background:radial-gradient(circle, rgba(79,70,229,0.30), rgba(15,181,174,0.12) 45%, transparent 70%); pointer-events:none; }
.cta h2 { color:#fff; font-size:clamp(30px,4vw,46px); margin-bottom:16px; position:relative; }
.cta p { color:var(--on-dark-soft); font-size:18px; max-width:560px; margin:0 auto 30px; position:relative; }
.cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; }

/* ---------- footer ---------- */
footer { background:#fff; border-top:1px solid var(--line); padding:56px 0 44px; }
.foot-grid { display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.foot-brand { max-width:300px; }
.foot-brand p { font-size:13.5px; color:var(--muted); margin-top:14px; }
.foot-cols { display:flex; gap:56px; flex-wrap:wrap; }
.foot-col h5 { font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink); margin-bottom:14px; }
.foot-col a { display:block; font-size:14px; color:var(--body); margin-bottom:10px; transition:color .15s; }
.foot-col a:hover { color:var(--indigo); }
.foot-bottom { margin-top:44px; padding-top:24px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; color:var(--muted); }
.foot-bottom a { color:var(--indigo); font-weight:600; }

/* ---------- prose (legal / docs pages) ---------- */
.prose { max-width:760px; }
.prose h2 { font-size:24px; margin:38px 0 12px; }
.prose h3 { font-size:18px; margin:26px 0 10px; }
.prose p, .prose li { font-size:15.5px; color:var(--body); line-height:1.7; }
.prose ul { margin:12px 0 12px 22px; }
.prose li { margin-bottom:8px; }
.prose a { color:var(--indigo); font-weight:500; }
.prose strong { color:var(--ink); }
.prose .updated { font-size:13px; color:var(--muted); margin-bottom:30px; }

/* ---------- contact / demo form ---------- */
.form-card { background:#fff; border-radius:var(--r-lg); box-shadow:var(--sh-4); padding:34px; max-width:560px; margin:34px auto 0; text-align:left; position:relative; z-index:1; }
.form-card .form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field { display:flex; flex-direction:column; gap:7px; margin-bottom:0; }
.field.col-2 { grid-column:span 2; }
.field label { font-size:13px; font-weight:600; color:var(--ink-soft); letter-spacing:-0.005em; }
.field label .req { color:var(--indigo); }
.field input, .field select, .field textarea {
  font-family:var(--font); font-size:15px; color:var(--ink); background:#fff;
  border:1px solid var(--line); border-radius:var(--r-sm); padding:12px 14px; width:100%;
  transition:border-color .15s ease, box-shadow .15s ease; -webkit-appearance:none; appearance:none;
}
.field textarea { resize:vertical; min-height:84px; line-height:1.55; }
.field select {
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234F46E5' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center; background-size:15px; padding-right:40px; cursor:pointer;
}
.field input::placeholder, .field textarea::placeholder { color:var(--muted); }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px rgba(79,70,229,0.14); }
.form-honeypot { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-submit { width:100%; justify-content:center; margin-top:20px; font-size:16px; padding:15px 24px; }
.form-foot { margin-top:14px; font-size:12.5px; color:var(--muted); text-align:center; line-height:1.55; }
.form-foot a { color:var(--indigo); font-weight:600; }
.form-success { display:none; text-align:center; padding:20px 6px; }
.form-card.done .form-body { display:none; }
.form-card.done .form-success { display:block; }
.form-success .chk { width:56px; height:56px; margin:0 auto 16px; border-radius:50%; background:var(--teal-l); display:flex; align-items:center; justify-content:center; }
.form-success .chk svg { width:28px; height:28px; color:var(--teal-d); }
.form-success h3 { font-size:21px; color:var(--ink); margin-bottom:8px; }
.form-success p { font-size:14.5px; color:var(--body); max-width:380px; margin:0 auto; }

/* ---------- reveal — progressive enhancement ---------- */
html.js .reveal { opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
html.js .reveal.in { opacity:1; transform:none; }
.d1 { transition-delay:.08s; } .d2 { transition-delay:.16s; } .d3 { transition-delay:.24s; }

@keyframes flow { 0%{ opacity:0; } 12%{ opacity:1; } 88%{ opacity:1; } 100%{ opacity:0; } }
.flow-dot { animation:flow 3s ease-in-out infinite; }
@keyframes glow { 0%,100%{ opacity:.55; transform:scale(1); } 50%{ opacity:.95; transform:scale(1.06); } }
.glow-ring { transform-origin:center; animation:glow 5s ease-in-out infinite; }

:focus-visible { outline:2px solid var(--indigo); outline-offset:3px; border-radius:6px; }

/* ---------- responsive ---------- */
@media (max-width:960px){
  .hero-grid, .id-grid, .stat-grid, .feature { grid-template-columns:1fr; }
  .hero-visual { order:-1; max-width:480px; }
  .feature.rev .ftext { order:0; }
  .grid-3, .mini-row, .pillars, .steps, .price-grid, .grid-4 { grid-template-columns:1fr; }
  .grid-2 { grid-template-columns:1fr; }
  .cov-grid { grid-template-columns:repeat(2,1fr); }
  .stat-side { border-left:none; padding-left:0; border-top:1px solid rgba(255,255,255,.14); padding-top:24px; }
  .nav-links { display:none; position:absolute; top:70px; left:0; right:0; background:#fff; flex-direction:column; align-items:stretch; padding:14px 20px; gap:2px; border-bottom:1px solid var(--line); box-shadow:var(--sh-2); }
  .nav-links.open { display:flex; }
  .nav-links a.l { padding:12px 14px; }
  .nav-cta { display:none; }
  .hamb { display:flex; }
}
@media (max-width:560px){
  section { padding:72px 0; }
  .cov-grid { grid-template-columns:1fr; }
  .foot-cols { gap:32px; }
  .hero, .page-hero { padding-top:116px; }
  /* form collapses to one column (match .form-card .form-grid specificity) */
  .form-card .form-grid { grid-template-columns:1fr; }
  .field.col-2 { grid-column:auto; }
  .form-card { padding:24px 20px; }
  /* the product-mock table is wider than the phone — let it swipe horizontally
     inside the card instead of being clipped by the card's overflow:hidden */
  .mock-body { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  table.agents { min-width:430px; }
  table.agents th, table.agents td { padding:12px 14px; }
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.001ms!important; transition-duration:.001ms!important; }
  .reveal { opacity:1; transform:none; }
  html { scroll-behavior:auto; }
}
