/* ============================================================
   AimVisible marketing site styles
   Brand: pure white, teal/gold/coral/ink, Plus Jakarta Sans.
   ============================================================ */

:root{
  --teal:#2fb3a4; --teal-700:#1f8d80; --teal-300:#7fd0c6;
  --gold:#d9a22a; --gold-700:#b9851a;
  --coral:#df4340; --coral-700:#c4322f;
  --ink:#1a2238; --ink-900:#11162a;
  --bg:#ffffff; --bg-subtle:#f6f7f9; --bg-hover:#f1f3f6;
  --fg:#1a2238; --fg-2:#515a70; --fg-3:#656d82;
  --on-dark:#ffffff; --on-dark-2:#aab1c4;
  --line:#e8eaef; --line-strong:#d6dae2;
  --teal-tint:#e6f6f3; --gold-tint:#fbf2dd; --coral-tint:#fdeae9; --ink-tint:#eceef3;
  --r-sm:10px; --r-md:12px; --r-lg:16px; --r-xl:22px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(26,34,56,.05);
  --shadow-md:0 1px 2px rgba(26,34,56,.04),0 6px 18px rgba(26,34,56,.06);
  --shadow-lg:0 2px 4px rgba(26,34,56,.05),0 18px 40px rgba(26,34,56,.10);
  --shadow-pop:0 8px 30px rgba(26,34,56,.14);
  --display:'Bricolage Grotesque',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  --sans:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--fg);background:var(--bg);
  font-size:16px;line-height:1.55;font-weight:500;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--teal-tint);color:var(--ink)}
h1,h2,h3,h4{margin:0;font-family:var(--display);letter-spacing:-0.02em;font-weight:800;line-height:1.05;color:var(--fg)}
p{margin:0;color:var(--fg-2);text-wrap:pretty}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:104px 0}
.section-sm{padding:72px 0}

