/* =========================================================
   4 STEP AI - flagship site
   Design system: dark, premium, "operator" aesthetic
   Brand: electric blue #2E35FF + Stellar Pro (from brand kit)
   ========================================================= */

@font-face{
  font-family:"Stellar Pro";
  src:url("assets/fonts/StellarPro-Medium.woff2") format("woff2"),
      url("assets/fonts/StellarPro-Medium.woff") format("woff");
  font-weight:500;font-style:normal;font-display:swap;
}

:root{
  --font-brand:    "Stellar Pro", "Space Grotesk", system-ui, sans-serif;
  --bg:            #06070B;
  --bg-2:          #0A0C13;
  --surface:       #10131C;
  --surface-2:     #161A25;
  --text:          #ECEEF5;
  --muted:         #8B90A3;
  --muted-2:       #878CA0;
  --line:          rgba(255,255,255,.08);
  --line-2:        rgba(255,255,255,.14);

  --violet:        #2E35FF;
  --violet-soft:   #7A80FF;
  --mint:          #5D8BFF;
  --amber:         #FFB86B;

  --grad:          linear-gradient(115deg,#2E35FF 0%,#7A80FF 40%,#5D8BFF 100%);
  --grad-text:     linear-gradient(100deg,#fff 0%,#c3c6ff 55%,#9db8ff 100%);

  --font-display:  "Space Grotesk", system-ui, sans-serif;
  --font-body:     "Inter", system-ui, sans-serif;
  --font-serif:    "Instrument Serif", Georgia, serif;

  --maxw:          1200px;
  --pad:           clamp(20px, 5vw, 72px);
  --radius:        18px;
  --ease:          cubic-bezier(.16,1,.3,1);
  --ease-in-out:   cubic-bezier(.7,0,.2,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
em{font-family:var(--font-serif);font-style:italic;font-weight:400}
mark{color:#fff;background:linear-gradient(transparent 58%, rgba(46,53,255,.55) 58%);padding:0 .08em;border-radius:2px}
::selection{background:var(--violet);color:#fff}

/* ---------- grain + progress ---------- */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:100;background:transparent}
.scroll-progress span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 12px rgba(46,53,255,.6)}

/* ---------- buttons ---------- */
.btn{
  --h:52px;
  display:inline-flex;align-items:center;gap:.55em;
  height:var(--h);padding:0 24px;border-radius:100px;
  font-family:var(--font-display);font-weight:500;font-size:.95rem;letter-spacing:-.01em;
  cursor:pointer;border:1px solid transparent;white-space:nowrap;
  transition:transform .5s var(--ease), background .3s, border-color .3s, color .3s;
}
.btn svg{transition:transform .4s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--sm{--h:42px;padding:0 18px;font-size:.85rem}
.btn--lg{--h:58px;padding:0 30px;font-size:1.02rem}
.btn--primary{background:var(--text);color:#0a0a0f}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 34px -10px rgba(122,128,255,.55)}
.btn--ghost{background:rgba(255,255,255,.03);border-color:var(--line-2);color:var(--text)}
.btn--ghost:hover{background:rgba(255,255,255,.07);transform:translateY(-2px)}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:padding .4s var(--ease), background .4s, border-color .4s, backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding:12px var(--pad);
  background:rgba(6,7,11,.72);
  backdrop-filter:blur(16px) saturate(160%);
  border-bottom:1px solid var(--line);
}
.nav__brand{display:flex;align-items:center}
.nav__logo{height:24px;width:auto;display:block}
.nav__links{display:flex;gap:30px}
.nav__links a{font-size:.92rem;color:var(--muted);position:relative;transition:color .3s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--text);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--text)}
.nav__links a:hover::after{width:100%}
.nav__cta{background:var(--text);color:#0a0a0f}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 10px 26px -10px rgba(122,128,255,.5)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:22px;height:2px;background:var(--text);transition:.3s var(--ease)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;
  padding:120px var(--pad) 60px;
  overflow:hidden;isolation:isolate;
}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:-2;opacity:.9}
.hero__glow{
  position:absolute;z-index:-1;top:-10%;left:50%;transform:translateX(-50%);
  width:min(900px,90vw);height:600px;pointer-events:none;
  background:radial-gradient(closest-side,rgba(46,53,255,.28),transparent 70%);
  filter:blur(20px);
}
.hero__inner{max-width:var(--maxw);width:100%;margin:0 auto}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border:1px solid var(--line-2);border-radius:100px;
  font-size:.82rem;color:var(--muted);margin-bottom:30px;
  background:rgba(255,255,255,.02);
}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 0 rgba(93,139,255,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(93,139,255,.5)}70%{box-shadow:0 0 0 10px rgba(93,139,255,0)}100%{box-shadow:0 0 0 0 rgba(93,139,255,0)}}

