/* ============================================================
   INFORADIENT TECHNOLOGIES - Landing page
   Orange / black / white. Type: Hanken Grotesk.
   Font is loaded via <link> in each page head (faster than @import).
   ============================================================ */

:root{
  --ink:#0E0F11;
  --ink-2:#161719;
  --ink-3:#1d1f22;
  --bg:#ffffff;
  --bg-soft:#f4f3f1;
  --bg-cream:#faf9f7;
  --line:#e7e4e0;
  --line-strong:#d6d2cc;
  --line-d:rgba(255,255,255,.10);
  --muted:#6a6a67;
  --muted-d:#a2a29d;

  --accent:#f4511e;
  --accent-2:#ff6a3d;
  --accent-ink:#c8400f;

  --font:'Hanken Grotesk',system-ui,-apple-system,sans-serif;

  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --shadow-sm:0 1px 2px rgba(14,15,17,.05),0 2px 8px rgba(14,15,17,.04);
  --shadow:0 12px 36px rgba(14,15,17,.10);
  --shadow-lg:0 40px 80px -28px rgba(14,15,17,.45);

  --maxw:1180px;
  --pad:24px;
  --sec:clamp(76px,9vw,132px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{font-weight:700;line-height:1.04;letter-spacing:-.028em;margin:0;color:var(--ink);}
p{margin:0;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.section{padding-block:var(--sec);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:15px;letter-spacing:-.01em;
  padding:13px 22px;border-radius:10px;border:1px solid transparent;white-space:nowrap;
  transition:transform .18s,box-shadow .18s,background .18s,color .18s,border-color .18s;
}
.btn .arr{transition:transform .2s;}
.btn:hover .arr{transform:translateX(3px);}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 20px -8px rgba(244,81,30,.6);}
.btn-accent:hover{background:var(--accent-ink);transform:translateY(-2px);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;transform:translateY(-2px);}
.btn-light{background:#fff;color:var(--ink);}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(0,0,0,.4);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--ink);}
.btn-ghost-light{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28);}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.12);}
.btn-lg{padding:16px 28px;font-size:16px;}

/* ---------- eyebrow ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:12.5px;
  letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;
}
.eyebrow .idx{color:var(--ink);opacity:.35;font-variant-numeric:tabular-nums;}
.eyebrow::after{content:"";width:24px;height:1.5px;background:var(--accent);opacity:.5;}
.on-dark .eyebrow{color:var(--accent-2);}
.on-dark .eyebrow .idx{color:#fff;opacity:.4;}
.eyebrow.center{justify-content:center;}

.accent-text{color:var(--accent);}

/* ---------- top bar (bright orange, like reference) ---------- */
.topbar{
  background:var(--accent);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;
  justify-content:center;gap:10px;padding:11px 16px;text-align:center;position:relative;z-index:70;letter-spacing:-.005em;flex-wrap:wrap;line-height:1.3;
}
.topbar b{color:#fff;font-weight:700;}
.topbar a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px;}
.topbar a:hover{opacity:.85;}

