/* ============================================================
   DEMFI — design tokens
   Lime is a verb. Black is the tool. Numbers lead.
   ============================================================ */
:root{
  --lime:#CAFF00;
  --ink:#1A1A1A;
  --paper:#FAFAF7;
  --cream:#F2F1EC;
  --red:#E8462C;
  --green:#2FBE4B;
  --body:#3A3A3A;
  --secondary:#6B6B6B;
  --hairline:#E5E4DF;
  --hairline-dark:#2E2E2C;

  --r-card:18px;
  --r-btn:14px;
  --r-pill:999px;
  --r-panel:24px;

  --shadow:0 2px 8px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.04);

  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);

  --font:"General Sans","Helvetica Neue",Helvetica,Arial,sans-serif;
  --mono:"SFMono-Regular",ui-monospace,"JetBrains Mono",Menlo,Consolas,monospace;
}

*{box-sizing:border-box;margin:0;padding:0;min-width:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth;overflow-x:hidden;width:100%;max-width:100%}
body{
  font-family:var(--font);
  background:var(--cream);
  color:var(--body);
  font-size:18px;
  line-height:1.5;
  font-weight:400;
  overflow-x:hidden;
}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1}
img{display:block;max-width:100%}
::selection{background:var(--lime);color:var(--ink)}
a{color:inherit}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);width:100%}
section{position:relative}
.field-paper{background:var(--paper)}
.field-cream{background:var(--cream)}
.field-ink{background:var(--ink);color:var(--paper)}