.hero__title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.7rem,8vw,6.4rem);line-height:.98;letter-spacing:-.035em;
  margin-bottom:34px;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:block;will-change:transform}
.hero__title em{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__sub{max-width:620px;font-size:clamp(1.02rem,2vw,1.22rem);color:var(--muted);margin-bottom:38px}
.hero__sub strong{color:var(--text);font-weight:500}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:58px}

.hero__marquee{max-width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee{overflow:hidden}
.marquee__track{display:flex;gap:18px;width:max-content;animation:marq 26s linear infinite;color:var(--muted-2);font-family:var(--font-display);font-size:.9rem}
.marquee__track span{white-space:nowrap}
@keyframes marq{to{transform:translateX(-50%)}}

.hero__scrollcue{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);
}
.hero__scrollcue svg{animation:bob 1.8s var(--ease-in-out) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* =========================================================
   INTRO / MANIFESTO
   ========================================================= */
.intro{max-width:1080px;margin:0 auto;padding:clamp(90px,14vw,180px) var(--pad)}
.intro__text{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.9rem,5vw,3.8rem);line-height:1.14;letter-spacing:-.025em;
  max-width:900px;
}
.intro__sub{max-width:620px;margin-top:26px;color:var(--muted);font-size:clamp(1rem,1.8vw,1.18rem)}
/* mark styling: global marker-highlight (clip-to-text breaks with word-span animation) */
.reveal-words .word{display:inline-block;will-change:transform,opacity}
.intro__meta{display:flex;gap:28px;flex-wrap:wrap;margin-top:44px;color:var(--muted-2);font-size:.86rem;font-family:var(--font-display)}
.intro__meta span{padding-left:16px;border-left:1px solid var(--line-2)}

/* =========================================================
   SECTION HEADERS (shared)
   ========================================================= */
.section-head{max-width:var(--maxw);margin:0 auto clamp(48px,7vw,80px)}
.section-head--center{text-align:center}
.section-head--center .section-lead{margin-inline:auto}
.section-kicker{font-family:var(--font-display);font-size:.8rem;letter-spacing:.06em;color:var(--violet-soft);text-transform:uppercase}
.section-title{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,5vw,3.6rem);line-height:1.02;letter-spacing:-.03em;margin:16px 0 20px}
.section-title em{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-lead{max-width:560px;color:var(--muted);font-size:clamp(1rem,1.6vw,1.14rem)}

/* =========================================================
   SERVICES BENTO
   ========================================================= */
.services{padding:clamp(40px,6vw,60px) var(--pad) clamp(80px,10vw,120px)}
.services .section-head{margin-left:0}
.bento{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  grid-auto-flow:dense;
}
.bento__card{
  position:relative;padding:26px;border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .6s var(--ease), border-color .4s, background .4s;
  transform-style:preserve-3d;
}
.bento__card--tall{grid-row:span 2}
.bento__card--tall .bento__tag{margin-top:auto}
.bento__card::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .5s;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,0%),rgba(46,53,255,.14),transparent 60%);
}
.bento__card:hover{border-color:var(--line-2);transform:translateY(-4px)}
.bento__card:hover::before{opacity:1}
.bento__card[data-accent="mint"]:hover{border-color:rgba(93,139,255,.4)}
.bento__card[data-accent="amber"]:hover{border-color:rgba(255,184,107,.4)}
.bento__icon{font-size:1.6rem;margin-bottom:14px;filter:saturate(1.2)}
.bento__card h3{font-family:var(--font-display);font-weight:600;font-size:1.22rem;letter-spacing:-.02em;margin:0 0 8px}
.bento__card p{color:var(--muted);font-size:.95rem;line-height:1.5}
.bento__tag{margin-top:16px;font-size:.78rem;color:var(--muted-2);font-family:var(--font-display);letter-spacing:.02em}