/* ---- eyebrow / pill ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font:800 12.5px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;
  color:#fff;background:var(--teal);
  padding:10px 18px;border-radius:var(--r-pill);white-space:nowrap;
  box-shadow:0 8px 20px rgba(47,179,164,.34);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.kicker{
  font:700 13px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);
}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font:700 15px/1 var(--sans);letter-spacing:-0.01em;
  padding:15px 24px;border-radius:var(--r-sm);cursor:pointer;border:1.5px solid transparent;
  transition:background .16s ease,color .16s ease,border-color .16s ease,transform .16s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--ink);color:#fff}
.btn-primary:active{background:var(--ink-900);transform:translateY(1px)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--teal);color:#fff}
.btn-lg{padding:18px 30px;font-size:16px}
.btn .ic{width:18px;height:18px;stroke-width:2.2}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}
.header.scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:19px;letter-spacing:-0.02em}
.brand img{width:34px;height:34px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:9px 14px;border-radius:var(--r-sm);font-weight:600;font-size:14.5px;color:var(--fg-2);transition:background .15s,color .15s}
.nav-links a:hover{background:var(--ink);color:#fff}
.nav-login{padding:9px 12px;border-radius:var(--r-sm);font-weight:700;font-size:14.5px;color:var(--fg-2)}
.nav-login:hover{background:var(--ink);color:#fff}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;padding:78px 0 96px}
.hero-wave{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(1100px 520px at 88% -8%, var(--teal-tint) 0%, rgba(230,246,243,0) 60%),
            radial-gradient(900px 480px at 6% 108%, var(--gold-tint) 0%, rgba(251,242,221,0) 58%);
  opacity:.9}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(38px,5.1vw,62px);line-height:1.02;letter-spacing:-0.035em}
.hero h1 .accent{color:var(--teal)}
.hero .lede{margin-top:24px;font-size:19px;line-height:1.6;color:var(--fg-2);max-width:560px}
.hero .cta-row{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero .trust{margin-top:30px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--fg-3);font-size:13.5px;font-weight:600}
.trust-line{display:flex;align-items:center;gap:9px}
.trust-line .ic{width:17px;height:17px;color:var(--teal);stroke-width:2.4}

/* connectors strip */
.connectors{margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.connectors .lbl{font:700 11px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3)}
.connector-row{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.connector{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line);border-radius:var(--r-pill);font-weight:700;font-size:13px;color:var(--fg-2);background:#fff}
.connector .swatch{width:10px;height:10px;border-radius:3px}

/* ---- product mock (hero) ---- */
.mock-stack{position:relative;display:flex;flex-direction:column;gap:18px}
.mock{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.mock-head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--line)}
.mock-head .title{display:flex;align-items:center;gap:10px;font-weight:800;font-size:14.5px}
.mock-head .badge-mono{font:600 10.5px/1 var(--mono);letter-spacing:.04em;color:var(--fg-3);background:var(--bg-subtle);padding:6px 9px;border-radius:6px}
.decision{padding:20px}
.decision .row1{display:flex;align-items:flex-start;gap:14px}
.icon-badge{flex:none;width:44px;height:44px;border-radius:var(--r-md);display:grid;place-items:center}
.icon-badge .ic{width:22px;height:22px;stroke-width:2.2}
.ib-teal{background:var(--teal-tint);color:var(--teal)}
.ib-gold{background:var(--gold-tint);color:var(--gold-700)}
.ib-coral{background:var(--coral-tint);color:var(--coral)}
.ib-ink{background:var(--ink-tint);color:var(--ink)}
.decision h4{font-size:16.5px;letter-spacing:-0.02em}
.decision .why{margin-top:6px;font-size:14px;line-height:1.5;color:var(--fg-2)}
.decision .meta{margin-top:16px;display:flex;gap:22px;flex-wrap:wrap}
.metaitem .k{font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3)}
.metaitem .v{margin-top:6px;font-weight:800;font-size:20px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.metaitem .v.pos{color:var(--teal-700)}
.decision .actions{margin-top:18px;display:flex;gap:10px}
.act{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:var(--r-sm);font-weight:700;font-size:14px;border:1.5px solid var(--line-strong);background:#fff;color:var(--ink);cursor:pointer;transition:.15s}
.act .ic{width:16px;height:16px;stroke-width:2.4}
.act.go{background:var(--teal);color:#fff;border-color:var(--teal);flex:1.4}
.act.go:hover{background:var(--ink);border-color:var(--ink)}
.act.defer:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* mini kpi pulse card */
.pulse{padding:16px 20px}
.pulse-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.pulse-head .t{font-weight:800;font-size:13.5px;display:flex;align-items:center;gap:8px}
.live{display:inline-flex;align-items:center;gap:6px;font:600 10px/1 var(--mono);letter-spacing:.08em;color:var(--teal-700);text-transform:uppercase}
.live .led{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(47,179,164,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,179,164,.45)}70%{box-shadow:0 0 0 7px rgba(47,179,164,0)}100%{box-shadow:0 0 0 0 rgba(47,179,164,0)}}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.kpi{border:1px solid var(--line);border-radius:var(--r-md);padding:12px}
.kpi .k{font:600 9.5px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3)}
.kpi .v{margin-top:8px;font-weight:800;font-size:19px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.kpi .d{margin-top:5px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:3px}
.kpi .d.up{color:var(--teal-700)} .kpi .d.down{color:var(--coral)}
.float-tag{position:absolute;display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-pop);border-radius:var(--r-md);padding:11px 14px;font-weight:700;font-size:13px}
.float-tag .ring{width:26px;height:26px}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{max-width:720px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head h2{margin-top:18px;font-size:clamp(30px,3.7vw,46px);letter-spacing:-0.03em;line-height:1.05}
.sec-head p{margin-top:18px;font-size:18px;color:var(--fg-2)}

/* ============================================================
   COMPARISON (agency vs aimvisible)
   ============================================================ */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:54px}
.compare-col{border-radius:var(--r-xl);padding:34px;border:1px solid var(--line)}
.compare-col.old{background:var(--bg-subtle)}
.compare-col.new{background:var(--ink);color:#fff;border-color:var(--ink)}
.compare-col .tag{display:inline-flex;align-items:center;gap:8px;font:700 12px/1 var(--sans);letter-spacing:.06em;text-transform:uppercase;padding:7px 12px;border-radius:var(--r-pill)}
.compare-col.old .tag{background:#fff;color:var(--fg-3);border:1px solid var(--line)}
.compare-col.new .tag{background:rgba(255,255,255,.12);color:var(--teal-300)}
.compare-col h3{margin-top:20px;font-size:23px;letter-spacing:-0.02em}
.compare-col.new h3{color:#fff}
.compare-list{margin-top:22px;display:flex;flex-direction:column;gap:14px}
.cl-item{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.45}
.cl-item .ic{flex:none;width:20px;height:20px;margin-top:1px;stroke-width:2.3}
.compare-col.old .cl-item{color:var(--fg-2)} .compare-col.old .cl-item .ic{color:var(--coral)}
.compare-col.new .cl-item{color:var(--on-dark-2)} .compare-col.new .cl-item .ic{color:var(--teal-300)}
.compare-col.new .cl-item b{color:#fff;font-weight:700}

/* ============================================================
   HOW IT WORKS steps
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-md);overflow:hidden}
.step::before{content:"";position:absolute;left:0;top:0;right:0;height:3px}
.step.s1::before{background:var(--teal)} .step.s2::before{background:var(--gold)} .step.s3::before{background:var(--coral)}
.step .num{font:800 13px/1 var(--mono);color:var(--fg-3);letter-spacing:.05em}
.step .claywrap{margin:6px 0 18px;width:96px;height:96px;display:grid;place-items:center}
.step .claywrap img{width:96px;height:96px;object-fit:contain;filter:drop-shadow(0 8px 16px rgba(26,34,56,.10))}
.step h3{font-size:20px;letter-spacing:-0.02em}
.step p{margin-top:10px;font-size:15px}

/* ============================================================
   DIFFERENTIATORS coded cards
   ============================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.feat{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-md);overflow:hidden}
.feat::before{content:"";position:absolute;left:0;top:0;right:0;height:3px}
.feat.t::before{background:var(--teal)} .feat.g::before{background:var(--gold)} .feat.c::before{background:var(--coral)}
.feat h3{margin-top:18px;font-size:21px;letter-spacing:-0.02em}
.feat p{margin-top:11px;font-size:15px}
.feat .mini{margin-top:18px;display:flex;flex-direction:column;gap:9px}
.mini-row{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--fg-2);line-height:1.4}
.mini-row .ic{flex:none;width:17px;height:17px;margin-top:1px;color:var(--teal);stroke-width:2.4}

/* ============================================================
   PRODUCT TOUR
   ============================================================ */
.tour{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center;margin-top:54px}
.tour.rev{direction:rtl}.tour.rev>*{direction:ltr}
.tour-copy h3{font-size:28px;letter-spacing:-0.025em}
.tour-copy p{margin-top:14px;font-size:16px}
.tour-copy .pts{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.tour-img{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg)}
.tour-img img{width:100%;height:100%;object-fit:cover}

/* revenue chart mock */
.chartcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:22px}
.chartcard .ch-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.chartcard .ch-head .v{font-weight:800;font-size:30px;letter-spacing:-0.03em;font-variant-numeric:tabular-nums}
.chartcard .ch-head .d{margin-top:6px;font-size:13px;font-weight:700;color:var(--teal-700);display:inline-flex;gap:5px;align-items:center}
.seg{display:flex;gap:4px;background:var(--bg-subtle);padding:4px;border-radius:var(--r-sm)}
.seg span{font:700 12px/1 var(--sans);color:var(--fg-3);padding:7px 11px;border-radius:7px}
.seg span.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

/* ============================================================
   METRICS dark band
   ============================================================ */
.metrics{background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:64px 48px;position:relative;overflow:hidden}
.metrics .kicker{color:var(--teal-300)}
.metrics h2{color:#fff;margin-top:16px;font-size:clamp(28px,3.4vw,40px);letter-spacing:-0.03em;max-width:680px}
.metric-grid{margin-top:48px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.metric .v{font-weight:800;font-size:clamp(38px,4.4vw,56px);letter-spacing:-0.04em;line-height:1;font-variant-numeric:tabular-nums}
.metric.t .v{color:var(--teal-300)} .metric.g .v{color:var(--gold)} .metric.c .v{color:#ef6f6c}
.metric .l{margin-top:14px;font-size:14.5px;color:var(--on-dark-2);line-height:1.45}
.metrics .divider{height:1px;background:rgba(255,255,255,.1);margin:44px 0}

/* testimonial */
.quote{display:grid;grid-template-columns:300px 1fr;gap:44px;align-items:center}
.quote .photo{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:1/1.05;border:1px solid rgba(255,255,255,.12)}
.quote .photo img{width:100%;height:100%;object-fit:cover}
.quote blockquote{margin:0;font-size:clamp(20px,2.3vw,27px);line-height:1.4;font-weight:600;letter-spacing:-0.02em;color:#fff}
.quote .who{margin-top:22px;display:flex;align-items:center;gap:12px}
.quote .who .nm{font-weight:800;font-size:15px;color:#fff}
.quote .who .rl{font-size:13px;color:var(--on-dark-2)}

/* ============================================================
   PRICING / HOW WE WORK
   ============================================================ */
.pricing{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:54px}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.price-top{padding:32px;border-bottom:1px solid var(--line)}
.price-top .badge{display:inline-flex;align-items:center;gap:8px;background:var(--teal-tint);color:var(--teal-700);font:700 12px/1 var(--sans);letter-spacing:.05em;text-transform:uppercase;padding:7px 12px;border-radius:var(--r-pill)}
.price-top .amt{margin-top:20px;display:flex;align-items:baseline;gap:10px}
.price-top .amt .big{font-weight:800;font-size:46px;letter-spacing:-0.04em}
.price-top .amt .sub{color:var(--fg-3);font-weight:600;font-size:15px}
.price-top .note{margin-top:12px;font-size:14.5px;color:var(--fg-2)}
.price-body{padding:28px 32px 32px}
.price-body .pl{display:flex;flex-direction:column;gap:13px}
.pl-row{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.45}
.pl-row .ic{flex:none;width:20px;height:20px;margin-top:1px;color:var(--teal);stroke-width:2.3}
.price-body .btn{width:100%;margin-top:26px}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:840px;margin:48px auto 0}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;
  background:none;border:none;cursor:pointer;text-align:left;padding:26px 4px;font-family:var(--sans)}
.qa .q{font-weight:700;font-size:18px;letter-spacing:-0.015em;color:var(--fg)}
.qa .pm{flex:none;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:.18s;color:var(--fg-2)}
.qa .pm .ic{width:16px;height:16px;stroke-width:2.4;transition:transform .22s}
.qa[aria-expanded="true"] .pm{background:var(--ink);border-color:var(--ink);color:#fff}
.qa[aria-expanded="true"] .pm .ic{transform:rotate(45deg)}
.qa .a{overflow:hidden;max-height:0;transition:max-height .3s ease}
.qa .a p{padding:0 4px 26px;font-size:15.5px;color:var(--fg-2);max-width:680px}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{position:relative;overflow:hidden;border-radius:var(--r-xl);border:1px solid var(--line);box-shadow:var(--shadow-md)}
.final-grid{display:grid;grid-template-columns:1.05fr .95fr}
.final-copy{padding:64px 56px}
.final-copy h2{font-size:clamp(30px,3.6vw,44px);letter-spacing:-0.03em;line-height:1.05}
.final-copy p{margin-top:18px;font-size:18px;max-width:460px}
.final-copy .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.final-copy .micro{margin-top:22px;font-size:13.5px;color:var(--fg-3);display:flex;align-items:center;gap:8px}
.final-img{position:relative;min-height:420px}
.final-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:64px 0 40px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.foot-brand .brand{margin-bottom:14px}
.foot-brand p{font-size:14px;max-width:300px}
.foot-col h5{font:700 12px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);margin-bottom:16px}
.foot-col a{display:block;padding:6px 0;font-size:14.5px;color:var(--fg-2);font-weight:600}
.foot-col a:hover{color:var(--teal-700)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.foot-bottom .c{font-size:13px;color:var(--fg-3)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .mock-stack{max-width:520px}
  .tour,.tour.rev{grid-template-columns:1fr;direction:ltr;gap:30px}
  .quote{grid-template-columns:220px 1fr;gap:30px}
  .pricing{grid-template-columns:1fr;gap:32px}
  .metric-grid{grid-template-columns:repeat(2,1fr);gap:28px}
}
@media (max-width:820px){
  .section{padding:76px 0}
  .nav-links,.connectors{display:none}
  .steps,.feat-grid,.compare{grid-template-columns:1fr}
  .final-grid{grid-template-columns:1fr}
  .final-img{min-height:280px;order:-1}
  .final-copy{padding:44px 32px}
  .metrics{padding:48px 28px}
  .quote{grid-template-columns:1fr}
  .quote .photo{max-width:200px}
  .foot-top{grid-template-columns:1fr 1fr}
  .nav-toggle{display:grid}
}
@media (max-width:520px){
  .wrap{padding:0 20px}
  .metric-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .hero .cta-row .btn{width:100%}
}

/* =======================================================================
   V2 ELEVATION
   ======================================================================= */

/* ---- scroll reveal ---- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,.84,.44,1),transform .75s cubic-bezier(.16,.84,.44,1)}
  .reveal.in{opacity:1;transform:none}
}
.kicker{color:var(--teal-700)}

/* ---- HERO rebuilt: centered statement + product stage ---- */
.hero{padding:60px 0 0;text-align:center;overflow:visible}
.hero-wave{background:
  radial-gradient(760px 420px at 50% -10%, var(--teal-tint) 0%, rgba(230,246,243,0) 64%),
  radial-gradient(640px 380px at 87% 32%, var(--gold-tint) 0%, rgba(251,242,221,0) 58%),
  radial-gradient(560px 360px at 11% 30%, rgba(223,67,64,.06) 0%, rgba(253,234,233,0) 58%);
  opacity:1}
.hero-grid{display:block}
.hero-copy{max-width:940px;margin:0 auto;text-align:center}
.hero .eyebrow{margin-bottom:28px}
.hero h1{font-size:clamp(42px,6.6vw,78px);line-height:.98;letter-spacing:-0.042em;max-width:16ch;margin:0 auto}
.hero .lede{margin:28px auto 0;font-size:clamp(17px,1.9vw,21px);line-height:1.55;max-width:610px}
.hero .cta-row{justify-content:center;margin-top:36px}
.hero .trust{justify-content:center;margin-top:26px}

.hero-stage{position:relative;max-width:1080px;margin:72px auto 0;text-align:left}
.hero-stage::before{content:"";position:absolute;z-index:0;left:50%;top:18px;width:74%;height:78%;
  transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(closest-side,rgba(47,179,164,.22),rgba(47,179,164,0));filter:blur(26px)}
.app-frame{position:relative;z-index:2;border-radius:20px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-lg);overflow:hidden}
.app-bar{display:flex;align-items:center;gap:16px;height:48px;padding:0 18px;border-bottom:1px solid var(--line);background:var(--bg-subtle)}
.app-dots{display:flex;gap:7px}
.app-dots i{width:11px;height:11px;border-radius:50%;background:#d6dae2}
.app-url{font:600 12px/1 var(--mono);color:var(--fg-3);background:#fff;border:1px solid var(--line);padding:7px 16px;border-radius:8px}
.app-body{display:grid;grid-template-columns:212px 1fr}
.app-rail{border-right:1px solid var(--line);padding:16px 12px;display:flex;flex-direction:column;gap:3px}
.rail-brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:14px;letter-spacing:-0.02em;padding:6px 8px 14px}
.rail-brand img{width:24px;height:24px}
.rail-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-weight:600;font-size:13px;color:var(--fg-2)}
.rail-item .ic{width:16px;height:16px;color:var(--fg-3);stroke-width:2.2}
.rail-item.on{background:var(--teal-tint);color:var(--ink)}
.rail-item.on .ic{color:var(--teal)}
.rail-item .badge{margin-left:auto;background:var(--coral);color:#fff;font:700 10px/1 var(--sans);padding:3px 6px;border-radius:999px}
.app-main{padding:22px 24px 26px}
.app-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.app-h .t{font-weight:800;font-size:16px;letter-spacing:-0.02em}
.app-h .day{font:600 11px/1 var(--mono);color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em}
.app-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.app-kpi{border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px}
.app-kpi .k{font:600 9.5px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3)}
.app-kpi .v{margin-top:9px;font-weight:800;font-size:21px;letter-spacing:-0.025em;font-variant-numeric:tabular-nums}
.app-kpi .d{margin-top:6px;font-size:11px;font-weight:700;display:inline-flex;gap:4px;align-items:center}
.app-kpi .d.up{color:var(--teal-700)}
.app-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.app-card .ac-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line)}
.app-card .ac-head .t{display:flex;align-items:center;gap:9px;font-weight:800;font-size:13.5px}
/* floating chips */
.chip{position:absolute;z-index:4;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-pop);border-radius:14px;padding:12px 15px}
.chip .ring{width:32px;height:32px;flex:none}
.chip .ct{font-weight:800;font-size:14px;letter-spacing:-0.01em;line-height:1.1}
.chip .cs{font:600 10.5px/1 var(--mono);color:var(--fg-3);margin-top:4px;letter-spacing:.02em}
.chip .ib{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:none}
.chip .ib .ic{width:18px;height:18px;stroke-width:2.3}
.chip.tl{left:-30px;top:96px;animation:floaty 6s ease-in-out infinite}
.chip.br{right:-30px;bottom:42px;animation:floaty 6s ease-in-out infinite .8s}
@media (prefers-reduced-motion: reduce){.chip.tl,.chip.br{animation:none}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* connector strip */
.cstrip{margin-top:60px}
.cstrip .lbl{text-align:center;font:700 11px/1 var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.cwords{margin-top:22px;display:flex;align-items:center;justify-content:center;gap:14px 40px;flex-wrap:wrap}
.cword{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:-0.02em;color:var(--fg-2);opacity:.8;transition:opacity .2s}
.cword:hover{opacity:1}
.cword .swatch{width:9px;height:9px;border-radius:3px}

/* ---- card hover lift ---- */
.feat,.step{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.feat:hover,.step:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--line-strong)}
.compare-col,.price-card,.tour-img,.chartcard,.mock{transition:transform .22s ease,box-shadow .22s ease}

/* ---- bigger step clay ---- */
.step .claywrap{width:104px;height:104px;margin:2px 0 18px}
.step .claywrap img{width:104px;height:104px;filter:drop-shadow(0 10px 20px rgba(26,34,56,.12))}
.step .num{color:var(--teal-700);font-size:12px;letter-spacing:.1em}

/* ---- WHO IT'S FOR ---- */
.who{display:grid;grid-template-columns:1.05fr .95fr;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);background:#fff}
.who-copy{padding:60px 56px;display:flex;flex-direction:column;justify-content:center}
.who-copy h2{font-size:clamp(28px,3.4vw,42px);letter-spacing:-0.03em;line-height:1.05}
.who-copy .lede2{margin-top:20px;font-size:17px;line-height:1.6;color:var(--fg-2)}
.who-list{margin-top:28px;display:flex;flex-direction:column;gap:16px}
.who-list .wl{display:flex;gap:14px;align-items:flex-start}
.who-list .wl .ib{flex:none;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--teal-tint)}
.who-list .wl .ib .ic{width:19px;height:19px;color:var(--teal);stroke-width:2.3}
.who-list .wl b{display:block;font-weight:800;font-size:15.5px;letter-spacing:-0.01em;color:var(--fg)}
.who-list .wl span{font-size:14px;color:var(--fg-2);line-height:1.45}
.who-img{position:relative;min-height:520px}
.who-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.who-img .wtag{position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-md);max-width:280px}
.who-img .wtag .q{font-weight:700;font-size:14px;letter-spacing:-0.01em;color:var(--ink);line-height:1.35}
.who-img .wtag .a{margin-top:8px;font:600 11px/1 var(--mono);color:var(--fg-3);text-transform:uppercase;letter-spacing:.06em}

/* ---- mobile menu ---- */
.mobile-menu{display:none;position:fixed;inset:74px 0 auto 0;z-index:49;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);padding:14px 28px 22px}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:14px 6px;font-weight:700;font-size:17px;border-bottom:1px solid var(--line);color:var(--fg)}
.mobile-menu .btn{width:100%;margin-top:16px}

@media (max-width:1080px){
  .who{grid-template-columns:1fr}
  .who-img{min-height:340px;order:-1}
  .hero-stage{max-width:560px}
  .app-body{grid-template-columns:1fr}
  .app-rail{display:none}
  .chip{display:none}
}
@media (max-width:820px){
  .hero h1{font-size:clamp(36px,9vw,52px)}
  .who-copy{padding:40px 28px}
}

/* =======================================================================
   V3 POLISH: real wave imagery + generous section spacing
   ======================================================================= */
.hero .wrap{position:relative;z-index:1}
.hero-wave{
  background:url('assets/hero-wave.jpg') no-repeat;
  background-size:135% 135%;
  opacity:.85;transform:scaleX(-1);
  animation:heroDrift 36s ease-in-out infinite;
}
/* slow, seamless ambient drift of the brand wave */
@keyframes heroDrift{
  0%,100%{background-position:30% 28%}
  25%{background-position:43% 40%}
  50%{background-position:34% 51%}
  75%{background-position:47% 34%}
}
@media (prefers-reduced-motion: reduce){
  .hero-wave{animation:none;background-position:34% 36%}
}
.hero-wave::after{content:"";position:absolute;inset:0;
  background:radial-gradient(58% 52% at 50% 36%, rgba(255,255,255,.82), rgba(255,255,255,0) 76%),
            linear-gradient(180deg, rgba(255,255,255,0) 62%, #fff 98%)}

/* more air everywhere */
.section{padding:132px 0}
.hero{padding-top:74px}
.hero .eyebrow{margin-bottom:30px}
.hero-stage{margin-top:100px}
.sec-head h2{margin-top:20px}
.sec-head.center p{margin-top:20px}
.compare{margin-top:66px}
.steps{margin-top:66px}
.feat-grid{margin-top:66px}
.tour{margin-top:64px}
.cstrip{margin-top:88px;padding-top:40px;border-top:1px solid var(--line)}

/* hero stage breathing + crisper depth */
.hero-stage::before{top:34px;height:74%;background:radial-gradient(closest-side,rgba(47,179,164,.18),rgba(47,179,164,0))}
.app-frame{border-radius:22px}

/* refined connector strip */
.cstrip .lbl{letter-spacing:.2em}
.cwords{gap:16px 44px;margin-top:24px}
.cword{font-size:17px}

/* section header rhythm */
.sec-head.center{max-width:760px}
.metrics{padding:72px 56px}
.metric-grid{margin-top:54px}

/* final CTA gets a wave accent */
#book .final-copy{position:relative;overflow:hidden}
#book .final-copy::before{content:"";position:absolute;right:-120px;bottom:-140px;width:420px;height:420px;
  background:url('assets/wave-left.jpg') no-repeat center/cover;opacity:.5;transform:rotate(8deg);
  -webkit-mask:radial-gradient(closest-side, #000 50%, transparent);mask:radial-gradient(closest-side,#000 50%,transparent);pointer-events:none}
#book .final-copy>*{position:relative;z-index:1}

@media (max-width:820px){
  .section{padding:84px 0}
  .hero-stage{margin-top:64px}
  .cstrip{margin-top:56px}
  .metrics{padding:48px 26px}
}

/* =======================================================================
   V4 refined How-it-works steps (replaces stock clay icons)
   ======================================================================= */
.step{padding:36px 32px 34px;overflow:hidden}
.step .stepno{position:absolute;top:20px;right:26px;font-weight:800;font-size:62px;line-height:1;letter-spacing:-0.05em;color:#eef0f4;pointer-events:none}
.step .step-badge{position:relative;width:62px;height:62px;border-radius:18px;display:grid;place-items:center;margin-bottom:22px}
.step .step-badge .ic{width:27px;height:27px;stroke-width:2.2}
.step.s1 .step-badge{background:var(--teal-tint);color:var(--teal)}
.step.s2 .step-badge{background:var(--gold-tint);color:var(--gold-700)}
.step.s3 .step-badge{background:var(--coral-tint);color:var(--coral)}
.step .num{position:relative;margin-bottom:10px}
.step h3{position:relative}
.step p{position:relative;margin-top:12px}

/* =======================================================================
   V5 match the real product: bold brand color, pill buttons,
   4-color accent device, faithful dashboard hero mock
   ======================================================================= */

/* pill buttons everywhere (the product uses fully-round) */
.btn{border-radius:var(--r-pill)}

/* ---- the signature 4-color accent bar ---- */
.accent-top{height:5px;background:linear-gradient(90deg,var(--teal) 0 25%,var(--gold) 25% 50%,var(--coral) 50% 75%,var(--ink) 75% 100%)}
.price-card,.metrics,.final{position:relative}
.price-card,.final{overflow:hidden}
.price-card::before,.final::before,.metrics::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;z-index:3;
  background:linear-gradient(90deg,var(--teal) 0 25%,var(--gold) 25% 50%,var(--coral) 50% 75%,var(--ink) 75% 100%)}

/* who-list badges cycle the palette */
.who-list .wl:nth-child(2) .ib{background:var(--gold-tint)} .who-list .wl:nth-child(2) .ib .ic{color:var(--gold-700)}
.who-list .wl:nth-child(3) .ib{background:var(--coral-tint)} .who-list .wl:nth-child(3) .ib .ic{color:var(--coral)}

/* ---- DASHBOARD HERO MOCK (faithful to the product) ---- */
.hero-stage{max-width:1120px}
.dash{position:relative;z-index:2;border-radius:22px;border:1px solid var(--line);background:#eef1f5;box-shadow:var(--shadow-lg);overflow:hidden;text-align:left}
.dash-bar{display:flex;align-items:center;gap:11px;height:58px;padding:0 18px;background:#fff;border-bottom:1px solid var(--line)}
.ws{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 14px 6px 7px;font-weight:700;font-size:13px;color:var(--fg)}
.wsav{width:22px;height:22px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font:700 9px/1 var(--mono)}
.bc{color:var(--fg-3);font-weight:600;font-size:13px}
.dash-bar .spacer{flex:1}
.tbtn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-weight:600;font-size:12.5px;color:var(--fg-2);background:#fff;white-space:nowrap}
.tbtn .ic{width:14px;height:14px;color:var(--fg-3);stroke-width:2.2}
.tbtn .kbd{font:600 10px/1 var(--mono);background:var(--bg-subtle);border-radius:5px;padding:3px 5px;color:var(--fg-3)}
.tbtn.synced{color:var(--teal-700)}
.tbtn.synced .dotg{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.tcirc{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--fg-2);flex:none}
.tcirc .ic{width:16px;height:16px;stroke-width:2.1}
.tcirc.dark{background:var(--ink);color:#fff;border:none;font:700 12px/1 var(--sans)}

.dash-body{display:grid;grid-template-columns:218px 1fr}
.dash-rail{background:var(--ink);padding:18px 14px 22px;display:flex;flex-direction:column;gap:2px}
.dash-rail .rb{display:flex;align-items:center;gap:9px;color:#fff;font-weight:800;font-size:15px;letter-spacing:-0.02em;padding:4px 8px}
.dash-rail .rb img{width:26px;height:26px}
.dash-rail .rsub{font:700 9px/1 var(--mono);letter-spacing:.13em;color:#8089a0;padding:7px 8px 14px;text-transform:uppercase}
.dash-rail .rgrp{font:700 9.5px/1 var(--sans);letter-spacing:.15em;color:#5d6781;text-transform:uppercase;padding:16px 10px 8px}
.rnav{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;color:#c3c9d6;font-weight:600;font-size:13.5px;letter-spacing:-0.01em}
.rnav .ic{width:17px;height:17px;color:#878fa3;stroke-width:2.1}
.rnav.on{background:#fff;color:var(--ink);font-weight:700;box-shadow:var(--shadow-sm)}
.rnav.on .ic{color:var(--teal)}

.dash-main{padding:18px}
.panel{background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.panel .pad{padding:18px 20px}
.panel .ey{font:700 10px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3)}
.greet-h{margin-top:10px;font-weight:800;font-size:21px;letter-spacing:-0.025em;color:var(--ink)}

.dash-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:14px 0}
.kc{position:relative;border-radius:16px;padding:16px;color:#fff;overflow:hidden}
.kc.teal{background:var(--teal)} .kc.gold{background:var(--gold)} .kc.coral{background:var(--coral)} .kc.ink{background:var(--ink)}
.kib{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.22);display:grid;place-items:center}
.kib .ic{width:17px;height:17px;color:#fff;stroke-width:2.2}
.kdelta{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.24);border-radius:999px;padding:4px 9px;font:700 11px/1 var(--sans);color:#fff}
.klbl{margin-top:13px;font-size:12.5px;font-weight:600;color:rgba(255,255,255,.92)}
.kval{margin-top:4px;font-weight:800;font-size:25px;letter-spacing:-0.03em;font-variant-numeric:tabular-nums}
.ksub{margin-top:5px;font-size:10.5px;color:rgba(255,255,255,.78)}

.needs{font:700 11px/1 var(--sans);letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3);margin:6px 0 10px;padding-left:2px}
.dec-h{margin-top:9px;font-weight:800;font-size:19px;letter-spacing:-0.02em;color:var(--ink)}
.substats{display:flex;gap:10px;margin:15px 0}
.substat{flex:1;border:1px solid var(--line);border-radius:11px;padding:11px 13px}
.substat .sk{font:700 9px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3)}
.substat .sv{margin-top:7px;font-weight:800;font-size:14px;letter-spacing:-0.01em}
.substat .sv.pos{color:var(--teal-700)}
.substat .smut{color:var(--fg-3);font-weight:600;font-size:12px}
.dec-why{font-size:13.5px;line-height:1.5;color:var(--fg-2)}
.dactions{display:flex;gap:10px;margin-top:17px}
.pill{border-radius:999px;padding:11px 26px;font-weight:700;font-size:14px;border:1.5px solid var(--line-strong);background:#fff;color:var(--ink);cursor:pointer;transition:.15s;font-family:var(--sans)}
.pill.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.pill.go{background:var(--teal);border-color:var(--teal);color:#fff}
.pill.go:hover{background:var(--ink);border-color:var(--ink)}

@media (max-width:1080px){
  .hero-stage{max-width:600px}
  .dash-body{grid-template-columns:1fr}
  .dash-rail{display:none}
  .dash-kpis{grid-template-columns:repeat(2,1fr)}
  .tbtn:not(.synced){display:none}
}
@media (max-width:520px){
  .dash-kpis{grid-template-columns:1fr 1fr}
  .substats{flex-direction:column}
  .dash-bar{gap:8px;padding:0 12px}
}

/* =======================================================================
   V6 POLISH: type rhythm for Bricolage, honest illustrative captions,
   contrast nudges
   ======================================================================= */

/* Bricolage tracks tighter than the old face, so ease the hero a touch
   and settle the line height for a calmer block. */
.hero h1{letter-spacing:-0.03em;line-height:1.0}

/* Illustrative caption under the hero product mock */
.stage-cap{
  max-width:560px;margin:20px auto 0;text-align:center;
  font:500 13.5px/1.5 var(--sans);color:var(--fg-3);
}

/* the proof statement reads as a statement, not a personal quote */
.quote blockquote{text-wrap:pretty}
.quote .who .nm{font-weight:700}
.quote .who .rl{font:600 10.5px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-2)}
/* the byline uses a bare .who, which collided with the "Who it's for"
   section card (.who sets a white fill + border + shadow). Reset it. */
.quote .who{background:none;border:0;box-shadow:none;border-radius:0;padding:0}

/* mobile: keep the hero headline inside the viewport (Bricolage is wide) */
@media (max-width:520px){
  .hero h1{font-size:clamp(27px,7.8vw,40px);letter-spacing:-0.02em;line-height:1.04;max-width:18ch}
  /* the eyebrow pill is nowrap and too long for a phone; let it wrap */
  .hero .eyebrow{white-space:normal;text-align:center;line-height:1.35;max-width:100%}
}

/* mobile header: show only brand + hamburger. The booking CTA lives in
   the mobile menu, so the header pill would overlap the wordmark. */
@media (max-width:820px){
  .header .nav-cta .btn-primary{display:none}
}

/* eyebrow split: page section-level labels are sans (matching the kicker),
   so they don't read as decorative mono eyebrows. Micro-labels, IDs, STEP
   ticks, KPI ticks and the dashboard-mock chrome stay mono on purpose. */
.cstrip .lbl,
.foot-col h5{font-family:var(--sans)}

/* =======================================================================
   V7 RHYTHM + SECTION DIFFERENTIATION
   The middle of the page repeated one shape: centered header + a grid of
   white cards. This layer gives each section its own form and a tighter,
   consistent vertical rhythm.
   ======================================================================= */

/* --- tighter, consistent rhythm (was a flat 132px everywhere) --- */
.section{padding:112px 0}
.hero-stage{margin-top:84px}
.cstrip{margin-top:64px}
.sec-head h2{margin-top:14px}
.sec-head.center p{margin-top:16px}
.compare{margin-top:52px}
.steps{margin-top:56px}
.feat-grid{margin-top:48px}
.tour{margin-top:56px}
.metric-grid{margin-top:48px}

/* --- "How it works" becomes a connected process, not a card grid --- */
#how .steps{position:relative;gap:18px}
/* the connecting line runs through the three nodes */
#how .steps::before{content:"";position:absolute;top:31px;left:16.6%;right:16.6%;height:2px;background:var(--line-strong);z-index:0}
#how .step{background:none;border:0;box-shadow:none;padding:0;text-align:center;overflow:visible}
#how .step:hover{transform:none;box-shadow:none}
#how .step::before{display:none}          /* drop the top accent bar */
#how .step .stepno{display:none}          /* drop the ghost watermark numeral */
#how .step .step-badge{position:relative;z-index:1;margin:0 auto 18px;
  box-shadow:0 0 0 8px var(--bg-subtle)}  /* node punches through the line */
#how .step .num{justify-content:center;text-align:center}
#how .step h3{max-width:18ch;margin:0 auto}
#how .step p{max-width:34ch;margin:12px auto 0}

@media (max-width:820px){
  #how .steps::before{display:none}        /* no line when stacked */
  #how .step{padding:0 8px}
}

/* --- "What makes it different": left header + product-style left edge --- */
#different .sec-head{text-align:left;margin:0;max-width:840px}
#different .feat::before{top:0;bottom:0;right:auto;width:4px;height:auto}  /* left edge, not top bar */

/* --- the proof statement, centered, no repeated portrait --- */
.proofline{max-width:760px;margin:0 auto;text-align:center}
.proofline blockquote{margin:0;font-size:clamp(20px,2.3vw,28px);line-height:1.42;
  font-weight:600;letter-spacing:-0.02em;color:#fff;text-wrap:balance}
.proofline-tag{margin-top:18px;font:600 11px/1 var(--sans);letter-spacing:.12em;
  text-transform:uppercase;color:var(--teal-300)}

/* =======================================================================
   V9 LIVING HERO: the dashboard demonstrates the loop. A decision surfaces,
   a cursor approves it, it ships, the revenue ticks up. Motion is the proof.
   ======================================================================= */
@media (prefers-reduced-motion: no-preference){

  /* the signature accent bar draws itself in */
  .hero-stage .accent-top{transform-origin:left center;animation:accentDraw .9s .25s cubic-bezier(.5,0,.2,1) both}
  @keyframes accentDraw{from{transform:scaleX(0)}to{transform:scaleX(1)}}

  /* decision panel cross-fades between the live proposal and the shipped state */
  #decPanel .pad{position:relative;min-height:230px}
  .dec-live{transition:opacity .4s ease,transform .4s ease}
  #decPanel.shipped .dec-live{opacity:0;transform:scale(.98);pointer-events:none}
  .dec-shipped{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
    justify-content:center;text-align:center;gap:5px;padding:18px;opacity:0;transform:scale(.96);
    pointer-events:none;transition:opacity .45s ease,transform .45s cubic-bezier(.2,.8,.2,1)}
  #decPanel.shipped .dec-shipped{opacity:1;transform:scale(1)}
  .ship-h{font:800 18px/1.1 var(--display);letter-spacing:-0.02em;color:var(--ink);margin-top:8px}
  .ship-s{font-size:13px;color:var(--fg-2)}

  /* the checkmark draws, with a teal ripple */
  .ship-check{position:relative;display:grid;place-items:center}
  .ship-check svg{width:54px;height:54px;overflow:visible}
  .sc-ring{fill:none;stroke:var(--teal);stroke-width:3;opacity:.22}
  .sc-tick{fill:none;stroke:var(--teal);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;
    stroke-dasharray:44;stroke-dashoffset:44}
  #decPanel.shipped .sc-tick{animation:tickDraw .5s .18s cubic-bezier(.6,0,.2,1) forwards}
  #decPanel.shipped .ship-check{animation:checkPop .5s cubic-bezier(.2,.8,.2,1) both}
  @keyframes tickDraw{to{stroke-dashoffset:0}}
  @keyframes checkPop{0%{transform:scale(.6)}60%{transform:scale(1.08)}100%{transform:scale(1)}}
  .ship-check::after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;
    background:rgba(47,179,164,.30);opacity:0}
  #decPanel.shipped .ship-check::after{animation:ripple .9s .12s ease-out forwards}
  @keyframes ripple{0%{opacity:1;width:18px;height:18px}100%{opacity:0;width:300px;height:300px}}

  /* approve button, driven by the demo */
  #approveBtn{transition:transform .12s ease,background .18s ease,border-color .18s ease}
  #approveBtn.focus{box-shadow:0 0 0 4px rgba(47,179,164,.40)}
  #approveBtn.press{background:var(--ink);border-color:var(--ink);transform:translateY(1px) scale(.96)}

  /* the ghost cursor glides to the button and taps */
  .ghost-cursor{position:absolute;left:0;top:0;width:23px;height:23px;z-index:6;opacity:0;pointer-events:none;
    transform:translate(var(--cx,0),var(--cy,0));
    transition:transform 1.05s cubic-bezier(.45,0,.2,1),opacity .3s ease;
    filter:drop-shadow(0 3px 5px rgba(26,34,56,.4))}
  .ghost-cursor svg{width:100%;height:100%;fill:#1a2238;stroke:#fff;stroke-width:1.3}
  .ghost-cursor.show{opacity:1}
  .ghost-cursor::after{content:"";position:absolute;left:3px;top:3px;width:8px;height:8px;border-radius:50%;
    border:2px solid var(--teal);opacity:0}
  .ghost-cursor.tap::after{animation:curtap .5s ease-out}
  @keyframes curtap{0%{opacity:.85;transform:scale(.3)}100%{opacity:0;transform:scale(4)}}

  /* the payoff: revenue flashes and a chip floats up */
  #revKpi.flash{animation:kpiFlash 1.3s ease}
  @keyframes kpiFlash{0%,100%{box-shadow:none}28%{box-shadow:0 0 0 3px rgba(255,255,255,.55),0 12px 32px rgba(47,179,164,.5)}}
  .kfly{position:absolute;left:16px;top:44px;z-index:4;background:#fff;color:var(--teal-700);
    font:800 12px/1 var(--sans);padding:5px 9px;border-radius:999px;box-shadow:var(--shadow-md);
    opacity:0;transform:translateY(8px);pointer-events:none}
  .kfly.go{animation:flyUp 1.7s ease forwards}
  @keyframes flyUp{0%{opacity:0;transform:translateY(8px)}16%{opacity:1;transform:translateY(0)}
    78%{opacity:1;transform:translateY(-12px)}100%{opacity:0;transform:translateY(-22px)}}

  /* the confirmation toast */
  .hero-toast{position:absolute;left:50%;bottom:20px;z-index:7;display:flex;align-items:center;gap:9px;
    background:var(--ink);color:#fff;font:600 13px/1 var(--sans);padding:12px 18px;border-radius:999px;
    box-shadow:var(--shadow-pop);opacity:0;pointer-events:none;transform:translate(-50%,16px);
    transition:opacity .4s ease,transform .45s cubic-bezier(.2,.8,.2,1)}
  .hero-toast.show{opacity:1;transform:translate(-50%,0)}
  .ht-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);
    box-shadow:0 0 0 0 rgba(47,179,164,.5);animation:pulse 2s infinite}
}

/* reduced motion / no-JS: hide the demo-only chrome, leave a calm static panel */
.ghost-cursor,.hero-toast,.kfly{display:none}
.dec-shipped{display:none}
@media (prefers-reduced-motion: no-preference){
  .ghost-cursor,.hero-toast,.kfly,.dec-shipped{display:flex}
}

/* --- final CTA: a brand panel, not a third repeat of the same stock face --- */
.final-brand{position:relative;min-height:420px;background:var(--ink);
  display:grid;place-items:center;overflow:hidden}
.final-brand::after{content:"";position:absolute;inset:0;
  background:radial-gradient(62% 60% at 50% 38%, rgba(47,179,164,.20), transparent 70%)}
.final-brand .be{position:relative;z-index:1;width:188px;height:188px;
  filter:drop-shadow(0 14px 32px rgba(0,0,0,.34))}
@media (max-width:820px){
  .final-brand{min-height:220px;order:-1}
}

/* =======================================================================
   V10 THE OVERNIGHT: the cinematic open. Night shift streams the work the
   AI did overnight, the value tallies, dawn breaks in the brand colours,
   and the page wakes to a business that grew while you slept.
   ======================================================================= */
.overnight{position:relative;overflow:hidden;color:#fff;font-family:var(--sans);
  padding:116px 0;min-height:600px;display:flex;align-items:center}

/* sky: night, then a brand-coloured sunrise crossfades over it */
.on-sky,.on-dawn{position:absolute;inset:0;z-index:0}
.on-sky{background:radial-gradient(125% 90% at 50% 6%, #18254a 0%, #0b1024 56%, #060812 100%)}
/* dawn fades in ON TOP of the night, which stays opaque so the hero never bleeds through */
/* a brand nocturne, not a stock sunrise: ink night warms only into teal and
   gold at the horizon, staying dark and premium */
.on-dawn{opacity:0;transition:opacity 3.4s cubic-bezier(.4,0,.3,1);
  background:linear-gradient(180deg,#070b1c 0%,#090f2a 32%,#0d2546 54%,#11484f 72%,#1c6c61 86%,#9a7a28 100%)}
.overnight.dawn .on-dawn{opacity:1}

/* a gold first-light glow with a teal halo rises at the horizon */
.on-sun{position:absolute;left:50%;bottom:-320px;width:760px;height:760px;border-radius:50%;z-index:0;
  transform:translateX(-50%);opacity:0;
  background:radial-gradient(circle,rgba(217,162,42,.52) 0%,rgba(47,179,164,.20) 44%,rgba(217,162,42,0) 72%);
  transition:opacity 3s ease, bottom 4.4s cubic-bezier(.33,0,.2,1)}
.overnight.dawn .on-sun{opacity:.95;bottom:-150px}

/* stars, fading out as dawn arrives */
.on-stars{position:absolute;inset:0;z-index:0;opacity:.85;transition:opacity 2.6s ease;
  background-image:
    radial-gradient(1.5px 1.5px at 20% 30%,#fff,transparent),
    radial-gradient(1.5px 1.5px at 70% 18%,#fff,transparent),
    radial-gradient(1px 1px at 45% 12%,#cfe,transparent),
    radial-gradient(1.5px 1.5px at 85% 38%,#fff,transparent),
    radial-gradient(1px 1px at 33% 52%,#fff,transparent),
    radial-gradient(1px 1px at 62% 58%,#bdf,transparent),
    radial-gradient(1.5px 1.5px at 12% 66%,#fff,transparent),
    radial-gradient(1px 1px at 90% 64%,#fff,transparent);
  animation:twinkle 4s ease-in-out infinite}
.overnight.dawn .on-stars{opacity:0}
@keyframes twinkle{0%,100%{opacity:.85}50%{opacity:.5}}

.on-wrap{position:relative;z-index:2}
.on-kicker{display:block;color:var(--teal-300);margin-bottom:30px}
.on-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.on-col-say{padding-top:4px}
.on-clock{display:flex;align-items:center;gap:9px;font:600 11px/1 var(--mono);
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.on-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 rgba(47,179,164,.6);animation:pulse 2s infinite}
.on-feed{margin-top:20px;display:flex;flex-direction:column;gap:11px;min-height:208px}
.on-line{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:13px;
  opacity:0;transform:translateY(10px);transition:opacity .65s ease, transform .65s cubic-bezier(.2,.8,.2,1)}
.on-line.in{opacity:1;transform:none}
.ol-t{font:600 11px/1 var(--mono);color:rgba(255,255,255,.42)}
.ol-x{font-size:14.5px;color:rgba(255,255,255,.92);line-height:1.35}
.ol-v{font:800 13px/1 var(--sans);color:#e6bf52;white-space:nowrap}
.ol-v.done{color:rgba(255,255,255,.4);font-weight:600}
.on-total{margin-top:2px}
.on-total-lbl{font:600 11px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.on-total-val{margin-top:6px;font:800 clamp(46px,7vw,82px)/.95 var(--display);
  letter-spacing:-0.045em;color:#fff;font-variant-numeric:tabular-nums}
.on-head{margin-top:22px;font:600 clamp(21px,2.4vw,30px)/1.2 var(--display);
  letter-spacing:-0.018em;color:rgba(255,255,255,.94);max-width:19ch;
  transition:opacity .26s ease, transform .26s ease}
.on-head.swap{opacity:0;transform:translateY(8px)}

/* the payoff (proof stats + CTA) reveals as dawn breaks */
.on-payoff{margin-top:28px;opacity:0;transform:translateY(14px);
  transition:opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1)}
.overnight.lit .on-payoff{opacity:1;transform:none}
.on-stats{display:grid;grid-template-columns:repeat(2,auto);justify-content:start;gap:16px 36px;margin-bottom:26px}
.on-stat b{display:block;font:800 23px/1 var(--display);letter-spacing:-0.02em;color:#fff;font-variant-numeric:tabular-nums}
/* the four stats carry the four brand colours, not just teal */
.on-stat:nth-child(1) b{color:#7fd0c6}
.on-stat:nth-child(2) b{color:#e6bf52}
.on-stat:nth-child(3) b{color:#ef7d79}
.on-stat:nth-child(4) b{color:#ffffff}
.on-stat span{font-size:12.5px;color:rgba(255,255,255,.7)}

/* =======================================================================
   V15 AGENCY VS AIMVISIBLE: a head-to-head comparison table, the AimVisible
   column highlighted, dimension icons across the four brand colours
   ======================================================================= */
.cmp{max-width:840px;margin:46px auto 0}
.cmp-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;
  background:#fff;border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.cmp-grid>div{padding:0 22px;display:flex;align-items:center;min-height:62px}
/* dark header band */
.cmp-hd,.cmp-ht,.cmp-hu{background:var(--ink);min-height:66px}
.cmp-hd{font:700 12px/1.2 var(--sans);letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.cmp-ht,.cmp-hu{justify-content:center;font:800 13px/1 var(--sans);letter-spacing:.06em;text-transform:uppercase}
.cmp-ht{color:rgba(255,255,255,.9)}
.cmp-hu{color:#fff;gap:9px;position:relative}
.cmp-hu .cmp-mark{width:20px;height:20px;flex:none}
.cmp-hu::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;z-index:1;
  background:linear-gradient(90deg,var(--teal) 0 25%,var(--gold) 25% 50%,var(--coral) 50% 75%,var(--ink) 75% 100%)}
/* feature label column */
.cmp-d{gap:13px;font-weight:700;font-size:15px;color:var(--ink);line-height:1.3}
.cmp-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}
.cmp-ic .ic{width:18px;height:18px;stroke-width:2.3}
.ci-teal{background:var(--teal-tint)} .ci-teal .ic{color:var(--teal)}
.ci-gold{background:var(--gold-tint)} .ci-gold .ic{color:var(--gold-700)}
.ci-coral{background:var(--coral-tint)} .ci-coral .ic{color:var(--coral)}
.ci-ink{background:var(--ink-tint)} .ci-ink .ic{color:var(--ink)}
/* tick / cross cells */
.cmp-t,.cmp-u{justify-content:center}
.cmp-x .ic{width:26px;height:26px;color:var(--coral);stroke-width:3}
.cmp-c .ic{width:26px;height:26px;color:var(--teal);stroke-width:3}
/* highlighted AimVisible column body */
.cmp-u{background:var(--teal-tint);box-shadow:inset 1px 0 0 rgba(47,179,164,.18)}
/* price row */
.cmp-price{font-size:17px;font-weight:800}
.cmp-t.cmp-price{color:var(--coral)}
.cmp-u.cmp-price{color:var(--teal-700)}
.cmp-bad{color:var(--coral);font-weight:800}
/* row dividers */
.cmp-d,.cmp-t{border-top:1px solid var(--line)}
.cmp-u{border-top:1px solid rgba(47,179,164,.16)}

@media (max-width:720px){
  .cmp{max-width:500px}
  .cmp-grid{grid-template-columns:1.35fr 1fr 1fr}
  .cmp-grid>div{padding:0 12px;min-height:54px}
  .cmp-d{font-size:13px;gap:9px}
  .cmp-ic{width:28px;height:28px} .cmp-ic .ic{width:15px;height:15px}
  .cmp-x .ic,.cmp-c .ic{width:22px;height:22px}
  .cmp-price{font-size:14px}
  .cmp-hd{font-size:9.5px;letter-spacing:.08em}
  .cmp-ht,.cmp-hu{font-size:10.5px;letter-spacing:.05em}
}
.on-cta{box-shadow:0 10px 30px rgba(0,0,0,.25)}

/* reduced motion: show the resolved dawn state, no animation */
@media (prefers-reduced-motion: reduce){
  .overnight .on-dawn{opacity:1}
  .overnight .on-stars{opacity:0}
  .overnight .on-payoff{opacity:1;transform:none}
}
@media (max-width:860px){
  .overnight{padding:84px 0;min-height:0}
  .on-grid{grid-template-columns:1fr;gap:34px}
  .on-feed{min-height:auto}
}

/* =======================================================================
   V11 HERO with booking form: value left, form right, dashboard below
   ======================================================================= */
.hero{text-align:left}
.hero-top{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center}
.hero-copy{max-width:none;margin:0;text-align:left}
.hero h1{font-size:clamp(33px,4.3vw,56px);line-height:1.04;letter-spacing:-0.035em;max-width:none;margin:0}
.hero .lede{margin:20px 0 0;max-width:520px;font-size:clamp(16px,1.4vw,18.5px)}
.hero .trust{justify-content:flex-start;margin-top:24px}

.hero-social{display:flex;align-items:center;gap:14px;margin-top:26px;max-width:440px}
.hero-faces{display:flex;flex:none}
.hero-faces img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2.5px solid #fff;
  box-shadow:var(--shadow-sm);margin-left:-10px}
.hero-faces img:first-child{margin-left:0}
.hero-social span{font-size:13px;line-height:1.4;color:var(--fg-2);font-weight:500}

/* form card */
.hero-form{align-self:center;scroll-margin-top:112px}
.bookform{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:30px 26px 24px}
/* the signature 4-colour accent bar caps the form, like the dashboard panels and pricing card */
.bookform::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;z-index:1;
  background:linear-gradient(90deg,var(--teal) 0 25%,var(--gold) 25% 50%,var(--coral) 50% 75%,var(--ink) 75% 100%)}
.bf-head{margin-bottom:18px}
.bf-title{font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:-0.02em;color:var(--ink)}
.bf-sub{margin-top:7px;font-size:13px;color:var(--fg-2);line-height:1.45}
.bf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bf-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.bf-field.bf-full{grid-column:1 / -1}
.bf-field span{font-weight:600;font-size:12px;color:var(--fg-2)}
.bf-field input,.bf-field select{font:500 15px/1.2 var(--sans);color:var(--ink);background:#fff;
  border:1.5px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 13px;width:100%;
  transition:border-color .15s ease, box-shadow .15s ease}
.bf-field input::placeholder{color:var(--fg-3)}
.bf-field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--fg-3) 50%),linear-gradient(135deg,var(--fg-3) 50%,transparent 50%);background-position:calc(100% - 18px) 51%,calc(100% - 13px) 51%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px}
.bf-field input:focus,.bf-field select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(47,179,164,.18)}
.bf-consent{display:grid;grid-template-columns:18px 1fr;gap:10px;margin-top:14px;color:var(--fg-2);font-size:12px;line-height:1.45}
.bf-consent input{width:16px;height:16px;margin:2px 0 0;accent-color:var(--teal)}
.bf-links{margin-top:9px;font-size:11.5px;color:var(--fg-3);line-height:1.4}
.bf-links a{color:var(--teal-700);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.bf-submit{width:100%;margin-top:16px}
.bf-submit[disabled]{opacity:.68;cursor:not-allowed}
.bf-micro{margin-top:13px;display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--fg-3);line-height:1.4}
.bf-micro .ic{flex:none;width:14px;height:14px;color:var(--teal);stroke-width:2.4;margin-top:1px}
.bf-done{padding:22px 16px;border-radius:var(--r-md);background:var(--teal-tint);color:var(--teal-700);
  font-weight:700;font-size:15px;text-align:center;line-height:1.45}
.bf-status{min-height:18px;margin-top:10px;font-size:12px;font-weight:700;line-height:1.45}
.bf-status-loading{color:var(--fg-3)}
.bf-status-sent{color:var(--teal-700)}
.bf-status-error{color:var(--coral-700)}

.hero-stage{margin-top:76px}

@media (max-width:980px){
  .hero-top{grid-template-columns:1fr;gap:34px;max-width:560px;margin:0 auto}
  .hero h1{font-size:clamp(32px,7vw,48px)}
  .hero .lede{max-width:none}
  .hero-form{scroll-margin-top:132px}
  .hero-stage{margin-top:56px}
}
@media (max-width:420px){
  .bf-grid{grid-template-columns:1fr}
  .bookform{padding-left:18px;padding-right:18px}
}

/* =======================================================================
   V12 PRICING: four tiers in the brand colours (teal/gold/coral/ink),
   solid coloured headers on white cards, echoing the dashboard KPI tiles
   ======================================================================= */
.pricing-color{background:#fff}
.ptiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px;align-items:stretch}
.ptier{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md);
  transition:transform .2s ease, box-shadow .2s ease}
.ptier:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.ptier.popular{box-shadow:0 0 0 2px var(--gold), var(--shadow-pop)}
.ptier.popular:hover{transform:translateY(-5px);box-shadow:0 0 0 2px var(--gold), var(--shadow-pop)}

/* the solid brand-colour header band */
.pt-head{position:relative;padding:26px 24px 22px;color:#fff}
.pt-teal .pt-head{background:var(--teal)}
.pt-gold .pt-head{background:var(--gold)}
.pt-coral .pt-head{background:var(--coral)}
.pt-ink .pt-head{background:var(--ink)}
.pt-badge{position:absolute;top:18px;right:18px;background:var(--teal);color:#fff;
  font:700 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  padding:6px 11px;border-radius:999px;box-shadow:0 4px 12px rgba(47,179,164,.4)}
.pt-name{font-family:var(--display);font-weight:800;font-size:24px;letter-spacing:-0.02em}
.pt-tag{margin-top:6px;font-size:13.5px;opacity:.86}
.pt-price{margin-top:18px;display:flex;align-items:baseline;gap:5px}
.pt-amt{font-family:var(--display);font-weight:800;font-size:44px;line-height:1;
  letter-spacing:-0.04em;font-variant-numeric:tabular-nums}
.pt-amt.pt-amt-sm{font-size:38px}
.pt-per{font-size:15px;opacity:.82;font-weight:600}
.pt-aud{margin-top:13px;font:500 11px/1.3 var(--mono);letter-spacing:.06em;text-transform:uppercase;opacity:.8}

/* white body with the feature list */
.pt-body{display:flex;flex-direction:column;flex:1;padding:22px 24px 24px}
.pt-plus{font-weight:700;font-size:13px;margin-bottom:14px}
.pt-teal .pt-plus{color:var(--teal-700)}
.pt-gold .pt-plus{color:var(--gold-700)}
.pt-coral .pt-plus{color:var(--coral-700)}
.pt-ink .pt-plus{color:var(--ink)}
.pt-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;flex:1}
.pt-feats li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;line-height:1.4;color:var(--fg-2)}
.pt-check{flex:none;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;margin-top:1px}
.pt-check .ic{width:12px;height:12px;stroke-width:3.2}
.pt-teal .pt-check{background:var(--teal-tint)} .pt-teal .pt-check .ic{color:var(--teal-700)}
.pt-gold .pt-check{background:var(--gold-tint)} .pt-gold .pt-check .ic{color:var(--gold-700)}
.pt-coral .pt-check{background:var(--coral-tint)} .pt-coral .pt-check .ic{color:var(--coral-700)}
.pt-ink .pt-check{background:var(--ink-tint)} .pt-ink .pt-check .ic{color:var(--ink)}
.pt-cta{margin-top:24px;display:flex;align-items:center;justify-content:center;padding:13px;
  border-radius:999px;font-weight:700;font-size:15px;border:1.5px solid;cursor:pointer;
  transition:background .16s ease, color .16s ease, border-color .16s ease}
.pt-teal .pt-cta{border-color:var(--teal);color:var(--teal-700)}
.pt-teal .pt-cta:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.pt-gold .pt-cta{border-color:var(--gold);color:var(--gold-700)}
.pt-gold .pt-cta:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pt-coral .pt-cta{border-color:var(--coral);color:var(--coral-700)}
.pt-coral .pt-cta:hover{background:var(--coral);color:#fff;border-color:var(--coral)}
.pt-ink .pt-cta{border-color:var(--ink);color:var(--ink)}
.pt-ink .pt-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
/* the most-popular CTA is filled */
.pt-gold .pt-cta-go{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pt-gold .pt-cta-go:hover{background:var(--gold-700);border-color:var(--gold-700);color:#fff}

.pnote{margin-top:34px;text-align:center;font-size:13.5px;color:var(--fg-3)}

@media (max-width:980px){
  .ptiers{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media (max-width:560px){
  .ptiers{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
}

/* =======================================================================
   V13 DASHBOARD MOCK: faithful to the real product. The product uses
   Poppins (display/body) and Geist Mono (data labels), and the bullseye
   logo is a circle, not a white tile. Scope those to the mock only.
   ======================================================================= */
.dash{
  --display:'Poppins',ui-sans-serif,system-ui,sans-serif;
  --sans:'Poppins',ui-sans-serif,system-ui,sans-serif;
  --mono:'Geist Mono',ui-monospace,'SF Mono',Menlo,monospace;
  font-family:var(--sans);
}
.dash-rail .rb .rb-mark{width:26px;height:26px;flex:none}
/* every KPI card flashes when the demo ships, not just revenue */
.kc.flash{animation:kpiFlash 1.3s ease}

/* =======================================================================
   V14 UNDER-DASHBOARD: a prominent caption and proper connector chips,
   with intentional spacing into the next section
   ======================================================================= */
.stage-cap{max-width:600px;margin:24px auto 0;font:500 16px/1.55 var(--sans);color:var(--fg-2)}
.stage-cap strong{color:var(--ink);font-weight:800}

.cstrip{margin-top:54px;padding-top:0;border-top:0}
.cstrip .lbl{text-align:center;font:700 11px/1 var(--sans);letter-spacing:.16em;
  text-transform:uppercase;color:var(--fg-3)}
.cwords{margin-top:22px;display:flex;align-items:center;justify-content:center;gap:13px;flex-wrap:wrap}
.cword{display:inline-flex;align-items:center;gap:9px;padding:11px 20px;
  border:1px solid var(--line);border-radius:999px;background:#fff;box-shadow:var(--shadow-sm);
  font-weight:700;font-size:15px;color:var(--fg);opacity:1;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.cword:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.cword .clogo{width:18px;height:18px;flex:none}
.cword .clogo-k{display:inline-flex;align-items:center;justify-content:center;
  font:800 15px/1 var(--sans);color:#1f8d80}

.hero{padding-bottom:76px}

/* =======================================================================
   V17 TRUST AND PUBLIC DEMO PROOF
   ======================================================================= */
.experience,#product{scroll-margin-top:96px}
.experience{background:#fff;padding-top:92px;padding-bottom:92px}
.experience-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);
  gap:54px;align-items:center}
.experience-copy h2{margin-top:16px;font-size:clamp(30px,3.6vw,48px);
  max-width:13ch;text-wrap:balance}
.experience-copy p{margin-top:20px;max-width:610px;font-size:18px;line-height:1.62}
.experience-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px}
.experience-stats div{background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:18px 16px;box-shadow:var(--shadow-sm)}
.experience-stats b{display:block;font:800 22px/1 var(--display);letter-spacing:-0.02em;color:var(--ink)}
.experience-stats span{display:block;margin-top:8px;font-size:13.5px;line-height:1.4;color:var(--fg-2)}

.experience-card{position:relative;background:#fff;border:1px solid var(--line);
  border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden}
.experience-card::before{content:"";display:block;height:5px;
  background:linear-gradient(90deg,var(--teal) 0 28%,var(--gold) 28% 56%,var(--coral) 56% 82%,var(--ink) 82% 100%)}
.exp-card-head{display:flex;gap:16px;align-items:flex-start;padding:28px 28px 18px}
.ring-mini{width:42px;height:42px;flex:none;display:grid;place-items:center}
.ring-mini svg{width:100%;height:100%;display:block}
.exp-card-ey{font:800 11px/1 var(--sans);letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3)}
.exp-card-head h3{margin-top:8px;font-size:24px;line-height:1.15}
.exp-rows{display:grid;gap:0;border-top:1px solid var(--line)}
.exp-rows div{display:grid;grid-template-columns:48px 1fr;column-gap:14px;
  padding:20px 28px;border-top:1px solid var(--line)}
.exp-rows div:first-child{border-top:0}
.exp-rows span{grid-row:1 / span 2;font:800 12px/1 var(--mono);letter-spacing:.08em;color:var(--teal)}
.exp-rows b{font-size:16px;color:var(--ink)}
.exp-rows p{grid-column:2;margin-top:5px;font-size:14.5px;line-height:1.5}

.proof-showcase{display:grid;grid-template-columns:minmax(320px,.86fr) minmax(0,1.14fr);
  gap:34px;align-items:center;margin-top:58px;background:#fff;border:1px solid var(--line);
  border-radius:24px;box-shadow:var(--shadow-lg);padding:34px;overflow:hidden}
.proof-showcase-copy h3{margin-top:13px;font-size:clamp(26px,2.8vw,38px);line-height:1.08;text-wrap:balance}
.proof-showcase-copy p{margin-top:16px;font-size:16.5px;line-height:1.6}
.proof-showcase-list{display:grid;gap:14px;margin-top:28px}
.proof-showcase-list div{display:grid;grid-template-columns:42px 1fr;column-gap:12px;align-items:start}
.proof-showcase-list .ib{grid-row:1 / span 2;width:42px;height:42px;border-radius:12px}
.proof-showcase-list b{font-size:15px;color:var(--ink)}
.proof-showcase-list small{grid-column:2;margin-top:4px;font-size:13.5px;line-height:1.45;color:var(--fg-2)}

.proof-showcase-media{position:relative;min-height:430px}
.showcase-browser{position:absolute;left:0;right:78px;top:8px;background:#fff;border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden}
.showcase-bar{display:flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-bottom:1px solid var(--line);
  background:#f8f9fb;color:var(--fg-3);font-size:12px}
.showcase-bar span{width:9px;height:9px;border-radius:50%;background:var(--line-strong)}
.showcase-bar span:nth-child(1){background:var(--coral)}
.showcase-bar span:nth-child(2){background:var(--gold)}
.showcase-bar span:nth-child(3){background:var(--teal)}
.showcase-bar b{margin-left:6px;font:700 11px/1 var(--mono);letter-spacing:.02em;color:var(--fg-2)}
.showcase-browser img{width:100%;height:310px;object-fit:cover;object-position:left top}

.creative-stack{position:absolute;right:0;bottom:0;width:250px;display:grid;gap:14px}
.creative-card{margin:0;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-md);overflow:hidden}
.creative-card img{width:100%;height:128px;object-fit:cover}
.creative-card figcaption{padding:10px 12px;font:800 11px/1 var(--sans);
  letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);background:#fff}
.video-card{transform:rotate(1deg)}
.static-card{transform:translateX(-24px) rotate(-1deg)}
.email-card{transform:translateX(12px) rotate(1deg)}

@media (max-width:980px){
  .experience-grid,.proof-showcase{grid-template-columns:1fr}
  .experience-copy h2{max-width:720px}
  .proof-showcase-media{min-height:520px}
  .showcase-browser{right:0}
  .creative-stack{left:24px;right:auto;bottom:0;width:min(520px,calc(100% - 48px));
    grid-template-columns:repeat(3,1fr)}
  .static-card,.email-card,.video-card{transform:none}
}
@media (max-width:680px){
  .experience{padding-top:72px;padding-bottom:72px}
  .experience-stats{grid-template-columns:1fr}
  .exp-card-head{padding:24px 22px 16px}
  .exp-rows div{grid-template-columns:40px 1fr;padding:18px 22px}
  .proof-showcase{padding:22px;border-radius:20px}
  .proof-showcase-media{min-height:650px}
  .showcase-browser img{height:260px}
  .creative-stack{grid-template-columns:1fr;left:0;width:100%}
  .creative-card img{height:150px}
}

/* =======================================================================
   V16 HOW IT WORKS: a three-stage pipeline that auto-plays on scroll.
   Data travels the rail (teal to gold to coral), each stage fills in
   turn: sources sync, the work builds with a value counting up, then a
   cursor approves and it ships. All four brand colours carry a stage.
   ======================================================================= */
.flow{position:relative;display:grid;grid-template-columns:repeat(3,1fr);
  gap:26px;margin-top:54px;padding-top:30px}
#fs1{--ac:var(--teal)} #fs2{--ac:var(--gold)} #fs3{--ac:var(--coral)}

/* the data rail and travelling dot */
.flow-rail{position:absolute;left:14%;right:14%;top:6px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--teal),var(--gold),var(--coral));opacity:.3}
.flow-dot{position:absolute;top:50%;left:0;width:12px;height:12px;margin-top:-6px;
  border-radius:50%;background:var(--teal);transform:translateX(-50%);
  box-shadow:0 0 0 4px rgba(47,179,164,.16);
  transition:left .9s cubic-bezier(.4,0,.2,1), background .5s ease, box-shadow .5s ease}

/* stage shell */
.fstage{position:relative}
.fviz{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow-sm);padding:22px;min-height:188px;
  display:flex;flex-direction:column;justify-content:center;
  transition:transform .45s ease, box-shadow .45s ease, border-color .45s ease}
.fviz::before{content:'';position:absolute;left:0;right:0;top:0;height:3px;
  background:var(--ac);transform:scaleX(0);transform-origin:left;
  transition:transform .5s cubic-bezier(.4,0,.2,1)}
.fstage.active .fviz{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-strong)}
.fstage.active .fviz::before{transform:scaleX(1)}
.fnum{margin-top:20px;font:800 12px/1 var(--sans);letter-spacing:.1em;
  text-transform:uppercase;color:var(--ac)}
.fstage h3{margin:10px 0 8px;font:800 20px/1.22 var(--display);color:var(--ink)}
.fstage p{margin:0;font:500 14.5px/1.6 var(--sans);color:var(--fg-2)}

/* ---- Google Ads compliance/service section ---- */
.ads-service{background:#fff;scroll-margin-top:96px}
.ads-service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.ads-service-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-md);text-align:left}
.ads-service-card h3{font:800 20px/1.18 var(--display);letter-spacing:-0.02em;color:var(--ink)}
.ads-service-card p{margin-top:12px;font-size:14.5px;line-height:1.62;color:var(--fg-2)}
@media (max-width:900px){
  .ads-service-grid{grid-template-columns:1fr;max-width:620px;margin-left:auto;margin-right:auto}
}
@media (max-width:520px){
  .ads-service{padding-bottom:132px}
}

/* stage 01: connect the sources */
.fv-connect{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.fconn{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  background:var(--bg-subtle);border:1px solid var(--line);border-radius:12px;
  opacity:.42;transform:translateY(4px);
  transition:opacity .4s ease, transform .4s ease, border-color .4s ease, background .4s ease}
.fconn img{display:block}
.fconn.synced{opacity:1;transform:none;background:#fff;border-color:var(--teal-300)}
.fk{font:800 17px/1 var(--sans);color:#1f8d80}
.fchk{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;
  background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;
  transform:scale(0);transition:transform .32s cubic-bezier(.34,1.56,.64,1)}
.fconn.synced .fchk{transform:scale(1)}
.fchk .ic{width:11px;height:11px;stroke-width:3.4}
.fv-status{margin-top:16px;display:flex;align-items:center;gap:9px;
  font:600 13px/1 var(--sans);color:var(--fg-2);
  opacity:0;transform:translateY(4px);transition:opacity .4s ease, transform .4s ease}
.fv-status.show{opacity:1;transform:none}
.fled{width:9px;height:9px;flex:none;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 rgba(47,179,164,.5);animation:fled 1.9s infinite}
@keyframes fled{0%{box-shadow:0 0 0 0 rgba(47,179,164,.5)}
  70%{box-shadow:0 0 0 7px rgba(47,179,164,0)}100%{box-shadow:0 0 0 0 rgba(47,179,164,0)}}

/* stage 02: it builds the work */
.fv-build{display:flex;flex-direction:column;gap:9px}
.fb-eyebrow,.fb-title,.fb-val,.fb-ready{opacity:0;transform:translateY(5px);
  transition:opacity .45s ease, transform .45s ease}
.fstage.seen .fb-eyebrow{opacity:1;transform:none;transition-delay:0s}
.fstage.seen .fb-title{opacity:1;transform:none;transition-delay:.12s}
.fstage.seen .fb-val{opacity:1;transform:none;transition-delay:.24s}
.fstage.seen .fb-ready{opacity:1;transform:none;transition-delay:.36s}
.fb-eyebrow{font:700 10.5px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700)}
.fb-title{font:800 17px/1.28 var(--display);color:var(--ink)}
.fb-val{font:800 23px/1 var(--display);color:var(--ink);font-variant-numeric:tabular-nums}
.fb-val span{color:var(--gold-700)}
.fb-ready{display:inline-flex;align-items:center;gap:7px;font:700 13px/1 var(--sans);color:var(--teal-700)}
.fb-ready .ic{width:15px;height:15px;color:var(--teal);stroke-width:2.6}

/* stage 03: you say go, it ships */
.fv-ship{position:relative;min-height:100px;display:flex;align-items:center;justify-content:center}
.fs-live,.fs-done{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:13px;
  transition:opacity .4s ease, transform .4s ease}
.fs-done{opacity:0;transform:translateY(9px);pointer-events:none}
.fv-ship.shipped .fs-live{opacity:0;transform:translateY(-9px);pointer-events:none}
.fv-ship.shipped .fs-done{opacity:1;transform:none}
.fs-q{font:700 15px/1 var(--display);color:var(--ink)}
.fs-actions{display:flex;gap:10px;align-items:center}
.fs-skip{font:600 13px/1 var(--sans);color:var(--fg-3);padding:9px 15px;
  border:1px solid var(--line);border-radius:10px;background:#fff}
.fs-go{font:700 13px/1 var(--sans);color:#fff;background:var(--teal);border:0;
  border-radius:10px;padding:10px 22px;cursor:pointer;box-shadow:0 1px 2px rgba(31,141,128,.3);
  transition:transform .12s ease, box-shadow .16s ease}
.fs-go.focus{box-shadow:0 0 0 4px var(--teal-tint)}
.fs-go.press{transform:scale(.93)}
.fs-check{width:42px;height:42px;flex:none;border-radius:50%;background:var(--teal);color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px -4px rgba(47,179,164,.6)}
.fs-check .ic{width:22px;height:22px;stroke-width:2.6}
.fs-done-t{font:800 15px/1 var(--display);color:var(--ink)}
.fs-done-s{font:600 12.5px/1 var(--sans);color:var(--fg-2)}
.fs-cursor{position:absolute;left:0;top:0;width:22px;height:22px;z-index:3;
  opacity:0;transform:translate(var(--cx,40px),var(--cy,58px));
  transition:transform .7s cubic-bezier(.4,0,.2,1), opacity .3s ease;
  filter:drop-shadow(0 2px 4px rgba(26,34,56,.25))}
.fs-cursor svg{width:22px;height:22px;fill:#fff;stroke:var(--ink);stroke-width:1.5}
.fs-cursor.show{opacity:1}
.fs-cursor.tap{transform:translate(var(--cx),var(--cy)) scale(.82)}

@media (max-width:760px){
  .flow{grid-template-columns:1fr;gap:18px;padding-top:0}
  .flow-rail{display:none}
  .fviz::before{transform:scaleX(1)}
  .fstage h3{font-size:19px}
}
@media (prefers-reduced-motion: reduce){
  .fled{animation:none}
  .flow-dot,.fs-cursor,.fconn,.fb-eyebrow,.fb-title,.fb-val,.fb-ready,
  .fv-status,.fs-live,.fs-done,.fviz,.fviz::before{transition:none}
}

/* ---- pricing billing toggle (added) ---- */
.ptoggle{display:inline-flex;gap:4px;margin-top:24px;background:var(--bg-subtle);border:1px solid var(--line);border-radius:var(--r-pill);padding:4px}
.ptoggle-opt{display:inline-flex;align-items:center;gap:8px;border:0;background:transparent;cursor:pointer;font:700 14px/1 var(--sans);color:var(--fg-2);padding:10px 20px;border-radius:var(--r-pill);transition:background .15s,color .15s}
.ptoggle-opt.is-active{background:var(--ink);color:#fff}
.ptoggle-save{font:800 10.5px/1 var(--sans);letter-spacing:.05em;text-transform:uppercase;color:var(--teal-700)}
.ptoggle-opt.is-active .ptoggle-save{color:var(--teal-300)}
.pnote-link{color:var(--teal-700);font-weight:700}

/* ---- legal pages (privacy, terms) ---- */
.legal{padding:56px 0 104px}
.legal .wrap{max-width:780px}
.legal-head{margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.legal-head .kicker{display:block;margin-bottom:16px}
.legal-head h1{font-size:clamp(34px,5vw,48px);letter-spacing:-0.03em}
.legal-head .legal-date{margin-top:16px;font:500 13px/1 var(--mono);color:var(--fg-3)}
.legal h2{font-size:22px;margin:44px 0 14px}
.legal p{margin:0 0 14px;font-size:15.5px}
.legal ul{margin:0 0 14px;padding-left:22px;color:var(--fg-2);font-size:15.5px;line-height:1.55}
.legal li{margin-bottom:8px}
.legal a{color:var(--teal-700);font-weight:600}
.legal a:hover{color:var(--ink)}
.legal strong{color:var(--fg)}
.foot-bottom .c a:hover{color:var(--teal-700)}
@media (max-width:760px){
  .legal{padding:40px 0 72px}
}

/* ============================================================
   SALES AGENT CHAT WIDGET
   Public chat that pitches AimVisible. Scoped under .av-chat so it
   never touches the marketing layout. Reuses the brand tokens above.
   ============================================================ */
.av-launch{
  position:fixed;right:24px;bottom:24px;z-index:90;
  display:inline-flex;align-items:center;gap:10px;
  font:700 15px/1 var(--sans);letter-spacing:-0.01em;color:#fff;
  background:var(--ink);border:none;cursor:pointer;
  padding:14px 20px 14px 16px;border-radius:var(--r-pill);
  box-shadow:0 10px 30px rgba(26,34,56,.24);
  transition:background .16s ease,transform .16s ease,box-shadow .16s ease;
}
.av-launch:hover{background:var(--ink-900);transform:translateY(-1px);box-shadow:var(--shadow-pop)}
.av-launch:active{transform:translateY(0)}
.av-launch img{width:26px;height:26px;border-radius:50%}
.av-launch.is-open{display:none}

.av-panel{
  position:fixed;right:24px;bottom:24px;z-index:91;
  width:392px;max-width:calc(100vw - 32px);height:600px;max-height:calc(100vh - 48px);
  display:none;flex-direction:column;overflow:hidden;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
}
.av-panel.is-open{display:flex}

.av-accent{height:5px;flex:none;
  background:linear-gradient(90deg,var(--teal) 0 25%,var(--gold) 25% 50%,var(--coral) 50% 75%,var(--ink) 75% 100%);}

.av-head{display:flex;align-items:center;gap:11px;padding:15px 16px;border-bottom:1px solid var(--line)}
.av-head img{width:30px;height:30px}
.av-head .av-title{font-family:var(--display);font-weight:800;font-size:15.5px;letter-spacing:-0.02em;color:var(--fg)}
.av-head .av-sub{font:600 11.5px/1.2 var(--mono);letter-spacing:.04em;color:var(--fg-3);text-transform:uppercase;margin-top:2px}
.av-head .av-headtext{flex:1;min-width:0}
.av-bookchip{
  display:inline-flex;align-items:center;gap:6px;flex:none;
  font:700 12.5px/1 var(--sans);color:var(--teal-700);background:var(--teal-tint);
  border:none;cursor:pointer;padding:8px 12px;border-radius:var(--r-pill);
  transition:background .15s ease,color .15s ease;
}
.av-bookchip:hover{background:var(--teal);color:#fff}
.av-close{flex:none;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;
  border:none;background:transparent;cursor:pointer;color:var(--fg-3);border-radius:var(--r-sm)}
.av-close:hover{background:var(--bg-hover);color:var(--ink)}
.av-close svg{width:18px;height:18px;stroke-width:2.2}

.av-log{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:12px;background:var(--bg-subtle)}
.av-msg{max-width:86%;padding:11px 14px;border-radius:14px;font-size:14px;line-height:1.5}
.av-msg.av-bot{align-self:flex-start;background:#fff;color:var(--fg);border:1px solid var(--line);border-bottom-left-radius:5px}
.av-msg.av-user{align-self:flex-end;background:var(--ink);color:#fff;border-bottom-right-radius:5px}
.av-msg strong{font-weight:700}
.av-msg.av-note{align-self:center;max-width:94%;text-align:center;background:var(--teal-tint);
  color:var(--teal-700);border:none;font-weight:600;font-size:13px}
.av-msg.av-err{align-self:center;background:var(--coral-tint);color:var(--coral-700);border:none;font-size:13px}
.av-typing{display:inline-flex;gap:4px;align-items:center}
.av-typing i{width:6px;height:6px;border-radius:50%;background:var(--fg-3);opacity:.5;animation:avblink 1.2s infinite}
.av-typing i:nth-child(2){animation-delay:.2s}
.av-typing i:nth-child(3){animation-delay:.4s}
@keyframes avblink{0%,60%,100%{opacity:.25}30%{opacity:.9}}

.av-sugs{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}
.av-sug{font:600 12.5px/1 var(--sans);color:var(--fg);background:#fff;border:1px solid var(--line-strong);
  cursor:pointer;padding:9px 12px;border-radius:var(--r-pill);transition:background .15s,color .15s,border-color .15s}
.av-sug:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

.av-foot{flex:none;border-top:1px solid var(--line);padding:12px;display:flex;gap:9px;align-items:flex-end;background:#fff}
.av-input{flex:1;resize:none;border:1px solid var(--line-strong);border-radius:14px;
  padding:11px 13px;font:500 14px/1.4 var(--sans);color:var(--fg);max-height:120px;outline:none;
  transition:border-color .15s,box-shadow .15s}
.av-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(47,179,164,.20)}
.av-send{flex:none;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  border:none;background:var(--teal);color:#fff;border-radius:50%;cursor:pointer;transition:background .15s,opacity .15s}
.av-send:hover{background:var(--ink)}
.av-send:disabled{opacity:.45;cursor:not-allowed}
.av-send svg{width:19px;height:19px;stroke-width:2.2}
.av-disc{flex:none;text-align:center;font:500 10.5px/1.3 var(--sans);color:var(--fg-3);padding:0 12px 10px;background:#fff}

@media (max-width:520px){
  .av-panel{right:0;bottom:0;width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;border-radius:0;border:none}
  .av-launch{right:16px;bottom:16px}
}
@media (prefers-reduced-motion:reduce){
  .av-launch,.av-bookchip,.av-sug,.av-send,.av-input{transition:none}
  .av-typing i{animation:none}
}