/* ---------- type ---------- */
.eyebrow{
  font-size:12.5px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--secondary);
}
.field-ink .eyebrow{color:#9A9A95}
.display{
  font-weight:600;line-height:0.96;letter-spacing:-0.035em;color:var(--ink);
  text-wrap:balance;
}
.field-ink .display{color:var(--paper)}
.d-xl{font-size:clamp(46px,8.2vw,116px)}
.d-lg{font-size:clamp(40px,6.4vw,84px)}
.d-md{font-size:clamp(32px,4.4vw,60px)}
.d-sm{font-size:clamp(26px,3.2vw,40px)}
.lede{font-size:clamp(18px,1.7vw,23px);line-height:1.45;color:var(--body);font-weight:400;max-width:46ch;text-wrap:pretty}
.field-ink .lede{color:#C9C9C4}
.lime-word{color:var(--lime)}
.muted{color:var(--secondary)}
.field-ink .muted{color:#8C8C87}

/* metric numerals */
.metric{font-weight:600;letter-spacing:-0.04em;line-height:0.9;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font);font-weight:600;font-size:16px;letter-spacing:-0.01em;
  border-radius:var(--r-btn);padding:15px 24px;border:1px solid transparent;cursor:pointer;
  text-decoration:none;transition:transform .25s cubic-bezier(.2,.7,.2,1),background .25s,color .25s,border-color .25s;
  -webkit-tap-highlight-color:transparent;white-space:nowrap;
}
.btn-lime{background:var(--lime);color:var(--ink)}
.btn-lime:hover{transform:translateY(-1px)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--hairline)}
.field-ink .btn-ghost{color:var(--paper);border-color:var(--hairline-dark)}
.btn-ghost:hover{border-color:var(--ink)}
.field-ink .btn-ghost:hover{border-color:var(--paper)}
.btn .arrow{transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:transparent;border-bottom:1px solid transparent;transition:background .35s ease,border-color .35s ease,backdrop-filter .35s ease}
.nav.scrolled{background:rgba(250,250,247,0.82);backdrop-filter:saturate(1.2) blur(12px);border-bottom:1px solid var(--hairline)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.wordmark{display:inline-flex;align-items:center;gap:11px;font-weight:600;font-size:21px;letter-spacing:0.02em;color:var(--ink);text-decoration:none}
.wm-bare{display:inline-flex;align-items:center;flex:0 0 auto}
.wm-bare img{height:24px;width:auto;display:block}
/* lime mark needs a touch of contrast on the light nav bar */
.nav .wm-bare img{filter:drop-shadow(0 1px 1px rgba(26,26,26,0.28))}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{color:var(--body);text-decoration:none;font-size:15.5px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta-wrap{display:flex;align-items:center;gap:18px}

/* ---------- device frame ---------- */
.phone{position:relative;filter:drop-shadow(0 30px 50px rgba(0,0,0,0.10))}
.phone img{width:100%;height:auto}
.field-ink .phone{filter:drop-shadow(0 30px 60px rgba(0,0,0,0.5))}

/* ---------- 3D phone ---------- */
.scene{perspective:2200px;perspective-origin:60% 40%}
.phone3d{transform:rotateY(-15deg) rotateX(6deg) rotate(0.4deg);
  filter:drop-shadow(-30px 40px 44px rgba(0,0,0,0.26));transition:transform .5s cubic-bezier(.16,1,.3,1);will-change:transform}
.phone3d img{width:100%;height:auto;display:block}
.hero-fade{opacity:0;transform:translateY(42px);transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.hero-fade.in{opacity:1;transform:none}
.phone-halo{position:absolute;z-index:0;left:50%;top:47%;transform:translate(-50%,-50%);
  width:128%;height:78%;border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side, rgba(202,255,0,0.38), rgba(202,255,0,0.12) 52%, rgba(202,255,0,0) 76%)}

/* hero background — animated dispatch beams (aceternity-style) */
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.beamfield{position:absolute;top:-40%;right:-25%;width:96%;height:180%;transform:rotate(-24deg)}
.bline{position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(26,26,26,0.075) 22%,rgba(26,26,26,0.075) 78%,transparent)}
.comet{position:absolute;left:-220px;width:180px;height:2px;border-radius:3px;
  background:linear-gradient(90deg,rgba(202,255,0,0),var(--lime));
  box-shadow:0 0 14px 2px rgba(202,255,0,0.4);will-change:transform,opacity;
  animation:cometrun linear infinite}
@keyframes cometrun{0%{transform:translateX(0);opacity:0}7%{opacity:1}82%{opacity:1}100%{transform:translateX(1150px);opacity:0}}
@media (prefers-reduced-motion:reduce){.comet{display:none}}

/* aceternity-style word reveal */
.rw{display:inline}
.rw-word{display:inline-block;opacity:0;filter:blur(10px);transform:translateY(16px);
  transition:opacity .7s cubic-bezier(.16,1,.3,1),filter .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.rw.in .rw-word{opacity:1;filter:blur(0);transform:none}
@media (prefers-reduced-motion:reduce){.rw-word{opacity:1;filter:none;transform:none;transition:none}}

/* hero headline */
.hero-h1{text-wrap:normal !important;font-weight:700;letter-spacing:-0.03em;line-height:1.02}
.sticker3d{color:var(--lime);white-space:nowrap;text-shadow:0.07em 0.08em 0 var(--ink)}

/* shimmer CTA (aceternity-style) */
.btn-lime{position:relative;overflow:hidden;isolation:isolate}
.btn-lime::after{content:"";position:absolute;top:-30%;left:-160%;width:55%;height:160%;z-index:-1;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,0.6),transparent);transform:skewX(-18deg)}
.btn-lime:hover::after{animation:shimmer .95s ease}
@keyframes shimmer{from{left:-160%}to{left:170%}}

/* spotlight cards (aceternity-style) */
.spot{position:relative}
.spot::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .45s;pointer-events:none;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%), rgba(202,255,0,0.12), transparent 62%)}
.spot:hover::before{opacity:1}