/* =========================================================
   PROCESS - pinned
   ========================================================= */
.process{position:relative}
.process__sticky{padding:clamp(70px,9vw,120px) var(--pad)}
.process__head{max-width:var(--maxw);margin:0 auto clamp(40px,6vw,70px)}
.process__stage{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:start;
}
.process__list{list-style:none;display:flex;flex-direction:column;gap:18px}
.process__item{
  display:flex;gap:20px;padding:24px;border-radius:16px;
  border:1px solid var(--line);background:var(--surface);
  opacity:.8;transform:translateY(0);
  transition:opacity .5s var(--ease), border-color .5s, background .5s, transform .5s;
}
.process__item.is-active{opacity:1;border-color:var(--line-2);background:linear-gradient(180deg,var(--surface-2),var(--surface))}
.process__num{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--violet-soft);flex:none}
.process__item h3{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;margin-bottom:6px}
.process__item p{color:var(--muted);font-size:.96rem}

.process__viz{
  position:sticky;top:110px;aspect-ratio:1;border-radius:22px;overflow:hidden;
  border:1px solid var(--line);background:radial-gradient(circle at 50% 40%,var(--surface),var(--bg));
}
.process__viz canvas{width:100%;height:100%;display:block}
.process__progresslabel{
  position:absolute;bottom:18px;left:0;right:0;text-align:center;
  font-family:var(--font-display);font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);
}

/* =========================================================
   STATS
   ========================================================= */
.stats{padding:clamp(80px,10vw,130px) var(--pad);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.stats__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{padding:32px 24px;border-radius:16px;border:1px solid var(--line);background:var(--surface);text-align:center}
.stat__num{display:block;font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.03em;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat__label{display:block;margin-top:12px;color:var(--muted);font-size:.9rem;max-width:180px;margin-inline:auto}
.logos{max-width:var(--maxw);margin:56px auto 0;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 34px;opacity:.85}
.logos span{font-family:var(--font-display);font-weight:500;color:var(--muted);font-size:1.05rem;transition:color .3s,opacity .3s}
.logos:hover span{opacity:.4}
.logos span:hover{color:var(--text);opacity:1}

/* =========================================================
   WORK
   ========================================================= */
.work{padding:clamp(80px,10vw,130px) var(--pad)}
.work .section-head{margin-left:0}
.work__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.work__card{
  padding:32px;border-radius:var(--radius);border:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  transition:transform .6s var(--ease),border-color .4s;
}
.work__card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.work__meta{display:flex;justify-content:space-between;color:var(--muted-2);font-size:.8rem;font-family:var(--font-display);letter-spacing:.03em;margin-bottom:18px}
.work__meta span:first-child{color:var(--violet-soft)}
.work__card h3{font-family:var(--font-display);font-weight:600;font-size:1.5rem;letter-spacing:-.02em;margin-bottom:12px}
.work__card p{color:var(--muted);font-size:.98rem}

/* =========================================================
   CTA
   ========================================================= */
.cta{padding:clamp(90px,12vw,160px) var(--pad);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(closest-side at 50% 0%,rgba(46,53,255,.18),transparent 70%)}
.cta__inner{max-width:780px;margin:0 auto;text-align:center}
.cta__title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.2rem,6vw,4.4rem);line-height:1.02;letter-spacing:-.03em;margin-bottom:20px}
.cta__title em{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta__sub{color:var(--muted);font-size:clamp(1rem,2vw,1.2rem);max-width:520px;margin:0 auto 44px}

.cta__form{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left;margin-bottom:30px}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field textarea{
  width:100%;padding:20px 18px 8px;border-radius:12px;
  background:var(--surface);border:1px solid var(--line);color:var(--text);
  font-family:var(--font-body);font-size:1rem;resize:vertical;transition:border-color .3s,background .3s;
}
.field textarea{padding-top:24px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--violet);background:var(--surface-2)}
.field label{position:absolute;left:18px;top:15px;color:var(--muted-2);font-size:1rem;pointer-events:none;transition:.25s var(--ease)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{top:7px;font-size:.72rem;color:var(--violet-soft)}
.cta__form .btn{grid-column:1/-1;justify-self:center}
.cta__direct{display:flex;gap:16px;justify-content:center;align-items:center;color:var(--muted)}
.cta__direct a{color:var(--text);border-bottom:1px solid var(--line-2);padding-bottom:2px;transition:border-color .3s}
.cta__direct a:hover{border-color:var(--violet)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{padding:clamp(50px,7vw,80px) var(--pad) 40px;border-top:1px solid var(--line);background:var(--bg-2)}
.footer__top{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px}
.footer__brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:1.1rem}
.footer__tag{color:var(--muted)}
.footer__links{max-width:var(--maxw);margin:34px auto;display:flex;flex-wrap:wrap;gap:22px}
.footer__links a{color:var(--muted);font-size:.92rem;transition:color .3s}
.footer__links a:hover{color:var(--text)}
.footer__bottom{max-width:var(--maxw);margin:0 auto;padding-top:26px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted-2);font-size:.82rem}

