/* ========================================================================
 * pages/assistant_home.css
 *
 * Hiroi Assistant marketing landing (assistant.hiroi.ai).
 * Built on the System A token bridge (design-tokens.css + public-shared.css,
 * loaded before this file). All page classes are prefixed .ah- to avoid
 * collisions with welcome.css / the consumer .as- landing system.
 *
 * The .grad gradient, the pulsing-dot keyframe, and the dark mockup palette
 * are page-scoped in welcome.css, so the bits reused here are re-declared
 * locally under the .ah- prefix.
 * ======================================================================== */


/* ---- shared local primitives -------------------------------------------- */

.ah-grad{
  background:linear-gradient(135deg,#0f766e 0%,var(--teal) 42%,#2dd4bf 72%,#10b981 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

@keyframes ah-pdot{0%,100%{opacity:1;}50%{opacity:.25;}}


/* ---- section scaffolding ------------------------------------------------- */

.ah-sec{padding:96px 24px;position:relative;}
.ah-sec-alt{background:var(--bg2);}

/* fixed public_nav is 56px tall — offset in-page anchor jumps (#how, #pricing, etc.) */
.ah-sec[id],.ah-security[id]{scroll-margin-top:72px;}

.ah-sec-hd{text-align:center;max-width:620px;margin:0 auto 60px;}
.ah-sec-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--teal-fg);margin-bottom:12px;}
.ah-sec-hd h2{font-size:clamp(1.75rem,3.5vw,2.3rem);font-weight:700;letter-spacing:-.027em;line-height:1.14;margin-bottom:13px;text-wrap:pretty;}
.ah-sec-hd p{font-size:15px;color:var(--t2);line-height:1.65;}

.ah-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--teal-fg);margin-bottom:18px;}

.ah-microline{font-size:13px;color:var(--t3);letter-spacing:.005em;}

.ah-inline-link{
  color:var(--teal-fg);font-weight:600;
  text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;
  text-decoration-color:color-mix(in srgb,var(--teal-fg) 50%,transparent);
  transition:color .15s ease,text-decoration-color .15s ease;
}
.ah-inline-link:hover{color:var(--teal-h);text-decoration-color:var(--teal-fg);}
.ah-security-link a{
  color:var(--t3);text-decoration:none;
  border-bottom:1px solid transparent;transition:color .15s ease,border-color .15s ease;
}

/* branded keyboard focus rings — match .btn / .footer-links in public-shared.css */
.ah-inline-link:focus-visible,
.ah-security-link a:focus-visible{outline:2px solid var(--teal-fg);outline-offset:2px;border-radius:2px;}
/* light ring: .ah-voice-link sits on the dark teal band */
.ah-voice-link:focus-visible{outline:2px solid rgba(255,255,255,.9);outline-offset:2px;border-radius:2px;}


/* ========================================================================
 * 1. HERO
 * ===================================================================== */

.ah-hero{padding:148px 24px 84px;position:relative;overflow:hidden;}

.ah-hero-glow{
  position:absolute;top:-260px;left:62%;transform:translateX(-50%);
  width:1100px;height:1100px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(13,148,136,.08) 0%,rgba(96,165,250,.04) 38%,transparent 70%);
}

.ah-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(to right,rgba(0,0,0,.014) 1px,transparent 1px),
                   linear-gradient(to bottom,rgba(0,0,0,.014) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,black 0%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,black 0%,transparent 100%);
}
[data-theme="dark"] .ah-hero::after{
  background-image:linear-gradient(to right,rgba(255,255,255,.018) 1px,transparent 1px),
                   linear-gradient(to bottom,rgba(255,255,255,.018) 1px,transparent 1px);
}

.ah-hero-inner{
  position:relative;max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:minmax(0,1.04fr) minmax(0,1fr);
  gap:56px;align-items:center;
}