/* ---------- showcase ---------- */
.showcase-screen{position:absolute;inset:0;opacity:0;transform:scale(0.98);
  transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.showcase-screen img{width:100%;height:auto;display:block}
.showcase-screen.on{opacity:1;transform:none}
.feat-list{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.feat{display:grid;grid-template-columns:3px 1fr;gap:20px;align-items:stretch;text-align:left;
  background:transparent;border:0;cursor:pointer;width:100%;font-family:var(--font);
  padding:18px 18px 18px 16px;border-radius:14px;opacity:.5;
  transition:opacity .45s ease,background .45s ease}
.feat:hover{opacity:.8}
.feat.on{opacity:1;background:rgba(202,255,0,0.07)}
.feat-rail{position:relative;width:3px;border-radius:3px;background:var(--hairline);overflow:hidden}
.feat-fill{position:absolute;left:0;top:0;width:100%;height:0;background:var(--lime);border-radius:3px}
.feat.on .feat-fill{animation:featfill 5s linear forwards}
.feat-list.paused .feat.on .feat-fill{animation-play-state:paused}
@keyframes featfill{from{height:0}to{height:100%}}
.feat-pr{display:block;font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--secondary);margin-bottom:9px;transition:color .4s}
.feat.on .feat-pr{color:var(--ink)}
.feat-h{display:block;font-size:clamp(19px,2vw,23px);font-weight:600;letter-spacing:-0.015em;color:var(--ink);line-height:1.15;margin-bottom:7px}
.feat-p{display:block;font-size:15px;color:var(--secondary);line-height:1.5;max-width:46ch}
@media (prefers-reduced-motion:reduce){.feat.on .feat-fill{animation:none;height:100%}}
.phone3d-soft{transform:rotateY(-11deg) rotateX(3deg);
  filter:drop-shadow(-22px 30px 40px rgba(0,0,0,0.22));transition:transform 1s cubic-bezier(.16,1,.3,1)}
.scene:hover .phone3d-soft{transform:rotateY(-5deg) rotateX(1.5deg)}

/* ---------- live chip ---------- */
.live-chip{
  display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);
  border-radius:var(--r-pill);padding:8px 15px 8px 13px;font-size:13px;font-weight:600;letter-spacing:.04em;
}
.live-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:blink 1.6s steps(1,end) infinite}
@keyframes blink{0%,60%{opacity:1}61%,100%{opacity:.25}}

/* ---------- reveal motion (deliberate, weighty) ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- hairline divider ---------- */
.rule{height:1px;background:var(--hairline);border:0}
.field-ink .rule{background:var(--hairline-dark)}

/* ---------- chips / tags ---------- */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;letter-spacing:.02em;
  border:1px solid var(--hairline);border-radius:var(--r-pill);padding:7px 14px;color:var(--body);background:var(--paper)}
