/* Metix — rebuilt in the Ando.so design language.
   Clean white surfaces, Sora display type, generous whitespace,
   pill buttons, soft rounded cards, sky-backed product windows. */

/* ---------------- fonts ---------------- */
@font-face{font-family:"Sora";src:url(fonts/sora.woff2) format("woff2");font-weight:100 800;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Sora";src:url(fonts/sora-ext.woff2) format("woff2");font-weight:100 800;font-display:swap;
  unicode-range:U+0100-02BA,U+1E00-1E9F,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:"Geist";src:url(fonts/geist-sans.woff2) format("woff2");font-weight:100 900;font-display:swap}
@font-face{font-family:"Geist Mono";src:url(fonts/geist-mono.woff2) format("woff2");font-weight:100 900;font-display:swap}

/* ---------------- tokens ---------------- */
:root{
  color-scheme:light only;
  --surface:#ffffff;
  --surface-2:#fafafa;
  --surface-3:#f5f5f4;
  --inverse:#161514;
  --text-strong:#161514;
  --text:rgba(22,21,20,.92);
  --text-2:rgba(22,21,20,.66);
  --text-3:rgba(22,21,20,.56);
  --text-inv:#ffffff;
  --text-inv-2:rgba(255,255,255,.66);
  --border:rgba(22,21,20,.08);
  --border-2:rgba(22,21,20,.12);
  --accent:#4B3FD4;
  --accent-2:#7C6BF0;
  --accent-soft:#EEEBFB;
  --accent-line:#ddd6f7;
  --display:"Sora","Geist",system-ui,sans-serif;
  --sans:"Geist",system-ui,-apple-system,sans-serif;
  --mono:"Geist Mono",ui-monospace,monospace;
  --maxw:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--surface)}
body{background:var(--surface);color:var(--text);font-family:var(--sans);
  font-size:17px;line-height:1.6;letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,canvas,svg{display:block;max-width:100%}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative}
@media(min-width:768px){.wrap{padding:0 40px}}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:-.022em;line-height:1.08}
.display{font-family:var(--display);font-weight:400;letter-spacing:-.022em}
.em{color:var(--text-2)}            /* secondary-tone phrase in headings */
.accent{color:var(--accent)}
.muted{color:var(--text-2)}
.mono{font-family:var(--mono);letter-spacing:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------------- buttons ---------------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);
  font-weight:500;font-size:15px;line-height:1;padding:0 18px;height:44px;border-radius:999px;cursor:pointer;
  border:1px solid transparent;white-space:nowrap;
  transition:background .18s,color .18s,border-color .18s,transform .18s var(--ease),box-shadow .25s var(--ease)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--inverse);color:var(--text-inv)}
.btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 10px 26px -12px rgba(0,0,0,.5)}
.btn-secondary{background:var(--surface-3);color:var(--text)}
.btn-secondary:hover{background:#ebebe9;color:var(--text-strong)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border-2)}
.btn-ghost:hover{border-color:var(--text-strong);transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#3f34c2;transform:translateY(-1px);box-shadow:0 12px 28px -14px rgba(75,63,212,.7)}
.btn-light{background:#fff;color:var(--inverse)}
.btn-light:hover{background:#f1f1ef;transform:translateY(-1px)}
.btn-dark-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.22)}
.btn-dark-ghost:hover{border-color:#fff;transform:translateY(-1px)}
.btn-lg{height:52px;font-size:16px;padding:0 24px}

/* ---------------- nav ---------------- */
nav{position:sticky;top:0;z-index:60;transition:background .3s,border-color .3s,box-shadow .3s;
  border-bottom:1px solid transparent}
nav.scrolled{background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid var(--border);box-shadow:0 1px 24px -18px rgba(0,0,0,.4)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-size:23px;
  letter-spacing:-.03em;color:var(--text-strong)}
.logo img{height:28px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links .nlink{padding:8px 12px;border-radius:9px;color:var(--text-2);font-size:15px;font-weight:450;
  transition:color .18s,background .18s}
.nav-links .nlink:hover{color:var(--text-strong)}
.nav-links .sep{width:1px;height:18px;background:var(--border-2);margin:0 6px}
.nav-burger{display:none;width:42px;height:42px;border:1px solid var(--border);border-radius:11px;
  background:rgba(255,255,255,.6);align-items:center;justify-content:center;flex-direction:column;gap:5px;
  cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}
.nav-burger span{display:block;width:18px;height:1.7px;background:var(--text-strong);border-radius:2px;
  transition:transform .26s var(--ease),opacity .18s}
#nav.open .nav-burger span:nth-child(1){transform:translateY(6.7px) rotate(45deg)}
#nav.open .nav-burger span:nth-child(2){opacity:0}
#nav.open .nav-burger span:nth-child(3){transform:translateY(-6.7px) rotate(-45deg)}
@media(max-width:760px){
  .nav-burger{display:flex}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:3px;
    background:rgba(255,255,255,.94);backdrop-filter:blur(18px) saturate(1.4);
    border-bottom:1px solid var(--border);box-shadow:0 26px 44px -30px rgba(0,0,0,.45);
    padding:14px clamp(20px,5vw,40px) 20px;
    opacity:0;visibility:hidden;transform:translateY(-8px);pointer-events:none;
    transition:opacity .24s var(--ease),transform .24s var(--ease),visibility .24s}
  #nav.open .nav-links{opacity:1;visibility:visible;transform:none;pointer-events:auto}
  .nav-links .nlink{padding:13px 12px;font-size:16px;border-radius:11px}
  .nav-links .nlink:hover{background:var(--surface-2)}
  .nav-links .sep{display:none}
  .nav-links .btn-primary{justify-content:center;margin-top:7px;padding:14px;font-size:16px}
}

/* ---------------- layout / reveal ---------------- */
section{padding:104px 0}
@media(max-width:760px){section{padding:72px 0}}
.band{background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.center{text-align:center}
.reveal{opacity:0;filter:blur(8px);transform:translateY(18px);
  transition:opacity .8s var(--ease),filter .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;filter:blur(0);transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

.eyebrow{display:inline-block;font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.04em;
  text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.pill-link{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 14px;border-radius:999px;
  background:linear-gradient(180deg,rgba(22,21,20,.02),rgba(22,21,20,.04));
  box-shadow:0 0 0 1px var(--border),0 0 0 2px rgba(22,21,20,.02);
  color:var(--text-2);font-size:14px;transition:color .18s}
.pill-link:hover{color:var(--text-strong)}
.pill-link .arr{transition:transform .2s var(--ease)}
.pill-link:hover .arr{transform:translateX(2px)}

.statement{font-family:var(--display);font-weight:400;letter-spacing:-.025em;line-height:1.1;
  font-size:clamp(30px,4.4vw,52px);text-wrap:balance}
.lead{font-size:clamp(17px,2vw,20px);color:var(--text-2);line-height:1.55;max-width:60ch}
.body-narrow{max-width:58ch;margin:18px auto 0;color:var(--text-2);font-size:18px}
/* manifesto lede — four beats, each block balanced so no line is left dangling */
.lede{max-width:58ch;margin:24px auto 0;display:flex;flex-direction:column;gap:1.15em;
  color:var(--text-2);font-size:18px;line-height:1.62}
.lede p{text-wrap:balance}
.lede .lede-end{color:var(--text-strong)}
@media(max-width:600px){.lede{font-size:16.5px;gap:1em;text-align:left}}

/* ---------------- hero ---------------- */
.hero{position:relative;padding:64px 0 0;text-align:center;overflow:hidden}
.hero h1{font-size:clamp(44px,7.4vw,88px);letter-spacing:-.03em;line-height:1.06;max-width:16ch;margin:22px auto 0;
  display:flex;flex-direction:column;align-items:center}
.hero .lead{margin:24px auto 0}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.hero .fineprint{margin-top:18px;font-size:14px;color:var(--text-3)}

/* sky-backed product window frame (the Ando hero treatment) */
.showcase{padding:56px 0 0}
.sky-frame{position:relative;border-radius:28px;padding:10px;overflow:hidden;
  border:.5px solid var(--border-2)}
.sky-frame .sky{position:absolute;inset:0;z-index:0;
  background:url(img/social-bg.svg) center/cover no-repeat}
.sky-inner{position:relative;z-index:1;padding:54px clamp(16px,5vw,86px);display:flex;justify-content:center}

/* mac window */
.window{width:100%;background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:0 4px 16px -2px rgba(0,0,0,.08),0 24px 60px -18px rgba(40,30,90,.32),0 0 0 .5px rgba(0,0,0,.04)}
.win-bar{position:relative;display:flex;align-items:center;height:38px;padding:0 14px;
  border-bottom:1px solid var(--border);background:#fcfcfc}
.win-bar .dots{display:flex;gap:7px}
.win-bar .dots i{width:11px;height:11px;border-radius:50%;border:.5px solid rgba(0,0,0,.08)}
.win-bar .dots i:nth-child(1){background:#ff736a}.win-bar .dots i:nth-child(2){background:#febc2e}.win-bar .dots i:nth-child(3){background:#19c332}
.win-bar .title{position:absolute;left:0;right:0;text-align:center;font-size:13px;font-weight:600;color:rgba(0,0,0,.55);pointer-events:none;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 14px}
@media(max-width:560px){.win-bar .title{left:72px;right:14px;text-align:left;padding:0;font-size:12px}}

/* shortlist app */
.app{display:grid;grid-template-columns:236px 1fr}
.rail{background:#fbfbfa;border-right:1px solid var(--border);padding:22px 18px}
.rail .role{font-family:var(--display);font-size:19px;line-height:1.15;color:var(--text-strong)}
.rail .role small{display:block;font-family:var(--sans);font-size:12px;color:var(--text-3);margin-top:5px}
.rail .prog{margin-top:24px;display:flex;flex-direction:column;gap:2px}
.rail .pstep{position:relative;display:flex;align-items:center;gap:11px;font-size:13.5px;color:var(--text-3);padding:8px 0;transition:color .3s}
/* connector — runs from each tick centre to the next; ticks mask the overlap */
.rail .pstep:not(:last-child)::before{content:"";position:absolute;left:8px;top:50%;width:2px;height:calc(100% + 2px);
  background:#e6e3f5;z-index:0;transition:background .45s var(--ease)}
.rail .pstep.done:not(:last-child)::before{background:linear-gradient(180deg,var(--accent),var(--accent-2))}
.rail .pstep .tick{position:relative;z-index:1;flex:none;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-2);
  background:#fbfbfa;display:grid;place-items:center;transition:background .3s,border-color .3s}
.rail .pstep .tick .ck{grid-area:1/1;width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round;opacity:0;transform:scale(.5);transition:.28s var(--ease)}
.rail .pstep.done{color:var(--text)}
.rail .pstep.done .tick{background:var(--accent);border-color:var(--accent)}
.rail .pstep.done .tick .ck{opacity:1;transform:none}
.rail .pstep.active{color:var(--text-strong);font-weight:500}
.rail .pstep.active .tick{border-color:var(--accent);border-width:2px}
.rail .pstep.active .tick::after{content:"";grid-area:1/1;width:8px;height:8px;border-radius:50%;background:var(--accent);animation:ping 1.7s var(--ease) infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(75,63,212,.45)}70%{box-shadow:0 0 0 7px rgba(75,63,212,0)}100%{box-shadow:0 0 0 0 rgba(75,63,212,0)}}

/* ---- auto-play demo stages ---- */
.stage-wrap{position:relative;min-height:336px;overflow:hidden}
.stage{position:absolute;inset:20px 24px;background:#fff;z-index:1;opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .4s var(--ease),transform .5s var(--ease)}
.stage.on{opacity:1;transform:none;pointer-events:auto;z-index:2}
.stage-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.stage-head .t{font-size:14px;font-weight:500;color:var(--text)}
.stage-head .t b{color:var(--accent);font-weight:600}
.step-of{font-family:var(--mono);font-size:11.5px;color:var(--text-3);letter-spacing:.03em}
.badge{font-size:11.5px;font-weight:500;border-radius:999px;padding:4px 11px;display:inline-flex;align-items:center;gap:6px}
.badge.live{color:#2f7a4e;background:#E6F4EC;border:1px solid #c9e7d4}
.badge.live::before{content:"";width:6px;height:6px;border-radius:50%;background:#34a853;animation:blink 1.6s infinite}
.badge.scan{color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-line)}
.badge.scan .spin{width:11px;height:11px;border-radius:50%;border:1.6px solid var(--accent-line);border-top-color:var(--accent);animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* stage 0 — role brief */
.dchat{display:flex;flex-direction:column;gap:10px}
.dchat .bub{max-width:90%;min-height:1em}
.dchat .caret{display:inline-block;width:2px;height:1.05em;vertical-align:-2px;margin-left:1px;background:#fff;animation:blink .9s steps(1) infinite}
.stage[data-s="0"].typed .caret{display:none}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.chips .chip{font-size:12.5px;font-weight:500;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-line);
  border-radius:999px;padding:6px 12px;opacity:0;transform:scale(.82)}
.stage[data-s="0"].run .chip{animation:chipIn .42s var(--ease) forwards}
.stage[data-s="0"].run .chip:nth-child(1){animation-delay:1.55s}.stage[data-s="0"].run .chip:nth-child(2){animation-delay:1.68s}
.stage[data-s="0"].run .chip:nth-child(3){animation-delay:1.81s}.stage[data-s="0"].run .chip:nth-child(4){animation-delay:1.94s}
.stage[data-s="0"].run .chip:nth-child(5){animation-delay:2.07s}
@keyframes chipIn{to{opacity:1;transform:none}}
.brief-ok{margin-top:20px;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:#2f7a4e;opacity:0}
.brief-ok .ok-ic{width:18px;height:18px;border-radius:50%;background:#34a853;display:grid;place-items:center}
.brief-ok .ok-ic svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
.stage[data-s="0"].run .brief-ok{animation:fadeUp .5s var(--ease) 2.5s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* stage 1 — search */
/* an elegant narrowing progression instead of dashboard bars: scanned → matched → shortlisted */
.narrow{display:flex;align-items:center;gap:16px;margin:10px 0 28px}
.narrow .nd{display:flex;flex-direction:column;gap:3px;flex:none}
.narrow .nd b{font-family:var(--display);font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--text-strong);font-variant-numeric:tabular-nums}
.narrow .nd span{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}
.narrow .nd.hot b{color:var(--accent)}
.narrow-c{flex:1;min-width:18px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--accent-line),var(--accent-soft));position:relative}
.narrow-c::after{content:"";position:absolute;right:0;top:50%;width:5px;height:5px;border-right:1.6px solid var(--accent-2);border-top:1.6px solid var(--accent-2);transform:translate(1px,-50%) rotate(45deg)}
.scan-num{font-variant-numeric:tabular-nums}
/* real candidates surfacing from the search (an avatar stack), then the human
   delivery-lead checking quality — replaces the old placeholder-dot stream */
.surfacing{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.surf-avs{display:flex;align-items:center}
.surf-avs .sav{flex:none;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:600;
  font-family:var(--display);border:2px solid #fff;margin-left:-9px;box-shadow:0 6px 14px -6px rgba(22,21,20,.45)}
.surf-avs .sav:first-child{margin-left:0}
.surf-avs .sav.more{background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:500}
.surf-avs .surf-cap{margin-left:12px;font-size:12.5px;color:var(--text-3)}
.surf-lead{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-3)}
.surf-lead .lead-ic{flex:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#34a853,#2f8f6a);display:grid;place-items:center}
.surf-lead .lead-ic svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
.stage[data-s="1"] .surf-avs .sav{opacity:0;transform:scale(.55) translateY(5px)}
.stage[data-s="1"] .surf-cap,.stage[data-s="1"] .surf-lead{opacity:0}
.stage[data-s="1"].run .surf-avs .sav{animation:savPop .55s var(--ease) forwards}
.stage[data-s="1"].run .surf-avs .sav:nth-child(1){animation-delay:.5s}
.stage[data-s="1"].run .surf-avs .sav:nth-child(2){animation-delay:.66s}
.stage[data-s="1"].run .surf-avs .sav:nth-child(3){animation-delay:.82s}
.stage[data-s="1"].run .surf-avs .sav:nth-child(4){animation-delay:.98s}
.stage[data-s="1"].run .surf-avs .sav:nth-child(5){animation-delay:1.14s}
.stage[data-s="1"].run .surf-cap{animation:savPop .5s var(--ease) 1.3s forwards}
.stage[data-s="1"].run .surf-lead{animation:savFade .5s var(--ease) 1.55s forwards}
@keyframes savPop{to{opacity:1;transform:none}}
@keyframes savFade{to{opacity:1}}

/* stage 2 & 3 — candidate / booked rows */
.dlist{display:flex;flex-direction:column;gap:2px}
.drow{display:flex;align-items:center;gap:13px;padding:11px 10px;border-radius:12px;border:1px solid transparent}
.stage.on .drow{opacity:0;transform:translateY(10px)}
.stage.run .drow{animation:rowIn .5s var(--ease) forwards}
.stage.run .drow:nth-child(1){animation-delay:.06s}.stage.run .drow:nth-child(2){animation-delay:.19s}
.stage.run .drow:nth-child(3){animation-delay:.32s}.stage.run .drow:nth-child(4){animation-delay:.45s}
@keyframes rowIn{to{opacity:1;transform:none}}
.drow .dav{flex:none;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:14px;color:#fff}
.drow .dwho{flex:1;min-width:0}
.drow .dwho .nm{font-weight:500;font-size:15px;color:var(--text-strong)}
.drow .dwho .rl{font-size:13px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* warm interest signal instead of a match score — a soft "available" dot */
.drow .dsig{flex:none;display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-2);white-space:nowrap}
.drow .dsig .sig-dot{flex:none;width:7px;height:7px;border-radius:50%;background:#1f9d57;box-shadow:0 0 0 3px rgba(31,157,87,.14)}
.stage[data-s="2"].run .drow .dsig .sig-dot{animation:sigPulse 2.4s var(--ease) infinite}
@keyframes sigPulse{0%,100%{box-shadow:0 0 0 3px rgba(31,157,87,.14)}50%{box-shadow:0 0 0 5px rgba(31,157,87,.05)}}
.drow .dbook{flex:none;font-size:13px;font-weight:500;color:var(--accent);border:1px solid var(--accent-line);
  background:var(--accent-soft);padding:7px 14px;border-radius:999px;transition:.18s;cursor:default;display:inline-flex;align-items:center;gap:6px}
/* stage 3 — a real week time-grid; each interview is a time-positioned event */
.wk{--hh:40px;display:flex;flex-direction:column}
.wk-head{display:grid;grid-template-columns:32px repeat(5,1fr);align-items:end;padding-bottom:9px;border-bottom:1px solid var(--border)}
.wk-corner{font-family:var(--mono);font-size:9px;letter-spacing:.05em;color:var(--text-3);text-transform:uppercase}
.wk-d{text-align:center}
.wk-d b{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-weight:500;margin-bottom:5px}
.wk-d em{font-family:var(--display);font-style:normal;font-size:15px;line-height:1;color:var(--text-strong)}
.wk-d.today b{color:var(--accent)}
.wk-d.today em{display:inline-grid;place-items:center;width:25px;height:25px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px}
.wk-body{display:grid;grid-template-columns:32px 1fr}
.wk-axis{position:relative}
.wk-axis span{position:absolute;left:0;top:calc(var(--i,0)*var(--hh));transform:translateY(-.5em);font-family:var(--mono);font-size:9px;color:var(--text-3)}
.wk-axis span:nth-child(2){--i:1}.wk-axis span:nth-child(3){--i:2}.wk-axis span:nth-child(4){--i:3}.wk-axis span:nth-child(5){--i:4}
.wk-grid{position:relative;display:grid;grid-template-columns:repeat(5,1fr);height:calc(5*var(--hh));
  background:repeating-linear-gradient(to bottom,var(--border) 0,var(--border) 1px,transparent 1px,transparent var(--hh))}
.wk-col{border-right:1px solid var(--border)}
.wk-col:last-child{border-right:0}
.wk-col.today{background:rgba(75,63,212,.045)}
.wk-now{position:absolute;top:var(--nt);left:0;width:20%;border-top:2px solid var(--accent);z-index:3}
.wk-now::before{content:"";position:absolute;left:-3px;top:-4px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.ev{position:absolute;top:var(--t);height:var(--h);left:calc(var(--col)*20% + 4px);width:calc(20% - 8px);z-index:2;
  border-radius:7px;border-left:3px solid var(--c);padding:4px 8px;overflow:hidden;
  background:#fafbff;background:color-mix(in srgb,var(--c) 11%,#fff);box-shadow:0 5px 12px -8px rgba(22,21,20,.45)}
.ev b{display:block;font-size:10.5px;font-weight:600;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.35}
.ev i{font-style:normal;font-family:var(--mono);font-size:9px;color:var(--text-3)}
.ev .ev-dot{position:absolute;top:6px;right:7px;width:6px;height:6px;border-radius:50%;background:#1f9d57}
.ev .ev-dot.pend{background:transparent;border:1.4px solid var(--text-3)}
.ev:has(.pend){border-left-style:dashed;background:#fcfcfe}
.stage[data-s="3"].run .ev{animation:evIn .5s var(--ease) backwards}
@keyframes evIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
@media(max-width:720px){.app{grid-template-columns:1fr}.rail{display:none}}

/* trust ribbon */
.ribbon-cap{text-align:center;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:18px}
.ribbon{position:relative;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.ribbon-track{display:flex;width:max-content;animation:marq 34s linear infinite}
.ribbon:hover .ribbon-track{animation-play-state:paused}
.ribbon-group{display:flex;align-items:center}
.ribbon-item{font-family:var(--display);font-size:24px;color:var(--text-2);letter-spacing:-.01em;
  padding:0 30px;white-space:nowrap;display:flex;align-items:center;gap:30px}
.ribbon-item::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.55}
@keyframes marq{to{transform:translateX(-50%)}}
.award-line{text-align:center;font-size:14px;color:var(--text-3);margin-top:20px}

/* formula */
.formula{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;gap:14px;margin-top:52px;text-align:left}
.fcard{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:32px 30px 34px;
  min-height:300px;display:flex;flex-direction:column;align-items:flex-start;overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s}
.fcard:hover{transform:translateY(-5px);box-shadow:0 28px 56px -32px rgba(40,30,90,.45);border-color:var(--accent-line)}
.fcard .ic{width:48px;height:48px;border-radius:14px;background:var(--accent-soft);display:grid;place-items:center;
  margin-bottom:28px;transition:transform .4s var(--ease)}
.fcard:hover .ic{transform:scale(1.07)}
.fcard .ic svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.fcard .k{font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}
.fcard h3{font-family:var(--display);font-size:24px;font-weight:400;letter-spacing:-.018em;margin-bottom:11px;line-height:1.12}
.fcard p{font-size:15px;color:var(--text-2);line-height:1.55}
.fcard.out{background:var(--inverse);color:#fff;border-color:var(--inverse)}
.fcard.out:hover{border-color:var(--inverse)}
.fcard.out .ic{background:rgba(255,255,255,.13)}
.fcard.out .ic svg{stroke:#fff}
.fcard.out .k{color:var(--accent-2)}
.fcard.out h3{color:#fff}.fcard.out p{color:var(--text-inv-2)}
.fop{display:grid;place-items:center;font-family:var(--display);font-size:26px;color:var(--text-3);min-width:20px}
@media(max-width:820px){.formula{grid-template-columns:1fr;gap:10px;text-align:left}.fcard{min-height:0;padding:28px 26px}
  .fcard .k{margin-top:20px}.fop{padding:4px 0;font-size:22px}}

/* proof stats */
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:32px 26px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .3s}
.stat:hover{transform:translateY(-5px);border-color:var(--border-2);box-shadow:0 18px 40px -24px rgba(40,30,90,.32)}
.stat .num{font-family:var(--display);font-size:56px;line-height:.95;color:var(--text-strong);letter-spacing:-.03em}
.stat .num .u{color:var(--accent)}
.stat .lbl{font-size:14.5px;color:var(--text-2);margin-top:12px;line-height:1.45}
.proof-foot{text-align:center;font-size:13.5px;color:var(--text-3);margin-top:30px;max-width:60ch;margin-inline:auto}
@media(max-width:880px){.proof-grid{grid-template-columns:repeat(2,1fr)}}

/* who / steps grids */
.two-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:46px}
.who-card{position:relative;background:#fff;border:1px solid var(--border);border-radius:24px;padding:40px;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .35s}
.who-card:hover{transform:translateY(-5px);border-color:var(--accent-line);
  box-shadow:0 0 0 1px var(--accent-line),0 30px 60px -34px rgba(75,63,212,.42)}
.who-card .ic{width:50px;height:50px;border-radius:14px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:20px}
.who-card .ic svg{width:25px;height:25px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.who-card h3{font-size:25px;margin-bottom:12px;line-height:1.15}
.who-card p{font-size:16px;color:var(--text-2)}
@media(max-width:768px){.two-grid{grid-template-columns:1fr}}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px;align-items:stretch}
.step{position:relative;display:flex;flex-direction:column;border-radius:22px;border:1px solid var(--border);
  background:#fff;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .35s}
.step:hover{transform:translateY(-5px);border-color:var(--accent-line);
  box-shadow:0 0 0 1px var(--accent-line),0 30px 60px -34px rgba(75,63,212,.42)}
/* selected (auto-rotating or hovered) card — accent ring, no lift so the
   rotation doesn't make cards bob; hover adds the lift on top */
.step.active{border-color:var(--accent-line);box-shadow:0 0 0 1px var(--accent-line),0 22px 48px -36px rgba(75,63,212,.4)}
.step .body{padding:26px 26px 30px;display:flex;flex-direction:column;gap:0;flex:1}
.step .ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:15px;
  transition:transform .45s var(--ease)}
.step:hover .ic{transform:scale(1.06)}
.step .ic svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.step .n{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.06em}
.step h3{font-size:23px;margin:9px 0 9px;line-height:1.15}
.step p{font-size:15px;color:var(--text-2);line-height:1.55}

/* per-step figure — a compact UI mock that visualises each step */
.step-fig{position:relative;height:226px;padding:18px;display:flex;flex-direction:column;gap:8px;justify-content:center;
  background:linear-gradient(180deg,var(--surface-2) 0%,#fff 100%);border-bottom:1px solid var(--border);overflow:hidden}
.step-fig::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%,rgba(75,63,212,.06),transparent 60%);opacity:0;transition:opacity .45s var(--ease)}
.step:hover .step-fig::after,.step.active .step-fig::after{opacity:1}
.step-fig .tag{position:absolute;top:13px;right:14px;z-index:2;font-family:var(--mono);font-size:10.5px;letter-spacing:.02em;color:var(--accent);
  background:rgba(255,255,255,.92);border:1px solid var(--accent-line);border-radius:99px;padding:4px 10px;display:flex;align-items:center;gap:6px}
.step-fig .tag i{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:pulse 1.8s var(--ease) infinite}

/* fig 1 — a 5-min brief: a question, then the captured brief, then confirmation */
.fig-chat{gap:9px}
.step-fig .fb{position:relative;max-width:92%;padding:9px 13px;border-radius:14px;font-size:12px;line-height:1.45;
  box-shadow:0 10px 20px -14px rgba(22,21,20,.5)}
.step-fig .fb.ai{align-self:flex-start;background:#fff;border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text)}
.fig-chat .brief{align-self:stretch;background:#fff;border:1px solid var(--border);border-radius:13px;padding:11px 12px;
  box-shadow:0 10px 22px -16px rgba(22,21,20,.5)}
.fig-chat .brief-role{font-weight:500;font-size:12.5px;color:var(--text-strong);margin-bottom:8px}
.fig-chat .brief-row{display:flex;align-items:baseline;gap:9px;font-size:11px;line-height:1.35}
.fig-chat .brief-row+.brief-row{margin-top:6px}
.fig-chat .brief-k{flex:none;width:56px;font-family:var(--mono);font-size:8.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.fig-chat .brief-k.flex{color:var(--text-3)}
.fig-chat .brief-v{color:var(--text-2)}
/* Idle cards rest in their finished state. Only the selected card — .step.active,
   which JS sets as the rotation lands on it (or on hover) — replays its build. */
.step.active .fig-chat .fb.ai{animation:fadeUp1 3.2s var(--ease) infinite}
.step.active .fig-chat .brief{animation:fadeUp2 3.2s var(--ease) infinite}

/* fig 3 — calendar rows (avatar/meta classes also shared with fig-search head) */
.step-fig .frow{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:8px 11px;box-shadow:0 9px 20px -16px rgba(22,21,20,.55);transition:border-color .3s,transform .3s var(--ease)}
.step:hover .step-fig .frow{transform:translateX(2px)}
.step-fig .fav{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:600;font-family:var(--display)}
.step-fig .fmeta{flex:1;min-width:0}
.step-fig .fmeta .fn{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-strong);line-height:1.25}
.step-fig .fmeta .fr{font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* fig 2 — a search/screening funnel: each stage narrows, conversion % between,
   final stage highlighted. */
.fig-search{justify-content:center}
.fig-search .fnl{display:flex;flex-direction:column;align-items:center;width:100%}
.fig-search .fstep{width:var(--w)}
.fig-search .fbar{display:flex;align-items:center;justify-content:space-between;gap:8px;height:26px;box-sizing:border-box;line-height:1;
  background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:8px;padding:0 11px}
.fig-search .fbar span{font-size:11px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fig-search .fbar b{flex:none;font-family:var(--display);font-size:13.5px;letter-spacing:-.01em;color:var(--text-strong);font-variant-numeric:tabular-nums}
.fig-search .fbar.hot{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;box-shadow:0 8px 18px -10px rgba(75,63,212,.6)}
.fig-search .fbar.hot span{color:rgba(255,255,255,.9)}
.fig-search .fbar.hot b{color:#fff}
.fig-search .fcv{font-family:var(--mono);font-size:8.5px;letter-spacing:.02em;color:var(--text-3);padding:2.5px 0}
/* funnel builds top-to-bottom while the card is selected */
.step.active .fig-search .fstep,.step.active .fig-search .fcv{animation:fadeUp1 3.2s var(--ease) infinite backwards}
.step.active .fig-search .fnl>:nth-child(2){animation-delay:.12s}
.step.active .fig-search .fnl>:nth-child(3){animation-delay:.22s}
.step.active .fig-search .fnl>:nth-child(4){animation-delay:.34s}
.step.active .fig-search .fnl>:nth-child(5){animation-delay:.44s}
.step.active .fig-search .fnl>:nth-child(6){animation-delay:.56s}
.step.active .fig-search .fnl>:nth-child(7){animation-delay:.66s}
.step-fig .fday{flex:none;width:38px;height:42px;border-radius:10px;background:var(--accent-soft);border:1px solid var(--accent-line);
  display:grid;place-content:center;justify-items:center;gap:1px;line-height:1}
.step-fig .fday b{font-family:var(--display);font-weight:500;font-size:16px;color:var(--accent)}
.step-fig .fday span{font-family:var(--mono);font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent)}
.step-fig .fchk{flex:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#34a853,#2f8f6a);display:grid;place-items:center}
.step-fig .fchk svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
/* fig 3 — bookings land on the calendar, each check draws; same fade-up rhythm */
.fig-cal{gap:9px}
.fig-cal .fchk svg path{stroke-dasharray:26;stroke-dashoffset:0}
.step.active .fig-cal .frow:nth-child(2){animation:fadeUp1 3.2s var(--ease) infinite}
.step.active .fig-cal .frow:nth-child(3){animation:fadeUp2 3.2s var(--ease) infinite}
.step.active .fig-cal .frow:nth-child(2) .fchk svg path{animation:calDraw 3.2s var(--ease) infinite}
.step.active .fig-cal .frow:nth-child(3) .fchk svg path{animation:calDraw 3.2s var(--ease) .2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.82)}}
/* shared staggered fade-up — every figure builds its three layers in this rhythm
   while its card is selected: layer 1 → layer 2 → layer 3, hold, brief fade-out */
@keyframes fadeUp1{0%{opacity:0;transform:translateY(7px)}9%,88%{opacity:1;transform:none}96%,100%{opacity:0;transform:translateY(-4px)}}
@keyframes fadeUp2{0%,22%{opacity:0;transform:translateY(7px)}32%,88%{opacity:1;transform:none}96%,100%{opacity:0;transform:translateY(-4px)}}
@keyframes calDraw{0%,30%{stroke-dashoffset:26}46%,88%{stroke-dashoffset:0}96%,100%{stroke-dashoffset:26}}
@media(max-width:880px){.steps{grid-template-columns:1fr;gap:14px}}

/* chat bubbles — used by the hero demo stage-0 brief */
.bub{max-width:82%;padding:11px 15px;border-radius:16px;font-size:14.5px;line-height:1.5}
.bub.ai{align-self:flex-start;background:var(--surface-3);border-bottom-left-radius:5px;color:var(--text)}
.bub.me{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:5px}

/* comparison */
.cmp-scroll{margin-top:48px;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:24px}
.cmp{width:100%;min-width:740px;border:1px solid var(--border);border-radius:24px;overflow:hidden;background:var(--surface)}
.cmp-row{display:grid;grid-template-columns:1.5fr 1.18fr 1fr 1fr}
.cmp-row+.cmp-row{border-top:1px solid var(--border)}
.cmp-cell{padding:18px 22px;font-size:14.5px;color:var(--text-2);display:flex;align-items:flex-start;gap:11px;line-height:1.4}
.cmp-cell.lbl{font-weight:500;color:var(--text-strong)}
.col-metix{background:var(--accent-soft);color:var(--text);font-weight:500}
.cmp-head .cmp-cell{padding:22px;font-family:var(--display);font-size:20px;color:var(--text-strong);align-items:center}
.cmp-head .col-metix{background:var(--accent);color:#fff}
.cmp-head .lbl{color:var(--text-3);font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase}
.ic2{flex:none;width:19px;height:19px;border-radius:50%;position:relative;margin-top:1px}
.ic2.yes{background:#1B9E59}
.ic2.yes::after{content:"";position:absolute;left:6px;top:4px;width:5px;height:9px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(40deg)}
.ic2.no{background:#ECD7D3}
.ic2.no::before,.ic2.no::after{content:"";position:absolute;left:8.5px;top:5px;width:2px;height:9px;background:#BC5446;border-radius:2px}
.ic2.no::before{transform:rotate(45deg)}.ic2.no::after{transform:rotate(-45deg)}
.ic2.mid{background:#F1E4C6}
.ic2.mid::after{content:"";position:absolute;left:4.5px;top:8.5px;width:10px;height:2px;background:#A87A1E;border-radius:2px}
.legend{text-align:center;margin-top:20px;font-size:14px;color:var(--text-3);display:flex;gap:22px;flex-wrap:wrap;justify-content:center}
.legend span{display:inline-flex;align-items:center;gap:8px}
.legend .ic2{transform:scale(.84)}
@media(max-width:760px){.cmp-cell{font-size:13.5px;padding:15px 16px}.cmp-head .cmp-cell{font-size:17px}}

/* dark teaser / cta cards */
.darkcard{position:relative;max-width:820px;margin:42px auto 0;background:var(--inverse);color:#fff;border-radius:28px;
  padding:60px 48px;overflow:hidden;text-align:center}
.darkcard .glow{position:absolute;top:-120px;right:-60px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,107,240,.42),transparent 66%);filter:blur(10px)}
.darkcard h2{position:relative;color:#fff;font-size:clamp(30px,4.4vw,46px);margin-bottom:14px}
.darkcard p{position:relative;color:var(--text-inv-2);max-width:48ch;margin:0 auto 26px;font-size:16.5px}
.darkcard .hint{position:relative;font-family:var(--display);font-size:18px;color:var(--accent-2);margin-top:18px}

/* final */
.final{position:relative;text-align:center;padding:130px 0;overflow:hidden}
.final h2{font-size:clamp(40px,7vw,80px);letter-spacing:-.03em;line-height:1.05;margin-bottom:18px}
.final p{font-size:19px;color:var(--text-2);margin-bottom:30px}
.glow-c{position:absolute;left:50%;width:760px;height:480px;transform:translateX(-50%);z-index:0;pointer-events:none;
  background:radial-gradient(50% 50% at 50% 50%,rgba(124,107,240,.18),transparent 70%);filter:blur(20px)}
.glow-top{top:-160px}.glow-bot{bottom:-200px}
.final .wrap{position:relative;z-index:1}

/* footer */
footer{position:relative;background:var(--inverse);color:var(--text-inv-2);overflow:hidden;isolation:isolate}
.foot-mark{position:relative;width:min(100% - 48px,var(--maxw));margin:44px auto 48px;aspect-ratio:1344/300;pointer-events:none;user-select:none;opacity:.8}
.foot-mark canvas{position:absolute;inset:0;width:100%;height:100%}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px}
@media(min-width:768px){.foot-inner{padding:0 40px}}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px;padding:64px 0 44px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:23px;color:#fff;letter-spacing:-.03em}
.foot-brand img{height:28px;width:auto;display:block}
.foot-tag{max-width:34ch;margin-top:14px;color:var(--text-inv-2);font-size:14.5px;line-height:1.5}
.foot-cols{display:flex;gap:clamp(56px,7vw,104px);flex-wrap:wrap}
.foot-col h4{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:16px;font-weight:500}
.foot-col a{display:block;color:var(--text-inv-2);margin-bottom:11px;font-size:14.5px;transition:color .18s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:26px 0 4px;color:rgba(255,255,255,.56);font-size:13.5px}
@media(max-width:600px){
  .foot-top{gap:30px;padding:52px 0 38px}
  .foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px 40px;width:100%}
  .foot-mark{margin:30px auto 36px}
}

/* ---------------- pricing page ---------------- */
.phead{position:relative;text-align:center;padding:72px 0 0;overflow:hidden}
.phead h1{font-size:clamp(40px,6.2vw,76px);letter-spacing:-.03em;line-height:1.06;max-width:17ch;margin:0 auto;
  display:flex;flex-direction:column;align-items:center}
.phead .lead{margin:24px auto 0}
.credit{max-width:680px;margin:46px auto 0;background:var(--accent-soft);border:1px solid var(--accent-line);
  border-radius:20px;padding:26px 30px;text-align:center}
.credit b{font-family:var(--display);font-weight:400;font-size:21px;color:var(--text-strong)}
.credit span{display:block;color:var(--text-2);font-size:15.5px;margin-top:8px}
.toggle{display:flex;justify-content:center;align-items:center;gap:14px;margin:44px 0 6px;font-size:15px}
.switch{position:relative;width:54px;height:30px;background:var(--inverse);border:0;padding:0;appearance:none;-webkit-appearance:none;border-radius:999px;cursor:pointer}
.switch:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.switch .knob{position:absolute;top:3px;left:3px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .3s var(--ease)}
.switch.on .knob{transform:translateX(24px)}
.toggle .lbl{color:var(--text-3);cursor:pointer;user-select:none;transition:color .2s}.toggle .lbl.active{color:var(--text-strong);font-weight:500}
.save{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);padding:5px 10px;border-radius:999px}
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:28px 0 18px}
.tier{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:30px 26px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .3s}
.tier:hover{transform:translateY(-5px);box-shadow:0 24px 50px -30px rgba(40,30,90,.32);border-color:var(--border-2)}
.tier.feat{border-color:var(--accent);box-shadow:0 20px 44px -28px rgba(75,63,212,.5)}
.tier .tag{height:20px;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.tier .name{font-family:var(--display);font-weight:400;font-size:24px;line-height:1.2;margin:0;color:var(--text-strong)}
.tier .price{font-family:var(--display);font-size:46px;line-height:1;margin:12px 0 2px;letter-spacing:-.03em;color:var(--text-strong);font-variant-numeric:tabular-nums}
.tier .price small{font-family:var(--sans);font-size:14px;color:var(--text-3);font-weight:450}
.tier .desc{font-size:14.5px;color:var(--text-2);min-height:46px;margin-top:6px}
.tier .cta{margin:18px 0}
.tier .cta .btn{width:100%;justify-content:center}
.tier ul{list-style:none;border-top:1px solid var(--border);padding-top:18px;display:flex;flex-direction:column;gap:11px}
.tier li{font-size:14.5px;color:var(--text-2);display:flex;gap:10px;align-items:flex-start;line-height:1.4}
.tier li::before{content:"";flex:none;margin-top:6px;width:14px;height:9px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
@media(max-width:980px){.tiers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.tiers{grid-template-columns:1fr}}
.ent{position:relative;max-width:920px;margin:22px auto 0;background:var(--inverse);color:#fff;border-radius:24px;
  padding:44px 48px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;overflow:hidden}
.ent .glow{position:absolute;top:-80px;right:-40px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(124,107,240,.4),transparent 65%);filter:blur(8px)}
.ent h3{position:relative;font-size:28px;color:#fff}
.ent p{position:relative;color:var(--text-inv-2);max-width:42ch;margin-top:8px;font-size:15.5px}
.ent .act{position:relative}
.faq h2{font-size:clamp(30px,4.2vw,46px);margin-bottom:34px}
.qa{border-top:1px solid var(--border)}
.qa details{border-bottom:1px solid var(--border)}
.qa summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--display);font-size:20px;color:var(--text-strong);transition:color .2s}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--accent)}
.qa summary .ic{flex:none;width:22px;height:22px;position:relative;transition:transform .3s var(--ease)}
.qa summary .ic::before,.qa summary .ic::after{content:"";position:absolute;background:var(--accent);border-radius:2px}
.qa summary .ic::before{top:10px;left:0;width:22px;height:2px}
.qa summary .ic::after{top:0;left:10px;width:2px;height:22px;transition:transform .3s var(--ease)}
.qa details[open] summary .ic::after{transform:rotate(90deg)}
.qa .ans{padding:0 0 24px;color:var(--text-2);font-size:16px;max-width:66ch}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important}
  .reveal{opacity:1;filter:none;transform:none;transition:none}
  /* force animation-gated content into its final visible state */
  .stage .drow,.chips .chip,.brief-ok,.step-fig .fb,
  .surf-avs .sav,.surf-cap,.surf-lead,.stage[data-s="3"] .ev,
  .fig-cal .frow,.fig-cal .fchk{opacity:1!important;transform:none!important}
  .fig-cal .fchk svg path{stroke-dashoffset:0!important}
  .stage[data-s="0"] .caret{display:none}
  html{scroll-behavior:auto}
}

/* ================= content pages (about / security / contact / research) ================= */
.pbody h2{font-size:clamp(27px,3.6vw,40px);letter-spacing:-.025em;line-height:1.12;color:var(--text-strong)}
.pbody .lead{margin-top:14px}
.pintro{max-width:62ch}
.prose{max-width:68ch;color:var(--text-2);font-size:17px;line-height:1.65}
.prose h2{margin-bottom:14px}
.prose p{margin-top:16px}
.prose p:first-of-type{margin-top:20px}
.prose b,.prose strong{color:var(--text-strong);font-weight:600}
.prose a:not(.btn){color:var(--accent);border-bottom:1px solid var(--accent-line);transition:border-color .18s}
.prose a:not(.btn):hover{border-color:var(--accent)}
.prose ul{list-style:none;margin:20px 0 0;display:flex;flex-direction:column;gap:13px}
.prose li{position:relative;padding-left:26px;line-height:1.5}
.prose li::before{content:"";position:absolute;left:0;top:7px;width:13px;height:8px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
.prose .btn{border-bottom:none}

/* numbered flow (about: brief → search → engage → book) */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.flow .fstep{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px 24px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.flow .fstep:hover{transform:translateY(-4px);box-shadow:0 22px 46px -30px rgba(40,30,90,.3);border-color:var(--border-2)}
.flow .fn{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--accent)}
.flow .ft{font-family:var(--display);font-size:21px;color:var(--text-strong);margin:14px 0 8px}
.flow .fd{font-size:14.5px;color:var(--text-2);line-height:1.5}

/* tag rows / award chips */
.tagrow{display:flex;flex-wrap:wrap;gap:10px}
.tagrow .tg{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text);
  background:var(--surface);border:1px solid var(--border-2);border-radius:999px;padding:9px 16px}
.tagrow .tg b{color:var(--accent);font-weight:700;font-family:var(--display)}
.tagrow .tg.soft{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent)}

/* leadership grid */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.team .m{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px 24px}
.team .m .av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--display);
  font-size:18px;font-weight:500;background:linear-gradient(135deg,var(--accent),var(--accent-2));margin-bottom:16px}
.team .m .nm{font-family:var(--display);font-size:20px;color:var(--text-strong)}
.team .m .role{font-size:14px;color:var(--text-3);margin-top:4px}

/* metric grid (research) */
.metricgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.metricgrid .metric{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px 24px}
.metricgrid .n{font-family:var(--display);font-size:46px;line-height:1;letter-spacing:-.03em;color:var(--text-strong);font-variant-numeric:tabular-nums}
.metricgrid .n .u{font-size:24px;color:var(--accent);margin-left:1px}
.metricgrid .l{font-size:14px;color:var(--text-2);line-height:1.45;margin-top:12px}
.metricgrid .vs{font-family:var(--mono);font-size:11.5px;letter-spacing:.02em;color:var(--text-3);margin-top:8px}

/* info / contact cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px 24px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:0 22px 46px -30px rgba(40,30,90,.3);border-color:var(--border-2)}
.card .ck{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.card h3{font-family:var(--display);font-size:20px;color:var(--text-strong);margin:12px 0 8px}
.card p{font-size:14.5px;color:var(--text-2);line-height:1.5}
.card .lk{margin-top:auto;padding-top:16px;font-size:14.5px;color:var(--accent);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.card .lk .arr{transition:transform .2s var(--ease)}
.card:hover .lk .arr{transform:translateX(3px)}

/* security feature list */
.featgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:24px}
.feat .ic{width:38px;height:38px;border-radius:11px;background:var(--accent-soft);border:1px solid var(--accent-line);
  display:grid;place-items:center;margin-bottom:14px}
.feat .ic svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.feat h3{font-family:var(--display);font-size:18px;color:var(--text-strong);margin-bottom:7px}
.feat p{font-size:14.5px;color:var(--text-2);line-height:1.5}

@media(max-width:900px){
  .flow,.metricgrid,.cards{grid-template-columns:repeat(2,1fr)}
  .team{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .flow,.metricgrid,.cards,.team,.featgrid{grid-template-columns:1fr}
}

/* ---------------- footer: address, socials, award ---------------- */
.foot-addr{margin-top:14px;color:var(--text-inv-2);font-size:13.5px;line-height:1.55;font-style:normal;max-width:34ch}
.foot-social{display:flex;gap:10px;margin-top:20px}
.foot-social a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  display:grid;place-items:center;color:rgba(255,255,255,.66);
  transition:color .18s,border-color .18s,transform .2s var(--ease)}
.foot-social a:hover{color:#fff;border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.foot-social svg{width:17px;height:17px;display:block}
.foot-award{margin-top:24px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.foot-award img{width:150px;height:auto;mix-blend-mode:lighten;opacity:.9}
.foot-col .nolink{display:block;color:var(--text-inv-2);margin-bottom:11px;font-size:14.5px}

/* ---------------- research papers ---------------- */
.papers{display:flex;flex-direction:column;gap:18px;margin-top:34px}
.paper{display:block;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:30px 32px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.paper:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(40,30,90,.32);border-color:var(--border-2)}
.paper .ptype{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.paper .ptype .dt{font-family:var(--sans);letter-spacing:0;text-transform:none;color:var(--text-3)}
.paper h3{font-family:var(--display);font-size:23px;line-height:1.22;color:var(--text-strong);margin:14px 0 10px}
.paper .pauth{font-size:14px;color:var(--text-3);margin-bottom:14px}
.paper .pdesc{font-size:15.5px;color:var(--text-2);line-height:1.55;max-width:72ch}
.paper .pkey{margin-top:16px;background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:12px;
  padding:12px 16px;font-size:14px;color:var(--text);line-height:1.5}
.paper .pkey b{font-family:var(--display);font-weight:400;color:var(--accent)}
.paper .pmore{margin-top:18px;display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:500;font-size:15px}
.paper .pmore .arr{transition:transform .2s var(--ease)}
.paper:hover .pmore .arr{transform:translateX(3px)}

/* paper detail */
.paper-meta{display:flex;flex-wrap:wrap;gap:10px 18px;margin:22px auto 0;justify-content:center;
  font-size:14.5px;color:var(--text-3)}
.paper-meta .pm{display:inline-flex;align-items:center;gap:7px}
.paper-meta .pm b{color:var(--text-2);font-weight:500}
.paper-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:30px}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:var(--text-3);margin-bottom:8px}
.back-link:hover{color:var(--accent)}
.back-link .ar{transition:transform .2s var(--ease)}
.back-link:hover .ar{transform:translateX(-3px)}
.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.result-grid .rc{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:24px}
.result-grid .rc .rn{font-family:var(--display);font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--text-strong);font-variant-numeric:tabular-nums}
.result-grid .rc .rn .from{font-size:18px;color:var(--text-3)}
.result-grid .rc .rl{font-size:13.5px;color:var(--text-2);margin-top:10px;line-height:1.45}
@media(max-width:760px){.result-grid{grid-template-columns:1fr}}

/* ---------------- top announcement banner ---------------- */
.banner{position:relative;z-index:70;background:var(--inverse);color:var(--text-inv-2);
  display:flex;align-items:center;justify-content:center;min-height:42px;padding:8px 46px;
  font-size:13.5px;line-height:1.4;text-align:center;border-bottom:1px solid rgba(255,255,255,.08)}
.banner-link{display:inline-flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:center;color:inherit}
.banner-dot{flex:none;width:7px;height:7px;border-radius:50%;
  background:linear-gradient(135deg,#5b54ef,#0defc8);box-shadow:0 0 0 3px rgba(124,107,240,.18)}
.banner-link b{color:#fff;font-weight:500}
.banner-msg{color:var(--text-inv-2)}
.banner-cta{display:inline-flex;align-items:center;gap:5px;color:#a89dff;font-weight:500}
.banner-cta .arr{transition:transform .2s var(--ease)}
.banner-link:hover .banner-cta{color:#c2b9ff}
.banner-link:hover .banner-cta .arr{transform:translateX(3px)}
.banner-x{position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;display:grid;place-items:center;border:0;border-radius:7px;
  background:transparent;color:var(--text-inv-2);font-size:19px;line-height:1;cursor:pointer;
  transition:color .15s,background .15s}
.banner-x:hover{color:#fff;background:rgba(255,255,255,.1)}
@media(max-width:680px){
  .banner{font-size:12.5px;padding:8px 40px}
  .banner-msg{display:none}
}

/* article/blog logo showcase — soft grey decorative panel */
.logo-showcase{margin:46px auto 0;background:var(--surface-3);border:1px solid var(--border);
  border-radius:24px;padding:clamp(52px,9vw,92px) 32px;display:grid;place-items:center}
.logo-showcase img{height:clamp(34px,4.6vw,46px);width:auto}

/* ---------------- blog comparison table ---------------- */
.cmp-wrap{overflow-x:auto;margin:30px 0;border:1px solid var(--border);border-radius:16px}
.cmp-table{width:100%;border-collapse:collapse;font-size:15px;min-width:560px}
.cmp-table th,.cmp-table td{text-align:left;padding:15px 18px;vertical-align:top;line-height:1.45;border-bottom:1px solid var(--border)}
.cmp-table tbody tr:last-child th,.cmp-table tbody tr:last-child td{border-bottom:0}
.cmp-table thead th{font-family:var(--display);font-weight:400;font-size:15.5px;color:var(--text-strong);border-bottom:1px solid var(--border-2)}
.cmp-table thead th:first-child{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:500}
.cmp-table tbody th{font-weight:500;color:var(--text-strong);width:26%}
.cmp-table td{color:var(--text-2)}
.cmp-table th:nth-child(2),.cmp-table td:nth-child(2){background:var(--accent-soft)}
.cmp-table thead th:nth-child(2){color:var(--accent)}
@media(max-width:640px){.cmp-table th,.cmp-table td{padding:11px 13px;font-size:13.5px}}