/* =========================================================
   REVEAL (JS-driven base states)
   ========================================================= */
.reveal{opacity:0;transform:translateY(24px)}
.is-in.reveal,.reveal.is-in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .process__stage{grid-template-columns:1fr}
  .process__viz{max-width:440px;margin:0 auto;width:100%}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .work__grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;padding:10px var(--pad) 22px;background:rgba(6,7,11,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
  .nav__links.open a{padding:14px 0;border-bottom:1px solid var(--line)}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{justify-content:center}
  .cta__form{grid-template-columns:1fr}
  .intro__meta span{border-left:0;padding-left:0}
}
@media (max-width:440px){
  .bento{grid-template-columns:1fr}
  .bento__card--tall{grid-row:auto}
  .stats__grid{grid-template-columns:1fr}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero__canvas,.marquee__track{display:none}
}

/* keyboard-only focus ring on form fields (mouse keeps subtle border) */
.field input:focus-visible,.field textarea:focus-visible{outline:2.5px solid var(--violet);outline-offset:2px}

/* =========================================================
   HERO v2 - two columns + chat command-center mock
   ========================================================= */
.hero{flex-direction:column;justify-content:center;gap:44px}
.hero__cols{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4.5vw,64px);align-items:center}
.hero__title{font-size:clamp(2.4rem,5.6vw,4.6rem)}
.hero__marquee{width:100%;max-width:var(--maxw);margin:0 auto}