.field-ink .tag{background:transparent;border-color:var(--hairline-dark);color:#C9C9C4}
.tag .gd{width:7px;height:7px;border-radius:50%;background:var(--green)}

/* ---------- engine diagram ---------- */
.engine-stage{position:relative;border:1px solid var(--hairline-dark);border-radius:var(--r-panel);overflow:hidden;background:#161615}
.dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.05) 1px,transparent 1px);background-size:22px 22px;pointer-events:none}
.eng-svg .conn{stroke-dasharray:6 7;stroke-dashoffset:120;opacity:0}
.eng-svg .route{stroke-dasharray:560;stroke-dashoffset:560}
.eng-svg .stop{opacity:0;transform:scale(.4);transform-origin:center;transform-box:fill-box}
.eng-svg .stopnum{opacity:0}
.eng-svg .enginebox{opacity:0;transform:translateY(8px)}
.eng-svg .stackring{opacity:0}
.eng-svg .ordertok{opacity:0;transform:translateX(-10px)}
.eng-stage.run .ordertok{animation:tokIn .7s cubic-bezier(.16,1,.3,1) forwards}
.eng-stage.run .ordertok.t2{animation-delay:.16s}
.eng-stage.run .ordertok.t3{animation-delay:.32s}
/* intro draw once, then keep the dotted feed marching into the engine, one direction, forever */
.eng-stage.run .conn{opacity:1;animation:connFlow 1.05s linear infinite 1.3s}
.eng-stage.run .conn.c1{animation-delay:1.3s}
.eng-stage.run .conn.c2{animation-delay:1.42s}
.eng-stage.run .conn.c3{animation-delay:1.54s}
@keyframes connFlow{from{stroke-dashoffset:13}to{stroke-dashoffset:0}}
/* dispatch box breathes so the engine reads as live, not static */
.eng-stage.run .enginebox rect{animation:boxPulse 3s ease-in-out infinite 1.6s}
@keyframes boxPulse{0%,100%{stroke-opacity:.55}50%{stroke-opacity:1}}
@media (prefers-reduced-motion:reduce){.eng-stage.run .conn{animation:none;stroke-dashoffset:0}.eng-stage.run .enginebox rect{animation:none}}
.eng-stage.run .enginebox{animation:boxIn .8s cubic-bezier(.16,1,.3,1) forwards .55s}
.eng-stage.run .route{animation:draw 1.5s cubic-bezier(.6,0,.2,1) forwards .9s}
.eng-stage.run .stop{animation:popIn .6s cubic-bezier(.16,1,.3,1) forwards}
.eng-stage.run .stopnum{animation:fadeIn .5s ease forwards}
.eng-stage.run .s0{animation-delay:1.0s}
.eng-stage.run .s1{animation-delay:1.22s}
.eng-stage.run .s2{animation-delay:1.44s}
.eng-stage.run .s3{animation-delay:1.66s}
.eng-stage.run .s4{animation-delay:1.88s}
.eng-stage.run .s5{animation-delay:2.10s}
.eng-stage.run .stackring{animation:ringIn 1.4s ease forwards 2.3s}
@keyframes tokIn{to{opacity:1;transform:none}}
@keyframes connIn{to{opacity:1;stroke-dashoffset:0}}
@keyframes boxIn{to{opacity:1;transform:none}}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes popIn{to{opacity:1;transform:scale(1)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes ringIn{0%{opacity:0;transform:scale(.6)}40%{opacity:1}100%{opacity:1;transform:scale(1)}}

/* ---------- flow arrows (integrations) ---------- */
.flowarrow{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:70px}
.flowarrow .lab{font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--secondary);white-space:nowrap}
.flowarrow.lime .lab{color:var(--ink);background:var(--lime);padding:4px 9px;border-radius:6px}

/* ---------- marketplaces marquee (aceternity infinite-moving) ---------- */
.marquee{margin-top:clamp(44px,5vw,64px);position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;width:max-content;gap:14px;animation:scrollx 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(calc(-50% - 7px))}}
.mq-chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:10px;
  border:1px solid var(--hairline);background:var(--paper);border-radius:var(--r-pill);
  padding:12px 22px;font-weight:600;font-size:16px;color:var(--ink);letter-spacing:-0.01em;white-space:nowrap}
.mq-chip .gd{width:8px;height:8px;border-radius:50%;background:var(--green);flex:0 0 auto}
.mq-chip.soon{color:var(--secondary);font-weight:500}
.mq-chip.soon .gd{background:var(--hairline)}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;width:auto}}