/* ---------- nav (transitions over dark hero) ---------- */
.nav{
  position:sticky;top:0;z-index:60;transition:background .3s,box-shadow .3s,border-color .3s;
  border-bottom:1px solid transparent;background:transparent;
}
.nav-inner{display:flex;align-items:center;gap:26px;height:74px;}
.brand{position:relative;display:inline-grid;height:30px;}
.brand img{grid-area:1/1;height:30px;width:auto;transition:opacity .3s;}
.brand .logo-light{opacity:1;}
.brand .logo-dark{opacity:0;}
.nav-links{display:flex;align-items:center;gap:28px;margin-left:12px;}
.nav-links a{font-size:15px;font-weight:500;color:rgba(255,255,255,.82);transition:color .15s;white-space:nowrap;}
.nav-links a:hover{color:#fff;}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:16px;}
.nav-cta .signin{font-weight:600;font-size:15px;color:rgba(255,255,255,.9);}
/* white pill primary in nav, like reference */
.nav-cta .btn-accent{background:#fff;color:var(--ink);box-shadow:none;border-radius:999px;padding:12px 22px;}
.nav-cta .btn-accent:hover{background:#f0efec;transform:translateY(-1px);}
.nav-cta .btn-accent .arr{display:none;}
.nav.scrolled .nav-cta .btn-accent{background:var(--ink);color:#fff;}
.nav.scrolled .nav-cta .btn-accent:hover{background:#000;}
/* scrolled state -> solid white */
.nav.scrolled{background:#fff;border-color:var(--line);box-shadow:var(--shadow-sm);}
.nav.scrolled .brand .logo-light{opacity:0;}
.nav.scrolled .brand .logo-dark{opacity:1;}
.nav.scrolled .nav-links a{color:var(--ink);}
.nav.scrolled .nav-links a:hover{color:var(--accent);}
.nav.scrolled .nav-cta .signin{color:var(--ink);}
.nav-toggle{display:none;margin-left:auto;width:44px;height:44px;border:1px solid rgba(255,255,255,.3);border-radius:11px;background:rgba(255,255,255,.08);align-items:center;justify-content:center;}
.nav.scrolled .nav-toggle{border-color:var(--line-strong);background:#fff;}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{display:block;width:18px;height:2px;background:#fff;position:relative;}
.nav.scrolled .nav-toggle span,.nav.scrolled .nav-toggle span::before,.nav.scrolled .nav-toggle span::after{background:var(--ink);}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;}
.nav-toggle span::before{top:-6px;}.nav-toggle span::after{top:6px;}

/* ---------- mobile menu ---------- */
.mm-backdrop{position:fixed;inset:0;background:rgba(14,15,17,.45);z-index:80;opacity:0;visibility:hidden;transition:.3s;}
.mm-backdrop.open{opacity:1;visibility:visible;}
.mobile-menu{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);z-index:90;background:#fff;
  box-shadow:-20px 0 60px rgba(0,0,0,.18);transform:translateX(100%);
  transition:transform .3s cubic-bezier(.2,.7,.2,1);padding:24px;display:flex;flex-direction:column;
}
.mobile-menu.open{transform:none;}
.mm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.mm-head img{height:28px;width:auto;}
.mm-close{width:42px;height:42px;border:1px solid var(--line);border-radius:11px;background:#fff;font-size:22px;line-height:1;color:var(--ink);}
.mm-links{display:flex;flex-direction:column;}
.mm-links a{font-weight:600;font-size:18px;padding:15px 0;border-bottom:1px solid var(--line);}
.mm-links .btn{margin-top:22px;justify-content:center;}

/* ============================================================
   HERO (dark)
   ============================================================ */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;margin-top:-74px;padding-block:calc(74px + clamp(48px,7vw,96px)) clamp(60px,8vw,110px);}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 40% at 50% -10%,rgba(244,81,30,.22),transparent 62%),
    linear-gradient(180deg,#140f0d 0%,#0c0d0e 40%);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);
  background-position:calc(50% - 560px) 0,calc(50% + 560px) 0;
  background-size:1px 100%,1px 100%;background-repeat:no-repeat;
}
.hero-inner{position:relative;z-index:1;text-align:center;max-width:940px;margin-inline:auto;}
.hero h1{font-size:clamp(44px,7.4vw,88px);font-weight:700;letter-spacing:-.04em;line-height:.98;color:#fff;}
.hero h1 .accent-text{color:var(--accent-2);}
.hero-sub{margin:28px auto 0;font-size:clamp(18px,2.1vw,23px);color:rgba(255,255,255,.62);max-width:600px;line-height:1.45;letter-spacing:-.01em;}
.hero-sub b{color:#fff;font-weight:700;}
.hero-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}
.hero-trust{margin-top:24px;font-size:14px;color:rgba(255,255,255,.5);}

/* ---------- animated hero scene (Melrose-style) ---------- */
.hero-scene{
  position:relative;z-index:1;margin:clamp(40px,6vw,68px) auto 0;max-width:1040px;
  height:clamp(380px,42vw,468px);border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1);
}
.scene-bg{
  position:absolute;inset:0;
  background:linear-gradient(180deg,#aec6df 0%,#d6e0ea 30%,#f3e6cd 54%,#f5cd9e 74%,#3f6b3a 74.4%,#2f5a2c 100%);
}
.scene-bg::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 60% at 50% 120%,rgba(47,90,44,0) 40%,rgba(47,90,44,.55) 74%,rgba(36,72,34,.9) 100%);
}
.scene-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,13,14,0) 60%,rgba(12,13,14,.35) 100%);}
.scene-card{
  position:absolute;background:rgba(255,255,255,.97);border-radius:16px;
  box-shadow:0 24px 60px -18px rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.6);overflow:hidden;
}
/* spinner + status dots */
.sdot{position:relative;width:24px;height:24px;border-radius:50%;border:2px solid #d9d6d0;flex:none;display:grid;place-items:center;background:#fff;transition:.3s;}
.sdot .ck{opacity:0;transform:scale(.5);transition:.25s;}
.sdot .spin{position:absolute;inset:-2px;border-radius:50%;border:2px solid transparent;border-top-color:var(--accent);opacity:0;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.srow.done .sdot{background:var(--accent);border-color:var(--accent);}
.srow.done .sdot .ck{opacity:1;transform:scale(1);}
.srow.active .sdot{border-color:transparent;}
.srow.active .sdot .spin{opacity:1;}
.sdot.active .spin{opacity:1;}

/* Card 1: status */
.card-status{top:16%;left:0;width:min(42%,372px);padding:6px 4px;}
.card-status .srow{display:flex;gap:13px;align-items:center;padding:15px 18px;border-bottom:1px solid #eee;transition:.3s;}
.card-status .srow:last-child{border-bottom:none;}
.card-status .stext .t{font-weight:600;font-size:14.5px;color:#9a9893;transition:.3s;white-space:nowrap;}
.card-status .stext .s{font-size:12.5px;color:#b3b1ac;margin-top:1px;height:0;overflow:hidden;opacity:0;transition:.3s;}
.card-status .srow.active .stext .t{color:var(--accent);}
.card-status .srow.done .stext .t{color:#16181a;}
.card-status .srow.active .stext .s{height:16px;opacity:1;}

/* Card 2: browser */
.card-browser{top:30%;left:42%;width:min(52%,460px);}
.bw-bar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid #eee;background:#fff;}
.bw-nav{color:#bdbbb6;font-size:17px;font-weight:600;line-height:1;}
.bw-url{margin-left:6px;flex:1;background:#f2f1ee;border-radius:999px;height:30px;display:flex;align-items:center;gap:7px;padding:0 13px;font-size:12.5px;color:#3a3a38;font-family:var(--font);min-width:0;}
.bw-url span#typeUrl{white-space:nowrap;overflow:hidden;}
.bw-body{padding:18px 20px;position:relative;}
.bw-id{font-family:ui-monospace,Menlo,monospace;font-size:12px;letter-spacing:.04em;color:#a9a7a2;margin-bottom:12px;}
.bw-line{font-size:15px;color:#16181a;margin-bottom:9px;}
.bw-line b{font-weight:700;}
.bw-line .muted{color:#8a8884;}
.bw-pic{position:absolute;right:18px;top:54px;width:96px;height:74px;border-radius:9px;background:linear-gradient(135deg,#3461a8,#5a86c4);box-shadow:0 6px 16px rgba(0,0,0,.18);}
.bw-tl{margin-top:14px;display:flex;flex-direction:column;gap:11px;}
.bw-tl .tl{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#54524e;}
.bw-tl .tl b{color:#16181a;font-weight:700;margin-left:2px;}
.bw-tl .tic{width:26px;height:26px;border-radius:7px;background:#f2f1ee;display:grid;place-items:center;flex:none;}

/* Card 3: AI typing */
.card-ai{bottom:8%;right:0;width:min(46%,380px);padding:16px 18px;}
.ai-head{display:flex;align-items:center;gap:10px;font-family:ui-monospace,Menlo,monospace;font-size:13px;font-weight:700;letter-spacing:.06em;color:#16181a;padding-bottom:12px;border-bottom:1px solid #eee;margin-bottom:12px;}
.ai-body{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;line-height:1.7;letter-spacing:.03em;text-transform:uppercase;color:#9a9893;min-height:64px;}
.caret{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:-2px;margin-left:1px;animation:blink 1s step-end infinite;}
.caret.mono{height:1.1em;}
@keyframes blink{50%{opacity:0;}}

.scene-card{animation:floaty 7s ease-in-out infinite;}
.card-browser{animation-delay:.6s;}
.card-ai{animation-delay:1.1s;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
@media (prefers-reduced-motion:reduce){.scene-card{animation:none;}.sdot .spin{animation:none;}.caret{animation:none;}}

/* ---------- logos strip ---------- */
/* ---------- logos strip (continuous marquee) ---------- */
.logos{background:var(--ink);border-bottom:1px solid var(--line-d);padding:0;}
.logo-marquee{overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.logo-track{display:flex;align-items:center;width:max-content;animation:marquee 34s linear infinite;}
.logo-marquee:hover .logo-track{animation-play-state:paused;}
@keyframes marquee{to{transform:translateX(-50%);}}
.logo-track .logo-item{
  flex:none;padding:30px clamp(34px,5vw,68px);font-weight:800;font-size:21px;letter-spacing:-.02em;
  color:#b9b9b4;display:flex;align-items:center;gap:10px;opacity:.7;transition:.2s;
  border-left:1px solid var(--line-d);
}
.logo-track .logo-item:hover{opacity:1;color:#fff;}
.logo-track .logo-item .mk{width:22px;height:22px;border-radius:6px;background:currentColor;opacity:.55;}
@media (prefers-reduced-motion:reduce){.logo-track{animation:none;}}

/* ---------- section heading ---------- */
.sec-head{max-width:640px;}
.sec-head.center{margin-inline:auto;text-align:center;}
.sec-head h2{font-size:clamp(31px,4.4vw,50px);letter-spacing:-.032em;}
.sec-head .lede{margin-top:18px;color:var(--muted);font-size:clamp(16px,1.8vw,19px);}
.on-dark .sec-head .lede{color:var(--muted-d);}

/* ============================================================
   PROBLEM (Before / After, dark)
   ============================================================ */
.problem{background:var(--ink);}
.prob-head{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:end;margin-bottom:clamp(40px,5vw,64px);}
.prob-head h2{color:#fff;font-size:clamp(31px,4.4vw,52px);letter-spacing:-.034em;}
.prob-head .eyebrow .idx{display:none;}
.prob-head-r{color:var(--muted-d);font-size:clamp(16px,1.7vw,18.5px);line-height:1.55;}
.prob-head-r b{color:#fff;font-weight:600;}

.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-d);border:1px solid var(--line-d);border-radius:var(--r-lg);overflow:hidden;}
.ba-col{background:var(--ink);padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;}
.ba-stage{position:relative;height:clamp(300px,30vw,360px);border-radius:14px;overflow:hidden;margin-bottom:24px;
  background:radial-gradient(120% 100% at 50% 0%,rgba(255,255,255,.04),transparent 70%);}
.ba-label{display:flex;align-items:center;gap:11px;font-weight:700;font-size:16px;color:#fff;margin-bottom:8px;}
.ba-ic{width:20px;height:20px;border-radius:5px;display:grid;place-items:center;flex:none;position:relative;}
.ba-ic.before{background:rgba(255,255,255,.14);}
.ba-ic.before::before,.ba-ic.before::after{content:"";position:absolute;width:3px;height:10px;border-radius:1px;background:#fff;}
.ba-ic.before::before{left:6px;}.ba-ic.before::after{right:6px;}
.ba-ic.after{background:var(--accent);}
.ba-ic.after::before{content:"";position:absolute;width:10px;height:3px;border-radius:2px;background:#fff;}
.ba-desc{color:var(--muted-d);font-size:14.5px;line-height:1.5;max-width:340px;}

/* BEFORE collage */
.sticky{position:absolute;top:6%;left:8%;width:200px;background:#ffd84d;color:#5b4a12;border-radius:3px 3px 10px 3px;
  padding:18px 18px 26px;font-family:'Bradley Hand','Comic Sans MS',cursive;font-size:14px;line-height:1.5;
  box-shadow:0 18px 36px rgba(0,0,0,.4);transform:rotate(-3deg);z-index:3;animation:stickyBob 5s ease-in-out infinite;}
.sticky-tip{position:absolute;bottom:-1px;right:-1px;width:34px;height:26px;background:linear-gradient(135deg,transparent 46%,#e8bd2f 47%);border-radius:0 0 10px 0;}
@keyframes stickyBob{0%,100%{transform:rotate(-3deg) translateY(0);}50%{transform:rotate(-3deg) translateY(-6px);}}
.app-icon{position:absolute;top:8%;right:14%;display:flex;flex-direction:column;align-items:center;gap:7px;z-index:4;animation:floaty 6s ease-in-out infinite .5s;}
.app-glyph{width:54px;height:54px;border-radius:13px;background:#1d7a45;color:#fff;display:grid;place-items:center;font-weight:800;font-size:15px;box-shadow:0 12px 26px rgba(0,0,0,.4);}
.app-name{font-size:12.5px;color:#cfcfca;font-weight:500;}
.xp-win{position:absolute;border:1px solid #1a4fc4;border-radius:7px 7px 0 0;overflow:hidden;box-shadow:0 14px 30px rgba(0,0,0,.45);background:#fff;}
.xp-bar{height:26px;background:linear-gradient(180deg,#3b7bf0,#1c52d6);display:flex;align-items:center;justify-content:space-between;padding:0 8px;color:#fff;font-size:12px;font-weight:600;}
.xp-x{width:16px;height:14px;background:#e0584f;border-radius:3px;display:grid;place-items:center;font-size:11px;line-height:1;}
.xp-1{left:2%;bottom:10%;width:62%;height:120px;animation:xpPop 6s ease-in-out infinite;}
.xp-2{left:9%;bottom:4%;width:62%;height:120px;animation:xpPop 6s ease-in-out infinite .4s;}
.xp-3{left:16%;bottom:-2%;width:64%;height:130px;z-index:2;animation:xpPop 6s ease-in-out infinite .8s;}
.xp-addr{display:flex;align-items:center;gap:5px;padding:6px 8px;background:#ece9d8;border-bottom:1px solid #cfc9b0;}
.xp-url{flex:1;background:#fff;border:1px solid #b7b3a0;border-radius:2px;height:18px;font-size:11px;color:#444;display:flex;align-items:center;padding:0 5px;}
.xp-go{font-size:11px;font-weight:700;color:#2a7d2a;}
.xp-page{height:100%;background:#fff;}
@keyframes xpPop{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.cursor{position:absolute;top:40%;left:46%;width:18px;height:18px;z-index:6;
  background:linear-gradient(135deg,#fff 50%,transparent 51%);clip-path:polygon(0 0,0 16px,4px 12px,7px 18px,9px 17px,6px 11px,12px 11px);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.5));animation:cursorMove 7s ease-in-out infinite;}
@keyframes cursorMove{0%{transform:translate(0,0);}25%{transform:translate(-120px,80px);}50%{transform:translate(60px,40px);}75%{transform:translate(-40px,-30px);}100%{transform:translate(0,0);}}

/* AFTER card */
.ba-stage .after-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(94%,424px);
  background:#fff;border-radius:16px;box-shadow:0 28px 60px -18px rgba(0,0,0,.5);padding:10px 8px;}
.after-card .arow{display:flex;align-items:center;gap:13px;padding:14px 18px;border-bottom:1px solid #eee;transition:.3s;}
.after-card .arow:last-child{border-bottom:none;}
.after-card .atext{font-weight:700;font-size:15px;color:#bdbbb6;transition:.3s;white-space:nowrap;}
.after-card .arow.active .atext{color:var(--accent);}
.after-card .arow.done .atext{color:#16181a;}
.after-card .arow.done .sdot{background:var(--accent);border-color:var(--accent);}
.after-card .arow.done .sdot .ck{opacity:1;transform:scale(1);}
.after-card .arow.active .sdot{border-color:transparent;}
.after-card .arow.active .sdot .spin{opacity:1;}
@media (prefers-reduced-motion:reduce){.sticky,.app-icon,.xp-win,.cursor{animation:none;}}

/* ============================================================
   QUOTE
   ============================================================ */
.quote{background:#fff;text-align:center;}
.quote .wrap{max-width:920px;}
.quote blockquote{margin:0;font-size:clamp(24px,3.4vw,38px);font-weight:600;letter-spacing:-.025em;line-height:1.28;}
.quote blockquote .accent-text{color:var(--accent);}
.quote .by{margin-top:28px;font-size:15px;color:var(--muted);}
.quote .by b{color:var(--ink);font-weight:700;}

/* ============================================================
   HOW IT WORKS (accordion + isometric conveyor)
   ============================================================ */
.hiw-grid{display:grid;grid-template-columns:1fr 1.08fr;gap:clamp(34px,5vw,64px);align-items:center;margin-top:48px;}
.hiw-list{border-top:1px solid var(--line);}
.hiw-item{border-bottom:1px solid var(--line);position:relative;}
.hiw-item::before{content:"";position:absolute;left:0;top:-1px;bottom:-1px;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .35s ease;}
.hiw-item.active::before{transform:scaleY(1);}
.hiw-q{width:100%;text-align:left;background:none;border:none;display:flex;align-items:center;gap:14px;padding:21px 8px;font-family:inherit;font-size:clamp(17px,2vw,20px);font-weight:600;letter-spacing:-.01em;color:var(--ink);cursor:pointer;transition:color .25s;}
.hiw-ic{width:30px;height:30px;border-radius:8px;background:var(--bg-soft);color:#9a9893;display:grid;place-items:center;flex:none;transition:.25s;}
.hiw-item.active .hiw-q{color:var(--accent);}
.hiw-item.active .hiw-ic{background:#fdeee8;color:var(--accent);}
.hiw-plus{margin-left:auto;width:20px;height:20px;position:relative;flex:none;}
.hiw-plus::before,.hiw-plus::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--line-strong);transition:.25s;}
.hiw-plus::before{width:12px;height:2px;}
.hiw-plus::after{height:12px;width:2px;}
.hiw-item.active .hiw-plus::before,.hiw-item.active .hiw-plus::after{background:var(--accent);}
.hiw-item.active .hiw-plus::after{transform:translate(-50%,-50%) scaleY(0);}
.hiw-a{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.hiw-a p{padding:0 8px 24px 52px;color:var(--muted);font-size:15px;line-height:1.62;}

/* isometric conveyor */
.hiw-visual{position:relative;}
.iso-scene{position:relative;height:clamp(320px,32vw,404px);border-radius:18px;overflow:hidden;border:1px solid var(--line);
  background:
    linear-gradient(180deg,#f7f6f4,#efeeeb);
}
.iso-scene::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);
  background-size:40px 40px;-webkit-mask-image:radial-gradient(70% 70% at 50% 50%,#000,transparent 78%);mask-image:radial-gradient(70% 70% at 50% 50%,#000,transparent 78%);}
.iso-belt{position:absolute;inset:0;}
.cube{position:absolute;top:50%;left:50%;width:150px;height:172px;margin:-86px 0 0 -75px;animation:convey 9s linear infinite;}
.cube .cf{position:absolute;inset:0;}
.cube .top{}
.cube .cf.top{background:#ffffff;clip-path:polygon(50% 0,100% 25%,50% 50%,0 25%);}
.cube .cf.left{background:#e9e7e2;clip-path:polygon(0 25%,50% 50%,50% 100%,0 75%);}
.cube .cf.right{background:#dcd9d3;clip-path:polygon(50% 50%,100% 25%,100% 75%,50% 100%);}
.cube.hot{filter:drop-shadow(0 18px 30px rgba(244,81,30,.4));z-index:5;}
.cube.hot .cf.top{background:#ff7a4d;}
.cube.hot .cf.left{background:#d8400e;}
.cube.hot .cf.right{background:#ef5a28;}
.cube .clabel{position:absolute;top:52%;left:50%;transform:translateX(-58%);font-size:12px;font-weight:700;line-height:1.15;color:#b5b2ac;text-align:left;}
.cube.hot .clabel{color:#fff;}
@keyframes convey{
  0%{transform:translate(-176px,-108px) scale(.62);opacity:0;}
  12%{opacity:1;}
  50%{transform:translate(0,0) scale(1);}
  88%{opacity:1;}
  100%{transform:translate(176px,108px) scale(1.16);opacity:0;}
}
@media (prefers-reduced-motion:reduce){.cube{animation:none;}.cube:not(.hot){opacity:.5;}}

/* swappable visual panels */
.hpanel{position:absolute;inset:0;opacity:0;visibility:hidden;transform:scale(.97);transition:opacity .5s ease,transform .5s ease;}
.hpanel.active{opacity:1;visibility:visible;transform:none;}

/* shared isometric card */
.iso-card{position:absolute;top:50%;left:50%;width:min(78%,360px);background:#fff;border-radius:16px;
  box-shadow:0 30px 60px -22px rgba(0,0,0,.4);padding:20px 22px;
  transform:translate(-50%,-50%) perspective(1400px) rotateX(46deg) rotateZ(-34deg);
  animation:cardFloat 6s ease-in-out infinite;}
@keyframes cardFloat{0%,100%{transform:translate(-50%,-50%) perspective(1400px) rotateX(46deg) rotateZ(-34deg);}50%{transform:translate(-50%,-54%) perspective(1400px) rotateX(46deg) rotateZ(-34deg);}}
.iso-card .ac-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #eee;padding-bottom:12px;margin-bottom:6px;}
.iso-card .ac-t{font-weight:700;font-size:15px;color:#16181a;}
.iso-card .ac-score{font-weight:800;font-size:15px;color:#16181a;}
.ac-score.up{color:#2e9c54;}
.ac-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;font-size:13.5px;color:#6a6a67;border-bottom:1px dashed #eee;}
.ac-row b{color:#16181a;font-weight:700;}
.ac-row b.up{color:#2e9c54;}
.ac-row b.warn{color:var(--accent);}
.ac-bar{margin-top:14px;height:8px;border-radius:6px;background:#f0eeea;overflow:hidden;}
.ac-bar span{display:block;height:100%;width:0;border-radius:6px;background:linear-gradient(90deg,#ff7a4d,#f4511e);animation:barFill 2.4s ease forwards;}
@keyframes barFill{to{width:var(--w);}}
.hpanel[data-p="0"]:not(.active) .ac-bar span{animation:none;width:0;}

/* growth chart bars */
.chart-card .bars{display:flex;align-items:flex-end;gap:10px;height:160px;padding-top:14px;}
.chart-card .bars span{flex:1;height:0;border-radius:6px 6px 3px 3px;background:#e3e0db;align-self:flex-end;animation:barGrow 1s ease forwards;}
.chart-card .bars span.hot{background:linear-gradient(180deg,#ff7a4d,#f4511e);}
.chart-card .bars span:nth-child(2){animation-delay:.08s;}
.chart-card .bars span:nth-child(3){animation-delay:.16s;}
.chart-card .bars span:nth-child(4){animation-delay:.24s;}
.chart-card .bars span:nth-child(5){animation-delay:.32s;}
.chart-card .bars span:nth-child(6){animation-delay:.4s;}
.chart-card .bars span:nth-child(7){animation-delay:.48s;}
@keyframes barGrow{to{height:var(--h);}}
.hpanel[data-p="3"]:not(.active) .bars span{animation:none;height:0;}

/* infinity flow */
.flow{position:absolute;inset:0;}
.flow-src{position:absolute;top:14%;left:8%;background:#fff;border-radius:10px;box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding:11px 15px;font-size:13.5px;font-weight:600;color:#16181a;transform:rotate(-2deg);}
.flow-svg{position:absolute;top:18%;left:14%;width:72%;height:64%;overflow:visible;}
.flow-live{stroke-dasharray:60 600;animation:flowDash 2.6s linear infinite;filter:drop-shadow(0 6px 14px rgba(244,81,30,.45));}
@keyframes flowDash{to{stroke-dashoffset:-660;}}
.flow-node{position:absolute;background:#fff;border-radius:10px;box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding:10px 14px;font-size:13px;font-weight:700;color:var(--accent);white-space:nowrap;opacity:0;animation:nodePop 2.6s ease-in-out infinite;}
.flow-node.n1{top:30%;right:4%;animation-delay:.7s;}
.flow-node.n2{bottom:8%;left:24%;animation-delay:1.3s;}
.flow-node.n3{bottom:20%;right:8%;animation-delay:1.9s;}
@keyframes nodePop{0%,100%{opacity:.25;transform:translateY(4px);}25%,60%{opacity:1;transform:translateY(0);}}

/* ============================================================
   BOUNDED AI (document extraction) + shared feat-head
   ============================================================ */
.feat-head{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:end;margin-bottom:clamp(34px,4vw,52px);}
.feat-head h2{font-size:clamp(30px,4.2vw,50px);letter-spacing:-.034em;line-height:1.02;}
.feat-head .eyebrow .idx{display:none;}
.feat-head-r{color:var(--muted);font-size:clamp(16px,1.7vw,18.5px);line-height:1.55;}
.feat-head-r b{color:var(--ink);font-weight:700;}

.extract-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(32px,4vw,56px);align-items:start;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,40px);}
.doc{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 26px;box-shadow:var(--shadow);overflow:hidden;}
.doc-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:18px;}
.doc-t{font-weight:700;font-size:18px;letter-spacing:-.01em;}
.doc-id{text-align:right;font-size:11.5px;color:var(--muted);line-height:1.5;}
.doc-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px 30px;}
.doc-col .dl{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#a9a7a2;margin-bottom:3px;}
.doc-col .dv{font-size:14px;color:#16181a;margin-bottom:15px;}
.doc-col .dv:last-child{margin-bottom:0;}
.doc mark{background:transparent;color:inherit;padding:1px 3px;border-radius:3px;transition:background .35s,box-shadow .35s,color .35s;}
.doc mark.lit{background:rgba(244,81,30,.16);box-shadow:0 0 0 1px rgba(244,81,30,.4);color:#c33d12;}
.scan-line{position:absolute;left:0;right:0;top:0;height:64px;pointer-events:none;
  background:linear-gradient(180deg,rgba(244,81,30,0),rgba(244,81,30,.12) 70%,rgba(244,81,30,.5));
  border-bottom:2px solid var(--accent);opacity:0;animation:scan 5.5s ease-in-out infinite;}
@keyframes scan{0%{opacity:0;transform:translateY(0);}6%{opacity:1;}90%{opacity:1;}100%{opacity:0;transform:translateY(320px);}}
.extract-copy .ec-h{font-size:17px;color:var(--accent);margin:0 0 8px;}
.extract-copy .ec-h:not(:first-child){margin-top:24px;}
.extract-copy p{font-size:14.5px;color:var(--muted);line-height:1.6;margin-bottom:6px;}
.extract-copy .ec-muted{color:#a9a7a2;}
@media (prefers-reduced-motion:reduce){.scan-line{animation:none;opacity:.4;}}

/* ============================================================
   WORKFLOWS (animated decision tree)
   ============================================================ */
.wf-tabs{display:flex;flex-wrap:wrap;gap:0;margin-bottom:8px;border-bottom:1px solid var(--line);}
.wf-tab{appearance:none;background:none;border:none;font-family:inherit;cursor:pointer;
  font-size:15px;font-weight:600;color:var(--muted);padding:14px 4px;margin-right:38px;position:relative;transition:color .2s;}
.wf-tab::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s;}
.wf-tab.on{color:var(--accent);}
.wf-tab.on::after{transform:scaleX(1);}
.wf-stage{position:relative;margin-top:26px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-lg);
  height:clamp(380px,40vw,460px);overflow:hidden;}
.wf-wires{position:absolute;inset:0;width:100%;height:100%;}
.wf-wires .wire{fill:none;stroke:#d8d5cf;stroke-width:2;stroke-dasharray:1000;stroke-dashoffset:1000;}
.wf-wires .wire.draw{animation:wireDraw 1s ease forwards;}
@keyframes wireDraw{to{stroke-dashoffset:0;}}
.wf-node,.wf-card{position:absolute;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-sm);
  opacity:0;transform:translateY(8px) scale(.96);transition:opacity .4s ease,transform .4s ease;}
.wf-node.show,.wf-card.show{opacity:1;transform:none;}
.wf-node{padding:12px 16px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:9px;white-space:nowrap;}
.n-start{left:5%;top:18%;flex-direction:column;align-items:flex-start;gap:1px;}
.n-start .wt{font-weight:700;}
.n-start .ws{font-size:12px;font-weight:500;color:var(--muted);}
.n-action{left:30%;top:20%;color:var(--accent);}
.wf-ic{width:24px;height:24px;border-radius:7px;background:#fdeee8;color:var(--accent);display:grid;place-items:center;flex:none;}
.wf-ic.sm{width:22px;height:22px;}
.n-ok{left:54%;top:8%;}
.n-no{left:54%;top:66%;}
.wf-dot{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;flex:none;}
.wf-dot.ok{background:#2e9c54;}
.wf-dot.no{background:#c9c7c2;}
.wf-card{padding:14px 16px;max-width:260px;}
.c-ok{left:72%;top:2%;display:flex;align-items:flex-start;gap:11px;width:240px;}
.c-ok > div{display:flex;flex-direction:column;gap:2px;}
.c-ok .wc-t{font-weight:700;font-size:13.5px;line-height:1.3;}
.c-ok .wc-s{font-size:12px;color:var(--muted);}
.c-no{left:70%;top:58%;display:flex;flex-direction:column;gap:9px;}
.c-no .wc-head{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;color:var(--accent);}
.c-no .wc-sub{font-size:12.5px;color:#b3b1ac;padding-left:27px;}
.wf-spin{width:18px;height:18px;border-radius:50%;border:2px solid #f3d4c6;border-top-color:var(--accent);animation:spin .8s linear infinite;flex:none;}
@media (prefers-reduced-motion:reduce){.wf-spin{animation:none;}.wf-node,.wf-card{opacity:1;transform:none;}.wf-wires .wire{stroke-dashoffset:0;}}

/* ============================================================
   SERVICES (tabs + cards row)
   ============================================================ */
.svc-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;}
.svc-tab{font-size:13.5px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;cursor:pointer;}
.svc-tab.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px;}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s;}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-strong);}
.svc .ic{width:48px;height:48px;border-radius:13px;background:#fdeee8;color:var(--accent);display:grid;place-items:center;margin-bottom:18px;}
.svc h4{font-size:18.5px;}
.svc p{margin-top:10px;font-size:14.5px;color:var(--muted);line-height:1.55;}
.svc .more{margin-top:15px;font-weight:600;font-size:13.5px;color:var(--accent);display:inline-flex;gap:6px;align-items:center;}
.svc:hover .more .arr{transform:translateX(3px);}

/* ============================================================
   GROWTH (dark, chart)
   ============================================================ */
.growth{background:var(--ink);color:#fff;}
.growth .sec-head h2,.growth h2,.growth h3{color:#fff;}
.growth-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(36px,5vw,64px);align-items:center;margin-top:46px;}
.growth h2 .accent-text{color:var(--accent-2);}
.growth-points{margin-top:26px;display:flex;flex-direction:column;gap:16px;}
.gp{display:flex;gap:13px;color:var(--muted-d);font-size:15px;}
.gp .ck{flex:none;width:26px;height:26px;border-radius:8px;background:rgba(244,81,30,.18);color:var(--accent-2);display:grid;place-items:center;}
.gp b{color:#fff;font-weight:700;}
.chart-panel{border:1px solid var(--line-d);border-radius:var(--r-lg);padding:26px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.01));}
.chart-panel .head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;}
.chart-panel .head .t{font-weight:700;font-size:15px;}
.chart-panel .head .s{font-size:13px;color:var(--muted-d);margin-top:2px;}
.chart-panel .tag{font-size:11.5px;font-weight:700;color:var(--accent-2);background:rgba(244,81,30,.16);padding:5px 11px;border-radius:999px;}
.chart-panel .legend{display:flex;gap:18px;font-size:12.5px;color:var(--muted-d);margin-top:14px;}
.chart-panel .legend span{white-space:nowrap;display:inline-flex;align-items:center;}
.chart-panel .legend i{width:12px;height:3px;border-radius:2px;display:inline-block;margin-right:7px;vertical-align:middle;}
.draw-path{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 1.6s ease;}
.draw-path.run{stroke-dashoffset:0;}

/* before/after two-line chart */
.bachart{position:relative;}
.ba-axis{display:flex;justify-content:space-between;font-size:11px;letter-spacing:.06em;color:var(--muted-d);line-height:1.4;margin-bottom:8px;padding:0 6px;}
.ba-axis .after{text-align:right;color:rgba(255,255,255,.6);}
.ba-line{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 2s ease;}
.ba-line.run{stroke-dashoffset:0;}
#baProfit{filter:drop-shadow(0 4px 12px rgba(31,191,120,.4));}
.ba-end{opacity:0;transition:opacity .4s ease .9s;}
.ba-end.run{opacity:1;}

/* ============================================================
   STATEMENT (pinned scroll word-reveal + floating cursors)
   ============================================================ */
.statement-track{position:relative;height:280vh;background:var(--ink-2);}
.statement-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;text-align:center;}
.statement-pin .wrap{max-width:1040px;position:relative;z-index:2;}
.reveal-text{font-size:clamp(30px,5.4vw,66px);font-weight:700;letter-spacing:-.035em;line-height:1.14;}
.reveal-text .w{color:rgba(255,255,255,.1);transition:color .3s ease,opacity .3s ease;}
.reveal-text .w.lit{color:#fff;}
.reveal-text .w.accent.lit{color:var(--accent-2);}

/* multiplayer-style cursor labels */
.cursor-lbl{position:absolute;z-index:1;display:flex;align-items:flex-start;gap:2px;
  font-size:clamp(13px,1.4vw,16px);font-weight:600;white-space:nowrap;will-change:transform;}
.cursor-lbl svg{filter:drop-shadow(0 0 10px currentColor);margin-top:-2px;}
.cursor-lbl span{margin-top:9px;margin-left:-2px;padding:2px 4px;border-radius:5px;}
.cl-1{color:#a855f7;}.cl-1 span b{color:#c891fb;}.cl-1 span{color:rgba(200,145,251,.6);}
.cl-2{color:#ec4899;}.cl-2 span b{color:#f375b3;}.cl-2 span{color:rgba(243,117,179,.6);}
.cl-3{color:#22c55e;}.cl-3 span b{color:#5ee089;}.cl-3 span{color:rgba(94,224,137,.6);}
.cl-4{color:#3b82f6;}.cl-4 span b{color:#74a8fb;}.cl-4 span{color:rgba(116,168,251,.6);}
.cl-1{top:22%;left:13%;animation:drift1 11s ease-in-out infinite;}
.cl-2{top:16%;right:11%;animation:drift2 13s ease-in-out infinite;}
.cl-3{bottom:26%;right:16%;animation:drift3 12s ease-in-out infinite;}
.cl-4{bottom:20%;left:16%;animation:drift4 14s ease-in-out infinite;}
@keyframes drift1{0%,100%{transform:translate(0,0);}33%{transform:translate(40px,26px);}66%{transform:translate(-22px,14px);}}
@keyframes drift2{0%,100%{transform:translate(0,0);}33%{transform:translate(-34px,30px);}66%{transform:translate(18px,-16px);}}
@keyframes drift3{0%,100%{transform:translate(0,0);}33%{transform:translate(-30px,-24px);}66%{transform:translate(26px,12px);}}
@keyframes drift4{0%,100%{transform:translate(0,0);}33%{transform:translate(36px,-22px);}66%{transform:translate(-16px,18px);}}
@media (prefers-reduced-motion:reduce){.cursor-lbl{animation:none;}}

/* ============================================================
   REVIEWS (featured quote + scrolling wall)
   ============================================================ */
.review-feature{max-width:880px;margin:clamp(34px,4vw,48px) auto 0;text-align:center;
  font-size:clamp(22px,2.9vw,33px);font-weight:600;letter-spacing:-.022em;line-height:1.34;color:var(--muted);}
.review-feature .rf-strong{color:var(--ink);}
.review-feature .rf-by{display:block;margin-top:26px;font-size:15px;font-weight:500;color:var(--muted);letter-spacing:0;}
.review-feature .rf-by b{color:var(--ink);font-weight:700;}

.review-rows{margin-top:clamp(44px,5vw,64px);display:flex;flex-direction:column;gap:20px;}
.review-marq{overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);}
.review-track{display:flex;gap:20px;width:max-content;animation:marquee 52s linear infinite;}
.review-track.rev{animation:marqueeRev 52s linear infinite;}
.review-marq:hover .review-track{animation-play-state:paused;}
@keyframes marqueeRev{from{transform:translateX(-50%);}to{transform:translateX(0);}}
.rev-card{flex:none;width:380px;border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;background:#fff;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:15px;}
.rev-card .stars{color:#f4b740;letter-spacing:2px;font-size:14px;}
.rev-card blockquote{margin:0;font-size:15px;line-height:1.55;color:#2a2a28;}
.rev-card .who{display:flex;align-items:center;gap:12px;margin-top:auto;}
.rev-card .av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;flex:none;}
.rev-card .who .nm{font-weight:700;font-size:14.5px;}
.rev-card .who .rl{font-size:13px;color:var(--muted);}
@media (prefers-reduced-motion:reduce){.review-track{animation:none;}}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(30px,5vw,60px);margin-top:20px;align-items:start;}
.faq-list{border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:22px 0;display:flex;align-items:center;gap:16px;font-family:inherit;font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.01em;}
.faq-q .sign{margin-left:auto;flex:none;width:26px;height:26px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;position:relative;transition:.2s;}
.faq-q .sign::before,.faq-q .sign::after{content:"";position:absolute;background:var(--ink);transition:.25s;}
.faq-q .sign::before{width:12px;height:2px;}
.faq-q .sign::after{width:2px;height:12px;}
.faq-item.open .faq-q .sign{background:var(--accent);border-color:var(--accent);}
.faq-item.open .faq-q .sign::before,.faq-item.open .faq-q .sign::after{background:#fff;}
.faq-item.open .faq-q .sign::after{transform:scaleY(0);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a p{padding:0 42px 22px 0;color:var(--muted);font-size:15.5px;line-height:1.6;}

/* ============================================================
   CTA (orange)
   ============================================================ */
.cta{background:var(--accent);color:#fff;position:relative;overflow:hidden;}
.cta::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 130% at 82% 0%,rgba(255,255,255,.2),transparent 60%);pointer-events:none;}
.cta-inner{display:grid;grid-template-columns:1.25fr 1fr;gap:42px;align-items:center;position:relative;}
.cta h2{color:#fff;font-size:clamp(34px,4.8vw,58px);letter-spacing:-.035em;}
.cta p{margin-top:16px;color:rgba(255,255,255,.92);font-size:18px;max-width:440px;}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}
.cta-side{display:flex;flex-direction:column;gap:14px;}
.cta-side .pt{display:flex;align-items:center;gap:12px;font-size:15.5px;font-weight:600;}
.cta-side .pt .ck{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.2);display:grid;place-items:center;flex:none;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:#9b9b97;padding-top:72px;overflow:hidden;}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:52px;border-bottom:1px solid var(--line-d);}
.foot-brand img{height:34px;width:auto;margin-bottom:18px;}
.foot-brand p{font-size:14.5px;max-width:300px;line-height:1.6;}
.foot-social{display:flex;gap:10px;margin-top:20px;}
.foot-social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-d);display:grid;place-items:center;color:#9b9b97;transition:.2s;}
.foot-social a:hover{color:#fff;border-color:var(--accent);background:rgba(244,81,30,.12);}
.foot-col h5{color:#fff;font-size:13px;letter-spacing:.07em;text-transform:uppercase;margin:0 0 16px;}
.foot-col a{display:block;font-size:14.5px;margin-bottom:11px;transition:color .15s;}
.foot-col a:hover{color:#fff;}
.foot-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding:24px 0 28px;font-size:13.5px;}
.foot-bottom .legal{display:flex;gap:22px;flex-wrap:wrap;}
.foot-watermark{font-weight:800;font-size:clamp(64px,17vw,230px);line-height:.78;letter-spacing:-.05em;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,0));-webkit-background-clip:text;background-clip:text;color:transparent;text-align:center;padding-bottom:14px;user-select:none;white-space:nowrap;}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
/* instant reveal for above-the-fold elements - no transition to get stuck */
.reveal.nofade{transition:none!important;transition-delay:0s!important;opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
.reveal[data-d="5"]{transition-delay:.40s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .hiw-grid,.growth-grid,.feature .feat-grid,.feature.alt .feat-grid,.cta-inner,.faq-grid{grid-template-columns:1fr;}
  .feat-head,.extract-grid{grid-template-columns:1fr;gap:24px;}
  .feature.alt .feat-visual{order:0;}
  .foot-top{grid-template-columns:1fr 1fr;gap:30px;}
  .foot-brand{grid-column:1 / -1;}
}
@media (max-width:860px){
  .nav-links,.nav-cta .signin{display:none;}
  .nav-toggle{display:flex;}
  .nav-cta{margin-left:auto;}
  .cta-side{order:-1;}
}
@media (max-width:760px){
  /* stack the animated hero scene cards on small screens */
  .hero-scene{height:auto;display:flex;flex-direction:column;gap:13px;padding:18px;}
  .scene-card{position:static;width:100%!important;animation:none;}
  .card-browser .bw-pic{display:none;}
  .card-browser .bw-body{padding-right:20px;}
  /* workflows: switch the absolute flowchart to a vertical stacked flow */
  .wf-stage{height:auto;overflow:visible;padding:20px 16px;display:flex;flex-direction:column;gap:14px;}
  .wf-wires{display:none;}
  .wf-node,.wf-card{position:static!important;left:auto!important;top:auto!important;right:auto!important;
    width:100%!important;max-width:none!important;}
  .wf-node.n-action,.wf-node.n-ok,.wf-node.n-no{align-self:flex-start;}
}
@media (max-width:620px){
  body{font-size:16px;}
  .svc-grid,.prob-cards{grid-template-columns:1fr;}
  .doc-cols{grid-template-columns:1fr;gap:0;}
  .extract-grid{padding:16px;}
  .doc{padding:18px 18px;}
  .rev-card{width:min(82vw,330px);}
  .hero-actions .btn,.cta-actions .btn{flex:1 1 auto;justify-content:center;}
  .prob-head{grid-template-columns:1fr;gap:18px;}
  .ba-grid{grid-template-columns:1fr;}
  .statement .av{display:none;}
  .foot-top{grid-template-columns:1fr;}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:10px;}
}