.ah-hero-copy h1{
  font-size:clamp(2.5rem,5vw,3.9rem);font-weight:700;letter-spacing:-.04em;
  line-height:1.05;margin-bottom:20px;text-wrap:pretty;max-width:14ch;
}
.ah-hero-copy>p{
  font-size:16px;color:var(--t2);line-height:1.65;letter-spacing:-.01em;
  max-width:30em;margin-bottom:30px;
}

.ah-hero-btns{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px;}
.ah-hero-btns .btn{padding:13px 28px;font-size:15px;}
.ah-hero-btns .btn-s{gap:7px;}
.ah-hero-btns .btn-s svg{flex-shrink:0;}


/* ---- hero mockup: unified live panel ---- */

.ah-hero-mock{position:relative;justify-self:end;width:100%;max-width:460px;}

.ah-mk{
  position:relative;z-index:1;
  font-family:var(--font);background:#0e0d0c;color:rgba(255,255,255,.82);
  border-radius:var(--r-xl);overflow:hidden;
  /* edge definition comes from the box-shadow's 1px ring below, not a border */
  box-shadow:0 28px 72px -16px rgba(30,42,40,.28),0 0 0 1px rgba(0,0,0,.03);
  --teal-text:#2dd4bf;
}

.ah-mk-chrome{
  height:34px;background:#161412;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:6px;padding:0 14px;
}
.ah-mk-dot{width:8px;height:8px;border-radius:50%;}
.ah-mk-dot.r{background:rgba(239,68,68,.55);}
.ah-mk-dot.y{background:rgba(245,158,11,.55);}
.ah-mk-dot.g{background:rgba(34,197,94,.55);}
.ah-mk-url{flex:1;text-align:center;font-size:9.5px;color:rgba(255,255,255,.5);letter-spacing:.03em;}