.hero__chat{display:flex;justify-content:center}
.chat{
  width:min(460px,100%);border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg,rgba(22,26,37,.92),rgba(10,12,19,.92));
  border:1px solid var(--line-2);backdrop-filter:blur(10px);
  box-shadow:0 30px 80px -30px rgba(46,53,255,.45), 0 4px 22px rgba(0,0,0,.5);
}
.chat__bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line)}
.chat__dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.14)}
.chat__title{margin-left:8px;font-family:var(--font-display);font-size:.82rem;color:var(--muted)}
.chat__live{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#7ee2b8}
.chat__live i{width:6px;height:6px;border-radius:50%;background:#7ee2b8;box-shadow:0 0 8px #7ee2b8;animation:pulse 2s infinite}
.chat__body{padding:18px 16px;display:flex;flex-direction:column;gap:10px;min-height:320px}
.msg{max-width:86%;padding:10px 14px;border-radius:14px;font-size:.88rem;line-height:1.45;
  opacity:0;transform:translateY(8px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.msg.in{opacity:1;transform:none}
.msg--user{align-self:flex-end;background:var(--violet);color:#fff;border-bottom-right-radius:4px}
.msg--ai{align-self:flex-start;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--text);border-bottom-left-radius:4px}
.msg--ai b{color:#9db8ff;font-weight:600}
.msg--typing{align-self:flex-start;background:rgba(255,255,255,.06);border:1px solid var(--line);display:flex;gap:4px;padding:13px 16px}
.msg--typing i{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:tybounce 1s infinite}
.msg--typing i:nth-child(2){animation-delay:.15s}
.msg--typing i:nth-child(3){animation-delay:.3s}
@keyframes tybounce{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}

/* process time chips */
.process__time{display:inline-block;margin-left:10px;padding:3px 10px;border-radius:100px;background:rgba(46,53,255,.14);border:1px solid rgba(46,53,255,.35);color:#9db8ff;font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;vertical-align:middle;font-family:var(--font-display)}

/* =========================================================
   TOOL ROWS (labeled categories)
   ========================================================= */
.toolrows{max-width:980px;margin:0 auto clamp(44px,6vw,64px);display:flex;flex-direction:column;gap:14px}
.toolrow{display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:start;
  padding:18px 22px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}
.toolrow__label{font-family:var(--font-display);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#9db8ff;padding-top:5px}
.toolrow__items{display:flex;flex-wrap:wrap;gap:8px}
.toolrow__items span{padding:6px 13px;border-radius:100px;border:1px solid var(--line-2);color:var(--text);font-size:.85rem;background:rgba(255,255,255,.02)}
.toolrow__more{color:var(--muted) !important;border-style:dashed !important}
.stats__grid--tight{margin-top:0}

/* =========================================================
   BEFORE / AFTER
   ========================================================= */
.result{padding:clamp(80px,10vw,130px) var(--pad) 0}
.result .section-head{margin-left:0}
.result__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.result__col{padding:32px;border-radius:var(--radius);border:1px solid var(--line)}
.result__col h3{font-family:var(--font-display);font-weight:600;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:20px}
.result__col ul{list-style:none;display:grid;gap:13px}
.result__col li{position:relative;padding-left:30px;font-size:1rem;line-height:1.5}
.result__col--before{background:var(--surface)}
.result__col--before h3{color:#f08a8a}
.result__col--before li{color:var(--muted)}
.result__col--before li::before{content:"✕";position:absolute;left:0;top:0;color:#f08a8a;font-size:.9rem}
.result__col--after{background:linear-gradient(180deg,rgba(46,53,255,.10),var(--surface));border-color:rgba(46,53,255,.4)}
.result__col--after h3{color:#7ee2b8}
.result__col--after li{color:var(--text)}
.result__col--after li::before{content:"✓";position:absolute;left:0;top:0;color:#7ee2b8;font-size:.95rem}

@media (max-width:980px){
  .hero__cols{grid-template-columns:1fr}
  .hero__chat{order:2}
  .chat__body{min-height:280px}
  .result__grid{grid-template-columns:1fr}
  .toolrow{grid-template-columns:1fr;gap:10px}
}
@media (max-width:720px){
  .hero{gap:28px}
  .process__time{display:block;margin:6px 0 0;width:max-content}
}

/* HARD RULE: inside word-animated blocks (.reveal-words), background-clip:text
   CANNOT work (each word is its own inline-block span, so the clip paints nothing
   and text goes invisible). Use solid accent color there instead. */
.reveal-words em, .reveal-words em .word{
  background:none;-webkit-background-clip:border-box;background-clip:border-box;
  color:#9db8ff;-webkit-text-fill-color:#9db8ff;
}