/* ---------- runs-on (Powering Biteo) band ---------- */
.runson{border:1px solid var(--hairline-dark);border-radius:var(--r-panel);overflow:hidden;
  background:linear-gradient(180deg,#1F1F1E,#161615);position:relative}
.runson .glowdot{position:absolute;width:420px;height:420px;border-radius:50%;right:-120px;top:-160px;
  background:radial-gradient(circle,rgba(202,255,0,0.14),rgba(202,255,0,0) 60%);pointer-events:none}
.runson-grid{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(28px,4vw,64px);align-items:center;
  padding:clamp(34px,4.4vw,56px) clamp(28px,4vw,56px);position:relative}
.runson-lockup{display:inline-flex;align-items:center;gap:14px}
.runson-lockup img{height:46px;width:auto;display:block}
.runson-lockup .name{font-size:clamp(30px,4vw,46px);font-weight:600;letter-spacing:-0.03em;color:var(--paper)}
.runson-say{max-width:42ch}
.runson-say .q{font-size:clamp(19px,2.1vw,26px);font-weight:500;color:var(--paper);line-height:1.32;letter-spacing:-0.01em}
.runson-say .q b{color:var(--lime);font-weight:600}
.runson-stat{text-align:right;border-left:1px solid var(--hairline-dark);padding-left:clamp(24px,3vw,40px)}
.runson-stat .v{font-size:clamp(30px,3.4vw,46px);font-weight:600;color:var(--lime);letter-spacing:-0.03em;line-height:1;font-variant-numeric:tabular-nums}
.runson-stat .k{font-size:13.5px;color:#9A9A95;margin-top:8px;max-width:16ch;margin-left:auto;line-height:1.4}
@media (max-width:900px){
  .runson-grid{grid-template-columns:1fr;gap:28px;text-align:left}
  .runson-stat{text-align:left;border-left:none;border-top:1px solid var(--hairline-dark);padding-left:0;padding-top:24px}
  .runson-stat .k{margin-left:0}
}

/* ---------- step timeline ---------- */
.step{display:grid;grid-template-columns:auto 1fr;gap:clamp(22px,4vw,56px);padding:clamp(30px,4vw,46px) 0;border-top:1px solid var(--hairline)}
.step:last-child{border-bottom:1px solid var(--hairline)}
.step .num{font-size:clamp(34px,4.4vw,58px);font-weight:600;letter-spacing:-0.04em;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1}

/* ---------- numbers band ---------- */
.numgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline-dark);border:1px solid var(--hairline-dark);border-radius:var(--r-panel);overflow:hidden}
.numcell{background:var(--ink);padding:clamp(28px,3.4vw,46px) clamp(22px,2.6vw,34px)}
.numcell .big{font-size:clamp(48px,6vw,86px);font-weight:600;letter-spacing:-0.04em;line-height:0.92;color:var(--paper);font-variant-numeric:tabular-nums}
.numcell .big.live{color:var(--lime)}
.numcell .lab{margin-top:14px;font-size:14.5px;color:#9A9A95;line-height:1.4;max-width:24ch}

/* ---------- contact (Talk to us) ---------- */
.contact-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(30px,5vw,80px);align-items:start}
.contact-form{display:grid;gap:16px}
.field{display:grid;gap:8px}
.field label{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#9A9A95}
.field input,.field textarea{
  font-family:var(--font);font-size:16px;color:var(--paper);background:#1F1F1E;
  border:1px solid var(--hairline-dark);border-radius:var(--r-btn);padding:14px 16px;width:100%;
  transition:border-color .2s ease,box-shadow .2s ease}
.field input::placeholder,.field textarea::placeholder{color:#6E6E6A}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px rgba(202,255,0,0.14)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:13.5px;color:#8C8C87;margin-top:2px}
.form-ok{font-size:15px;color:var(--lime);font-weight:600;display:none}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ---------- closing spotlight ---------- */
.spotlight{position:relative;overflow:hidden}
.spotlight .glow{position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(202,255,0,0.16),rgba(202,255,0,0) 62%);
  transform:translate(-50%,-50%);pointer-events:none;transition:opacity .4s;mix-blend-mode:screen}
/* aceternity-style entrance spotlight sweep */
.spotlight .sweep{position:absolute;top:0;left:50%;width:140%;height:160%;pointer-events:none;opacity:0;
  background:conic-gradient(from 210deg at 50% 0%, rgba(202,255,0,0.10), transparent 28%);
  transform:translate(-72%,-62%) scale(.5);filter:blur(6px)}
.spotlight.lit .sweep{animation:sweepIn 2.1s cubic-bezier(.16,1,.3,1) .2s forwards}
@keyframes sweepIn{0%{opacity:0;transform:translate(-72%,-62%) scale(.5)}100%{opacity:1;transform:translate(-50%,-40%) scale(1)}}
@media (prefers-reduced-motion:reduce){.spotlight .sweep{display:none}}

/* ---------- footer ---------- */
.footer{padding:72px 0 48px}
.footcol h5{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:#8C8C87;font-weight:600;margin-bottom:16px}
.footcol a{display:block;color:#C9C9C4;text-decoration:none;font-size:15px;margin-bottom:11px;transition:color .2s}
.footcol a:hover{color:var(--lime)}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr !important;gap:48px !important}
  .eng-head{grid-template-columns:1fr !important;align-items:start !important}
  .eng-caps{grid-template-columns:repeat(2,1fr) !important}
  .eng-caps > *{border-left:none !important;border-top:1px solid var(--hairline-dark)}
  .onb{grid-template-columns:1fr !important}
  .onb > div:first-child{position:static !important}
  .footgrid{grid-template-columns:1fr 1fr !important}
  .flow{grid-template-columns:1fr !important;gap:8px !important}
  .flow > .flow-sources{display:grid;grid-template-columns:1fr 1fr;gap:14px}
}
@media (max-width:900px){
  .nav-links{display:none}
  .numgrid{grid-template-columns:repeat(2,1fr)}
  .step{grid-template-columns:1fr;gap:14px}
  .compare{grid-template-columns:1fr !important}
  .compare > div:first-child{border-right:none !important;padding:34px 0 !important;border-bottom:1px solid var(--hairline-dark)}
  .compare > div:last-child{padding-left:0 !important}
  .showcase-grid{grid-template-columns:1fr !important;gap:40px !important}
  .showcase-grid > .scene{order:-1}
  .feat{opacity:1 !important}
}
@media (max-width:560px){
  body{font-size:17px}
  .numgrid{grid-template-columns:1fr}
  .eng-caps{grid-template-columns:1fr !important}
  .footgrid{grid-template-columns:1fr !important}
  .flow > .flow-sources{grid-template-columns:1fr}
}

/* ============================================================
   v2 polish: section blends, aurora, early-access
   ============================================================ */

/* clean section transition: dark sections lift onto the light canvas as
   rounded panels. No blur, no muddy fade. Corners reveal the page canvas. */
.panel-top{border-top-left-radius:clamp(26px,3.4vw,48px);border-top-right-radius:clamp(26px,3.4vw,48px)}
.panel-bot{border-bottom-left-radius:clamp(26px,3.4vw,48px);border-bottom-right-radius:clamp(26px,3.4vw,48px)}
.panel-top,.panel-bot{position:relative;z-index:1}

/* aceternity-style aurora — slow drifting field on a dark section, kept very low key */
.aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;opacity:.9}
.aurora::before{content:"";position:absolute;inset:-30%;
  background:
    radial-gradient(40% 55% at 18% 22%, rgba(202,255,0,0.10), transparent 60%),
    radial-gradient(45% 50% at 82% 28%, rgba(202,255,0,0.06), transparent 62%),
    radial-gradient(50% 60% at 60% 90%, rgba(47,190,75,0.06), transparent 60%);
  filter:blur(40px);background-size:200% 200%;animation:auroraDrift 26s ease-in-out infinite alternate}
@keyframes auroraDrift{0%{background-position:0% 50%,100% 50%,50% 100%}100%{background-position:60% 30%,30% 70%,40% 0%}}
@media (prefers-reduced-motion:reduce){.aurora::before{animation:none}}
.aurora ~ *{position:relative;z-index:1}

/* contact states */
.form-err{display:none;font-size:14.5px;color:var(--red);font-weight:600}
.contact-form.sending button[type=submit]{opacity:.6;pointer-events:none}

/* ============================================================
   mobile-only fixes — scoped to media queries, desktop untouched
   ============================================================ */

/* Integrations flow stacks vertically on mobile: the horizontal connector
   lines look broken when stacked, so swap them for a clean downward arrow. */
@media (max-width:1000px){
  .flowarrow{min-width:0;flex-direction:row;justify-content:center;align-items:center;gap:10px;padding:2px 0}
  .flowarrow svg{display:none}
  .flowarrow::after{content:"\2193";font-size:20px;line-height:1;color:var(--secondary)}
  .flowarrow.lime::after{color:var(--ink)}
  .flowarrow.lime .lab{display:inline-block}
}

@media (max-width:900px){
  /* nav: keep the Talk-to-us CTA fully on screen on phones */
  .nav-inner{height:64px;gap:12px}
  .wordmark{font-size:18px;gap:8px}
  .nav-cta-wrap .btn{padding:11px 16px;font-size:14px}
  /* engine diagram: scroll horizontally so it stays legible instead of
     shrinking to an unreadable thumbnail */
  .engine-stage{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
  .eng-svg{min-width:660px}
}

@media (max-width:560px){
  .nav-cta-wrap .btn{padding:10px 14px;font-size:13.5px}
  .nav-cta-wrap .btn .arrow{display:none}
}