.ah-mk-panel{padding:16px 16px 14px;border-bottom:1px solid rgba(255,255,255,.06);}
.ah-mk-panel-hd{margin-bottom:12px;}
.ah-mk-chanchip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:9.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--r-full);
}
.ah-mk-chanchip svg{width:10px;height:10px;}
.ah-mk-chanchip.ct{background:rgba(45,212,191,.16);color:#2dd4bf;}

.ah-mk-bubble{
  font-size:12px;line-height:1.45;border-radius:12px;padding:9px 12px;
  margin-bottom:9px;max-width:88%;
}
.ah-mk-bubble.visitor{background:#1c1a18;border:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.72);border-bottom-left-radius:4px;}
.ah-mk-bubble.bot{
  background:rgba(45,212,191,.12);border:1px solid rgba(45,212,191,.22);
  border-left:2px solid #2dd4bf;color:rgba(255,255,255,.9);
  margin-left:auto;border-bottom-right-radius:4px;
}
.ah-mk-status{display:flex;align-items:center;gap:6px;font-size:9.5px;color:rgba(255,255,255,.55);margin-top:2px;}
.ah-mk-statusdot{width:5px;height:5px;border-radius:50%;background:#34d399;box-shadow:0 0 6px rgba(52,211,153,.7);}

.ah-mk-call{display:flex;align-items:center;gap:11px;padding:14px 16px;}
.ah-mk-call-icon{
  width:38px;height:38px;flex-shrink:0;border-radius:10px;
  background:linear-gradient(135deg,rgba(45,212,191,.32),rgba(45,212,191,.12));
  display:flex;align-items:center;justify-content:center;
}
.ah-mk-wave{display:flex;align-items:center;gap:2.5px;height:18px;}
.ah-mk-wave .ah-mk-wb{width:3px;border-radius:2px;background:#2dd4bf;height:7px;animation:ah-wb 1.2s ease-in-out infinite;}
.ah-mk-wave .ah-mk-wb:nth-child(2){background:#60a5fa;animation-delay:.18s;}
.ah-mk-wave .ah-mk-wb:nth-child(3){animation-delay:.36s;}
@keyframes ah-wb{0%,100%{height:6px;}50%{height:16px;}}

.ah-mk-call-body{flex:1;min-width:0;}
.ah-mk-call-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px;}
.ah-mk-call-label{font-size:11px;font-weight:600;color:rgba(255,255,255,.85);}
.ah-mk-live{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:600;color:#34d399;background:rgba(52,211,153,.14);padding:2px 7px;border-radius:var(--r-full);flex-shrink:0;}
.ah-mk-livedot{width:5px;height:5px;border-radius:50%;background:#34d399;animation:ah-pdot 1.6s ease-in-out infinite;}
.ah-mk-call-caption{font-size:10.5px;color:rgba(255,255,255,.55);line-height:1.4;font-style:italic;}


/* ========================================================================
 * 2. TWO JOBS, ONE ASSISTANT — the split
 * ===================================================================== */

.ah-split{
  max-width:1040px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch;
}

.ah-jobcard{
  background:var(--surface);border:1px solid var(--bd);border-radius:var(--r-xl);
  padding:32px 30px;position:relative;overflow:hidden;
  transition:border-color var(--base),transform var(--base),box-shadow var(--base);
}
.ah-jobcard:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);border-color:var(--bd-h);}
.ah-jobcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.ah-job-a::before{background:linear-gradient(90deg,var(--teal),#2dd4bf);}
.ah-job-b::before{background:linear-gradient(90deg,var(--bd-h),color-mix(in srgb,var(--teal) 22%,var(--bd)));}

.ah-kicker{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);display:block;margin-bottom:18px;}

.ah-jobicon{
  width:44px;height:44px;border-radius:var(--r-md);
  background:var(--teal-10);color:var(--teal-fg);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.ah-jobicon svg{width:22px;height:22px;}

.ah-jobcard h3{font-size:clamp(1.15rem,2.4vw,1.4rem);font-weight:700;letter-spacing:-.022em;margin-bottom:18px;}

.ah-jobs-list{list-style:none;display:flex;flex-direction:column;gap:13px;}
.ah-jobs-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--t2);line-height:1.55;}
.ah-jobs-list li svg{flex-shrink:0;margin-top:2px;color:var(--teal-fg);}

/* center spine joining the two cards into one assistant */
.ah-spine{display:flex;flex-direction:column;align-items:center;justify-content:center;width:64px;padding:0 4px;}
.ah-spine-line{flex:1;width:1px;background:linear-gradient(var(--bd),color-mix(in srgb,var(--teal) 30%,var(--bd)));}
.ah-spine-node{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;margin:8px 0;
  background:var(--teal);box-shadow:0 0 0 5px var(--teal-10),0 0 14px rgba(13,148,136,.4);
}

.ah-disambig{text-align:center;max-width:46em;margin:42px auto 0;font-size:13px;color:var(--t3);line-height:1.6;}


/* ========================================================================
 * 3. CAPABILITIES GRID
 * ===================================================================== */

.ah-cap-grid{
  max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}

.ah-cap-card{
  background:var(--surface);border:1px solid var(--bd);border-radius:var(--r-xl);
  padding:28px 26px;
  transition:border-color var(--base),transform var(--base),box-shadow var(--base);
}
.ah-cap-card:hover{transform:translateY(-2px);border-color:var(--teal-text);box-shadow:var(--sh-lg);}
[data-theme="dark"] .ah-cap-card:hover{border-color:var(--teal-fg);}

.ah-cap-icon{
  width:40px;height:40px;border-radius:var(--r-md);
  background:var(--teal-10);color:var(--teal-fg);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  transition:background var(--base);
}
.ah-cap-icon svg{width:20px;height:20px;}
.ah-cap-card:hover .ah-cap-icon{background:var(--teal-20);}

.ah-cap-card h3{font-size:18px;font-weight:600;letter-spacing:-.016em;margin-bottom:8px;}
.ah-cap-card p{font-size:14px;color:var(--t2);line-height:1.62;}


/* ========================================================================
 * 4. HOW IT WORKS — 3 steps
 * ===================================================================== */

.ah-steps{
  max-width:1080px;margin:0 auto;position:relative;
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}

/* dashed teal "data path" connector across the step numerals */
.ah-steps-connector{
  position:absolute;top:28px;left:16.6%;right:16.6%;height:0;
  border-top:2px dashed color-mix(in srgb,var(--blue,#60a5fa) 60%,transparent);
  pointer-events:none;
}

.ah-step{position:relative;text-align:center;padding:0 8px;}
.ah-step-n{
  width:56px;height:56px;border-radius:50%;margin:0 auto 18px;
  /* Solid surface (not the faint teal tint) so the teal numeral clears AA. */
  background:var(--surface);color:var(--teal-fg);
  border:1.5px solid color-mix(in srgb,var(--teal) 30%,var(--bd));
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;letter-spacing:-.02em;
  position:relative;z-index:1;box-shadow:0 0 0 6px var(--bg2),var(--sh-sm);
}
.ah-sec:not(.ah-sec-alt) .ah-step-n{box-shadow:0 0 0 6px var(--bg);}

.ah-step h3{font-size:16px;font-weight:600;letter-spacing:-.014em;margin-bottom:9px;}
.ah-step p{font-size:14px;color:var(--t2);line-height:1.62;max-width:30ch;margin:0 auto 18px;}

/* tiny per-step glyphs */
.ah-step-glyph{display:flex;align-items:center;justify-content:center;gap:6px;height:40px;}
.ah-glyph-doc{width:22px;height:28px;border-radius:4px;background:var(--surface);border:1px solid var(--bd-h);box-shadow:var(--sh-sm);}
.ah-glyph-doc.alt{background:var(--teal-10);border-color:color-mix(in srgb,var(--teal) 30%,var(--bd));}
.ah-step-glyph.toggles{gap:9px;}
.ah-glyph-tog{width:30px;height:16px;border-radius:9999px;position:relative;flex-shrink:0;}
.ah-glyph-tog.on{background:var(--teal);}
.ah-glyph-tog.off{background:var(--bd-h);}
.ah-glyph-thumb{width:12px;height:12px;border-radius:50%;background:#fff;position:absolute;top:2px;box-shadow:0 1px 2px rgba(0,0,0,.2);}
.ah-glyph-tog.on .ah-glyph-thumb{left:16px;}
.ah-glyph-tog.off .ah-glyph-thumb{left:2px;}
.ah-glyph-card{width:74px;height:38px;border-radius:8px;background:var(--surface);border:1px solid var(--bd-h);box-shadow:var(--sh-sm);position:relative;padding:8px 9px;display:flex;flex-direction:column;gap:5px;}
.ah-glyph-line{height:4px;border-radius:2px;background:var(--bd-h);width:72%;}
.ah-glyph-line.short{width:44%;}
.ah-glyph-pulse{position:absolute;right:8px;bottom:8px;width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px rgba(13,148,136,.5);animation:ah-pdot 1.8s ease-in-out infinite;}


/* ========================================================================
 * 5. SPEAKS NATURALLY — dark Hiroi Voice Core band
 * ===================================================================== */

.ah-voice{
  position:relative;overflow:hidden;padding:104px 24px;
  /* Kept dark across the full width so foreground text holds AA on every
     gradient stop — the teal accent lives in the glow/::after, not the base. */
  background:linear-gradient(108deg,#0d1c1a 0%,#0c2e2a 48%,#0c3f39 100%);
}
.ah-voice::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:5px 5px;
}
.ah-voice::after{
  content:'';position:absolute;top:-30%;right:-10%;width:680px;height:680px;border-radius:50%;
  background:radial-gradient(circle,rgba(96,165,250,.12) 0%,transparent 68%);pointer-events:none;
}

.ah-voice-inner{
  position:relative;max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
}

.ah-voice-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#5eead4;margin-bottom:16px;}
.ah-voice-copy h2{font-size:clamp(1.85rem,3.6vw,2.5rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;color:#fff;margin-bottom:18px;text-wrap:pretty;}
.ah-voice-copy>p{font-size:16px;line-height:1.7;color:rgba(255,255,255,.85);max-width:38em;margin-bottom:24px;}

.ah-voice-chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:24px;}
.ah-voice-chip{
  font-size:12.5px;font-weight:600;color:#a7f3d0;
  background:rgba(45,212,191,.12);border:1px solid rgba(45,212,191,.26);
  padding:5px 12px;border-radius:var(--r-full);
}

.ah-voice-link{display:inline-block;color:#fff;font-size:14px;border-bottom:1px solid rgba(255,255,255,.4);}
.ah-voice-link:hover{border-bottom-color:#fff;}

.ah-voice-visual{display:flex;justify-content:center;}
.ah-voice-capsule{
  width:100%;max-width:380px;
  background:rgba(8,20,18,.5);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-2xl, var(--radius-2xl));padding:26px 24px 20px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 24px 60px -18px rgba(0,0,0,.5);
}
.ah-voice-bars{display:flex;align-items:center;justify-content:center;gap:3px;height:96px;margin-bottom:18px;}
.ah-voice-bars span{
  width:4px;border-radius:2px;background:#2dd4bf;flex-shrink:0;
  height:18px;animation:ah-vbar 1.4s ease-in-out infinite;
}
.ah-voice-bars span:nth-child(3n){background:#60a5fa;}
.ah-voice-bars span:nth-child(1){animation-delay:0s;}
.ah-voice-bars span:nth-child(2){animation-delay:.07s;}
.ah-voice-bars span:nth-child(3){animation-delay:.14s;}
.ah-voice-bars span:nth-child(4){animation-delay:.21s;}
.ah-voice-bars span:nth-child(5){animation-delay:.28s;}
.ah-voice-bars span:nth-child(6){animation-delay:.35s;}
.ah-voice-bars span:nth-child(7){animation-delay:.42s;}
.ah-voice-bars span:nth-child(8){animation-delay:.49s;}
.ah-voice-bars span:nth-child(9){animation-delay:.56s;}
.ah-voice-bars span:nth-child(10){animation-delay:.63s;}
.ah-voice-bars span:nth-child(11){animation-delay:.7s;}
.ah-voice-bars span:nth-child(12){animation-delay:.63s;}
.ah-voice-bars span:nth-child(13){animation-delay:.56s;}
.ah-voice-bars span:nth-child(14){animation-delay:.49s;}
.ah-voice-bars span:nth-child(15){animation-delay:.42s;}
.ah-voice-bars span:nth-child(16){animation-delay:.35s;}
.ah-voice-bars span:nth-child(17){animation-delay:.28s;}
.ah-voice-bars span:nth-child(18){animation-delay:.21s;}
.ah-voice-bars span:nth-child(19){animation-delay:.14s;}
.ah-voice-bars span:nth-child(20){animation-delay:.07s;}
.ah-voice-bars span:nth-child(21){animation-delay:0s;}
.ah-voice-bars span:nth-child(22){animation-delay:.1s;}
.ah-voice-bars span:nth-child(23){animation-delay:.2s;}
.ah-voice-bars span:nth-child(24){animation-delay:.3s;}
.ah-voice-bars span:nth-child(25){animation-delay:.4s;}
.ah-voice-bars span:nth-child(26){animation-delay:.5s;}
.ah-voice-bars span:nth-child(27){animation-delay:.6s;}
.ah-voice-bars span:nth-child(28){animation-delay:.7s;}
@keyframes ah-vbar{0%,100%{height:14px;}50%{height:64px;}}

.ah-voice-cap{display:flex;align-items:center;justify-content:center;gap:7px;font-size:12px;font-weight:600;color:rgba(255,255,255,.85);}
.ah-voice-capdot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 8px rgba(52,211,153,.8);animation:ah-pdot 1.6s ease-in-out infinite;}


/* ========================================================================
 * 6. PRICING TEASER
 * ===================================================================== */

.ah-price-panel{
  max-width:520px;margin:0 auto;text-align:center;
  background:var(--surface);border:1px solid var(--bd);border-radius:var(--r-xl);
  padding:32px 32px 30px;box-shadow:var(--sh-md);
}
.ah-price-rows{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:26px;text-align:left;}
.ah-price-rows li{display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--t1);font-weight:500;}
.ah-price-rows li svg{flex-shrink:0;color:var(--teal-fg);}
.ah-price-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.ah-price-btns .btn{padding:12px 26px;font-size:14px;}


/* ========================================================================
 * 7. SECURITY & TRUST STRIP
 * ===================================================================== */

.ah-security{
  padding:80px 24px;
  border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);
}
.ah-security-inner{max-width:1120px;margin:0 auto;}
.ah-security-hd{margin-bottom:48px;}

.ah-trust-row{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.ah-trust-tile{text-align:center;padding:6px 24px;position:relative;}
.ah-trust-tile:not(:first-child)::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;width:1px;background:var(--bd);
}
.ah-trust-icon{
  width:46px;height:46px;border-radius:50%;margin:0 auto 16px;
  background:var(--teal-10);color:var(--teal-fg);
  display:flex;align-items:center;justify-content:center;
}
.ah-trust-icon svg{width:22px;height:22px;}
.ah-trust-tile h3{font-size:15px;font-weight:600;letter-spacing:-.012em;margin-bottom:7px;}
.ah-trust-tile p{font-size:13px;color:var(--t2);line-height:1.55;}

.ah-security-link{text-align:center;margin-top:42px;font-size:13px;}
.ah-security-link a{color:var(--t3);}
.ah-security-link a:hover{color:var(--teal-text);}
[data-theme="dark"] .ah-security-link a:hover{color:var(--teal-fg);}


/* ========================================================================
 * 8. FINAL CTA
 * ===================================================================== */

.ah-cta{
  position:relative;overflow:hidden;padding:118px 24px;text-align:center;
  background:linear-gradient(180deg,var(--bg) 0%,color-mix(in srgb,var(--teal) 6%,var(--bg)) 100%);
}
.ah-cta-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:760px;height:760px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(13,148,136,.1) 0%,transparent 66%);
}
.ah-cta-mock{
  position:absolute;top:14%;right:8%;pointer-events:none;opacity:.16;
  transform:rotate(-4deg);
}
.ah-cta-bubble{
  background:var(--surface);
  border:1px solid var(--bd);border-left:2px solid var(--teal);
  border-radius:12px;padding:13px 16px;width:200px;box-shadow:var(--sh-md);
  display:flex;flex-direction:column;gap:7px;
}
.ah-cta-bubble-line{height:7px;border-radius:4px;background:var(--bd-h);width:100%;}
.ah-cta-bubble-line.short{width:60%;}

.ah-cta-inner{position:relative;max-width:560px;margin:0 auto;}
.ah-cta-inner h2{font-size:clamp(1.9rem,4vw,2.6rem);font-weight:700;letter-spacing:-.03em;line-height:1.12;margin-bottom:16px;text-wrap:pretty;}
.ah-cta-inner>p{font-size:16px;color:var(--t2);line-height:1.65;margin-bottom:30px;}
.ah-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:18px;}
.ah-cta-btns .btn{padding:13px 30px;font-size:15px;}

/* one-time attention pulse on the primary CTA (gated by reduced motion) */
.ah-cta-primary{animation:ah-cta-pulse 600ms ease-out .9s 1;}
@keyframes ah-cta-pulse{0%{transform:scale(1);}40%{transform:scale(1.03);}100%{transform:scale(1);}}


/* ========================================================================
 * RESPONSIVE
 * ===================================================================== */

@media(max-width:1024px){
  .ah-hero-inner{grid-template-columns:1fr;gap:44px;text-align:center;}
  .ah-hero-copy h1{max-width:none;}
  .ah-hero-copy>p{margin-left:auto;margin-right:auto;}
  .ah-hero-btns,.ah-hero-copy .ah-eyebrow{justify-content:center;}
  .ah-hero-mock{justify-self:center;margin:0 auto;}
  .ah-cap-grid{grid-template-columns:repeat(2,1fr);}
  .ah-voice-inner{grid-template-columns:1fr;gap:40px;}
  .ah-voice-visual{order:-1;}
}

@media(max-width:768px){
  .ah-sec{padding:72px 20px;}
  .ah-voice{padding:80px 20px;}
  .ah-security{padding:64px 20px;}
  .ah-split{grid-template-columns:1fr;max-width:520px;gap:0;}
  .ah-spine{flex-direction:row;width:auto;height:48px;padding:0;}
  .ah-spine-line{width:auto;height:1px;flex:1;background:linear-gradient(90deg,var(--bd),color-mix(in srgb,var(--teal) 30%,var(--bd)));}
  .ah-spine-node{margin:0 8px;}
  .ah-steps{grid-template-columns:1fr;gap:0;max-width:480px;}
  .ah-steps-connector{display:none;}
  .ah-step{display:grid;grid-template-columns:56px 1fr;text-align:left;gap:18px;padding:22px 0;align-items:start;}
  .ah-step:not(:last-child){border-bottom:1px solid var(--bd);}
  .ah-step-n{margin:0;box-shadow:none;}
  .ah-sec .ah-step-n,.ah-sec:not(.ah-sec-alt) .ah-step-n{box-shadow:none;}
  .ah-step h3{grid-column:2;}
  .ah-step p{grid-column:2;text-align:left;margin:0 0 12px;max-width:none;}
  .ah-step-glyph{grid-column:2;justify-content:flex-start;height:auto;}
  .ah-trust-row{grid-template-columns:repeat(2,1fr);gap:36px 0;}
  .ah-trust-tile:nth-child(odd)::before{display:none;}
  .ah-cta-mock{display:none;}
}

@media(max-width:480px){
  .ah-hero{padding:128px 20px 64px;}
  .ah-sec{padding:60px 16px;}
  .ah-sec-hd{margin-bottom:40px;}
  .ah-cap-grid{grid-template-columns:1fr;}
  .ah-trust-row{grid-template-columns:1fr;gap:30px;}
  .ah-trust-tile::before{display:none!important;}
  .ah-hero-btns,.ah-price-btns,.ah-cta-btns{flex-direction:column;width:100%;}
  .ah-hero-btns .btn,.ah-price-btns .btn,.ah-cta-btns .btn{width:100%;}
  .ah-price-panel{padding:26px 22px;}
  .ah-jobcard{padding:26px 22px;}
  .ah-voice-copy h2{font-size:1.85rem;}
}


/* ========================================================================
 * REDUCED MOTION — kill loops + transforms, keep everything visible
 * ===================================================================== */
@media (prefers-reduced-motion:reduce){
  .ah-mk-wave .ah-mk-wb,
  .ah-mk-livedot,
  .ah-glyph-pulse,
  .ah-voice-bars span,
  .ah-voice-capdot,
  .ah-cta-primary{animation:none;}
  .ah-voice-bars span{height:38px;}
  .ah-voice-bars span:nth-child(2n){height:22px;}
  .ah-voice-bars span:nth-child(3n){height:54px;}
  .ah-jobcard:hover,.ah-cap-card:hover{transform:none;}
}
