/* ============================================================
   GEMINI SOLUTIONS — HOMEPAGE PROTOTYPE v1
   Direction: "control room meets editorial"
   Dark cinematic hero + data sections, light editorial body
   ============================================================ */
:root{
  /* Site owns its dark theme — opt out of browser auto/force dark mode
     (e.g. Brave night mode), which otherwise darkens white-background
     elements like the nav-burger bars into near-invisible gray. */
  color-scheme:dark;
  /* CONTRAST PASS (design/contrast-pass): richer navy-blacks from the logo
     gradient instead of neutral ink, brighter type on dark, darker type on
     light, warmer paper, more saturated accents. Brand blues unchanged. */
  --ink-900:#050D1B;
  --ink-800:#0A1626;
  --ink-700:#102136;
  --ink-600:#183054;
  --paper:#FBF8F2;
  --white:#FFFFFF;
  --t-dark:#0A141D;
  --t-mid:#36424E;
  --t-faint:#57646F;
  --t-ondark:#F4F8FC;
  --t-ondark-mid:#C6D2DE;
  --t-ondark-faint:#93A3B3;
  /* Gemini brand blues — from the "Gemini Colors" Figma library + logo gradient */
  --blue:#2F80ED;        /* Blue 1 — primary */
  --blue-mid:#2D9CDB;    /* Blue 2 — hover */
  --blue-sky:#5FD4FF;    /* Blue 3 — accents on dark (brightened) */
  --blue-deep:#0757A4;   /* logo gradient — accents on light */
  --navy:#212A5B;        /* logo gradient base */
  --green:#3DDC9B;
  --red:#E25C5C;
  --line-dark:rgba(255,255,255,.13);
  --line-light:rgba(14,24,32,.17);
  --font-display:'Space Grotesk',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
  --w-max:1240px;
  --pad-x:clamp(20px,4vw,48px);
  --sec-y:clamp(88px,11vw,160px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--t-dark);background:var(--paper);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
::selection{background:var(--blue);color:#fff}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--w-max);margin:0 auto;padding:0 var(--pad-x)}

/* ---------- type ---------- */
.eyebrow{font-family:var(--font-mono);font-size:.72rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--blue-deep);
  display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;flex:none}
.hero .eyebrow,.dark .eyebrow,.dark-7 .eyebrow{color:var(--blue-sky)}
h1,h2,h3{font-family:var(--font-display);font-weight:500;letter-spacing:-.03em;line-height:1.04}
h1{font-size:clamp(2.5rem,5.4vw,4.6rem)}
h2{font-size:clamp(2rem,4.4vw,3.6rem)}
h3{font-size:clamp(1.2rem,1.8vw,1.5rem);letter-spacing:-.02em;line-height:1.2}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.55;color:var(--t-mid);max-width:36em}
.dark .lead{color:var(--t-ondark-mid)}
.accent{color:var(--blue)}
.dark .accent,.dark-7 .accent,.hero .accent{color:var(--blue-sky)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-weight:500;font-size:.95rem;letter-spacing:.01em;padding:.95rem 1.7rem;
  border-radius:4px;transition:all .25s ease;cursor:pointer;border:1px solid transparent}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-mid)}
.btn-ghost-dark{border-color:var(--line-dark);color:var(--t-ondark)}
.btn-ghost-dark:hover{border-color:var(--t-ondark-mid);background:rgba(255,255,255,.04)}
.btn-ghost-light{border-color:var(--line-light);color:var(--t-dark)}
.btn-ghost-light:hover{border-color:var(--t-mid)}

/* ---------- nav ---------- */
nav{position:fixed;inset:0 0 auto 0;z-index:100;transition:all .3s ease;
  border-bottom:1px solid transparent}
nav.scrolled{background:rgba(7,12,17,.82);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);border-bottom-color:var(--line-dark)}
.nav-inner{max-width:var(--w-max);margin:0 auto;padding:1.1rem var(--pad-x);
  display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center}
.logo img{height:32px;width:auto;display:block}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{font-size:.9rem;font-weight:500;color:var(--t-ondark-mid);transition:color .2s}
.nav-links a:hover{color:var(--t-ondark)}
.nav-cta{font-family:var(--font-display);font-weight:500;font-size:.88rem;
  padding:.6rem 1.2rem;border-radius:4px;background:var(--blue);color:#fff!important;
  transition:background .2s}
.nav-cta:hover{background:var(--blue-mid)}
/* Menu toggle is CSS-only (checkbox hack) — no JS, so it works even when a
   browser blocks scripts (e.g. Brave Shields). The checkbox is visually
   hidden but stays focusable for keyboard users; the .nav-burger is its label. */
.nav-toggle{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;
  clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap}
.nav-burger{display:none;position:relative;align-items:center;justify-content:center;
  width:42px;height:42px;border:1px solid var(--line-dark);border-radius:8px;background:transparent;
  cursor:pointer;padding:0;flex:none;-webkit-tap-highlight-color:transparent}
/* Icons are <img> SVGs (not CSS-painted bars). Browser auto/night dark-mode
   (Brave, etc.) darkens CSS background-colors but leaves <img> content alone —
   the same reason the SVG logo stays white — so the icon stays visible.
   Crossfade + rotate between the hamburger and the X keeps the open/close
   animation (the host page can animate the <img> box, just not its insides). */
.nav-burger img{position:absolute;inset:0;margin:auto;
  transition:opacity .28s ease,transform .28s ease}
.nav-burger .ico-close{opacity:0;transform:rotate(-90deg)}
.nav-toggle:checked ~ .nav-burger .ico-open{opacity:0;transform:rotate(90deg)}
.nav-toggle:checked ~ .nav-burger .ico-close{opacity:1;transform:rotate(0)}
.nav-toggle:focus-visible ~ .nav-burger{outline:2px solid var(--blue-sky);outline-offset:2px}
@media(max-width:860px){
  .nav-burger{display:flex}
  nav:has(.nav-toggle:checked){background:rgba(7,12,17,.97);backdrop-filter:blur(14px)}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(7,12,17,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-dark);
    padding:.4rem var(--pad-x) 1.3rem}
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-links a{padding:.9rem 0;border-bottom:1px solid var(--line-dark);font-size:1rem}
  .nav-links a.nav-cta{margin-top:1rem;text-align:center;padding:.85rem 1rem;border-bottom:none}
}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--ink-900);color:var(--t-ondark);
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.hero-bg-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(ellipse 90% 80% at 60% 40%,black 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 60% 40%,black 30%,transparent 75%)}
.hero-map{position:absolute;top:0;right:-6%;height:100%;width:62%;opacity:.85;pointer-events:none}
.hero-map svg{width:100%;height:100%}
.route{fill:none;stroke:rgba(86,204,242,.55);stroke-width:1.5;
  stroke-dasharray:6 7;animation:routeflow 30s linear infinite}
.route.r2{stroke:rgba(154,168,179,.32);animation-duration:44s}
.route.r3{stroke:rgba(47,128,237,.42);animation-duration:38s}
@keyframes routeflow{to{stroke-dashoffset:-1000}}
.node{fill:var(--ink-900);stroke:rgba(86,204,242,.85);stroke-width:1.5}
.node-pulse{fill:none;stroke:rgba(86,204,242,.5);stroke-width:1;
  transform-origin:center;transform-box:fill-box;animation:pulse 3.2s ease-out infinite}
.node-pulse.d1{animation-delay:.8s}.node-pulse.d2{animation-delay:1.6s}.node-pulse.d3{animation-delay:2.4s}
@keyframes pulse{0%{transform:scale(.4);opacity:.9}100%{transform:scale(3);opacity:0}}
.node-dot{fill:var(--t-ondark-faint)}
.hero-fade{position:absolute;inset:0;background:
  linear-gradient(90deg,var(--ink-900) 22%,rgba(7,12,17,.55) 55%,rgba(7,12,17,.15) 100%)}
.hero-inner{position:relative;z-index:2;padding-top:7.5rem;padding-bottom:1rem;
  display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);gap:3rem;align-items:end}
.hero h1{margin:1rem 0 1.4rem}
.hero h1 .l2{background:linear-gradient(92deg,#56CCF2 0%,#2D9CDB 45%,#2F80ED 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-ctas{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}

/* live ticket feed */
.feed{justify-self:end;width:min(380px,100%);background:rgba(15,27,38,.72);
  border:1px solid var(--line-dark);border-radius:8px;backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);overflow:hidden}
.feed-head{display:flex;justify-content:space-between;align-items:center;
  padding:.8rem 1.1rem;border-bottom:1px solid var(--line-dark);
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--t-ondark-faint)}
.feed-head .live{display:flex;align-items:center;gap:.45rem;color:var(--green)}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);
  animation:blink 1.6s ease-in-out infinite}
@keyframes blink{50%{opacity:.25}}
.feed-list{list-style:none;padding:.4rem 0;height:222px;overflow:hidden}
.feed-list li{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;
  padding:.62rem 1.1rem;font-family:var(--font-mono);font-size:.74rem;color:var(--t-ondark-mid);
  border-bottom:1px solid rgba(255,255,255,.03);animation:feedin .5s ease both}
@keyframes feedin{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.feed-list .tk{color:var(--t-ondark)}
.feed-list .ok{color:var(--green);white-space:nowrap}
.feed-list .flag{color:var(--red);white-space:nowrap}

/* hero stats bar */
.hero-stats{position:relative;z-index:2;border-top:1px solid var(--line-dark);margin-top:3.2rem}
.hero-stats-inner{max-width:var(--w-max);margin:0 auto;padding:1.6rem var(--pad-x);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.hstat{font-family:var(--font-mono)}
.hstat b{display:block;font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.3rem,2.2vw,1.8rem);letter-spacing:-.02em;color:var(--t-ondark)}
.hstat span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--t-ondark-faint)}
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;align-items:start}
  .feed{justify-self:start}
  .hero-map{width:100%;right:-20%;opacity:.35}
  .hero-stats-inner{grid-template-columns:repeat(2,1fr)}
}

/* ---------- sections ---------- */
section{padding:var(--sec-y) 0}
.dark{background:var(--ink-900);color:var(--t-ondark)}
.dark-7{background:var(--ink-800);color:var(--t-ondark)}
.sec-head{max-width:54rem;margin-bottom:clamp(3rem,6vw,5rem)}
.sec-head h2{margin-bottom:1.4rem}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

/* ---------- problem ---------- */
.problem-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.bigstat{border-left:3px solid var(--blue);padding-left:1.6rem;margin:2.4rem 0}
.bigstat b{font-family:var(--font-display);font-weight:600;letter-spacing:-.03em;
  font-size:clamp(2.6rem,5vw,4.2rem);line-height:1;display:block;color:var(--t-dark)}
.bigstat span{font-size:.95rem;color:var(--t-mid)}
.problem-points{list-style:none;display:flex;flex-direction:column;gap:0}
.problem-points li{display:flex;gap:1.2rem;padding:1.4rem 0;border-bottom:1px solid var(--line-light)}
.problem-points li:first-child{border-top:1px solid var(--line-light)}
.problem-points .num{font-family:var(--font-mono);font-size:.72rem;color:var(--blue-deep);padding-top:.3rem}
.problem-points h3{font-size:1.05rem;margin-bottom:.3rem}
.problem-points p{font-size:.92rem;color:var(--t-mid)}
.reframe{margin-top:2.6rem;font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.3rem,2.2vw,1.7rem);letter-spacing:-.02em;line-height:1.3}
.reframe .accent{border-bottom:2px solid var(--blue)}
@media(max-width:900px){.problem-grid{grid-template-columns:1fr}}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pillar{background:var(--white);border:1px solid var(--line-light);border-radius:8px;
  padding:2.4rem 2rem 2.2rem;display:flex;flex-direction:column;gap:1rem;
  transition:transform .3s ease,box-shadow .3s ease}
.pillar:hover{transform:translateY(-6px);box-shadow:0 24px 48px -24px rgba(14,24,32,.25)}
.pillar .tag{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue-deep)}
.pillar h3{font-size:1.45rem}
.pillar p{font-size:.95rem;color:var(--t-mid);flex:1}
.pillar .proof{font-family:var(--font-mono);font-size:.74rem;color:var(--t-dark);
  border-top:1px solid var(--line-light);padding-top:1.1rem;letter-spacing:.04em}
.pillar .proof b{color:var(--blue-deep);font-weight:500}
@media(max-width:900px){.pillars{grid-template-columns:1fr}}

/* ---------- how it works ---------- */
.flow{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:0;align-items:stretch}
.flow-col{display:flex;flex-direction:column;gap:.7rem}
.flow-label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--t-ondark-faint);margin-bottom:.6rem}
.chip{border:1px solid var(--line-dark);border-radius:6px;padding:.9rem 1.1rem;
  font-family:var(--font-mono);font-size:.78rem;color:var(--t-ondark-mid);
  display:flex;align-items:center;gap:.7rem;background:rgba(255,255,255,.02)}
.chip i{width:7px;height:7px;background:var(--blue);transform:rotate(45deg);flex:none;display:inline-block}
.chip.flow-out i{background:var(--green);border-radius:50%;transform:none}
.engine{margin:0 clamp(1rem,3vw,2.5rem);border:1px solid rgba(47,128,237,.45);border-radius:10px;
  background:linear-gradient(180deg,rgba(47,128,237,.09),rgba(47,128,237,.02));
  padding:1.8rem 1.6rem;display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  position:relative}
.engine::before,.engine::after{content:"";position:absolute;top:50%;width:clamp(1rem,3vw,2.5rem);height:1px;
  background:repeating-linear-gradient(90deg,var(--blue) 0 5px,transparent 5px 10px);opacity:.6}
.engine::before{right:100%}.engine::after{left:100%}
.engine .flow-label{color:var(--blue-sky);text-align:center;margin-bottom:1rem}
.engine-step{display:flex;align-items:center;gap:.9rem;padding:.72rem .4rem;
  border-bottom:1px solid rgba(255,255,255,.05);font-family:var(--font-display);
  font-weight:500;font-size:.98rem;color:var(--t-ondark)}
.engine-step:last-child{border-bottom:none}
.engine-step .n{font-family:var(--font-mono);font-size:.66rem;color:var(--blue-sky)}
.engine-step small{margin-left:auto;font-family:var(--font-mono);font-size:.62rem;
  color:var(--t-ondark-faint);letter-spacing:.06em;text-align:right}
@media(max-width:900px){
  .flow{grid-template-columns:1fr}
  .engine{margin:1.5rem 0}
  .engine::before,.engine::after{display:none}
}

/* ---------- inside the platform ---------- */
.product-stage{position:relative;padding-bottom:46px}
.browser{background:var(--white);border:1px solid var(--line-light);border-radius:12px;
  box-shadow:0 48px 90px -42px rgba(14,24,32,.4);overflow:hidden;width:min(900px,100%)}
.browser-bar{display:flex;align-items:center;gap:.45rem;padding:.65rem 1rem;
  background:#EEF0F2;border-bottom:1px solid var(--line-light)}
.browser-bar i{width:9px;height:9px;border-radius:50%;background:#D3D8DC}
.browser-url{margin-left:.8rem;display:flex;align-items:center;width:min(240px,48%);height:20px;
  background:var(--white);border:1px solid var(--line-light);border-radius:4px;padding:0 .6rem}
.browser-url::after{content:"";width:55%;height:5px;border-radius:3px;background:#DDE2E6}
.browser-body{display:grid;grid-template-columns:170px 1fr;min-height:430px}
.app-rail{border-right:1px solid var(--line-light);background:#FAFBFC;
  padding:.85rem .65rem;display:flex;flex-direction:column;gap:.25rem}
.rail-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;border-radius:6px;
  border:none;background:none;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--t-faint);cursor:pointer;text-align:left;
  transition:background .2s,color .2s;white-space:nowrap}
.rail-item svg{width:13px;height:13px;flex:none}
.rail-item:hover{background:#EFF2F4;color:var(--t-mid)}
.rail-item.on{background:rgba(47,128,237,.1);color:var(--blue-deep)}
.rail-item.dim{opacity:.4;cursor:default;pointer-events:none}
.app-views{position:relative;min-width:0}
.app-view{display:none}
.app-view.on{display:block;height:100%}
.view-fleet.on{display:grid;grid-template-columns:1fr 252px}
/* dispatch view */
.view-dispatch.on{display:flex;flex-direction:column}
.dis-head,.dis-row{display:grid;grid-template-columns:84px 1.5fr 1fr 112px;gap:1rem;
  align-items:center;padding:.8rem 1.2rem}
.dis-head{border-bottom:1px solid var(--line-light);font-family:var(--font-mono);
  font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--t-faint);padding:.65rem 1.2rem}
.dis-row{border-bottom:1px solid rgba(14,24,32,.05);font-family:var(--font-mono);
  font-size:.64rem;color:var(--t-mid)}
.dis-row b{color:var(--t-dark);font-weight:500}
.dis-route{display:flex;align-items:center;gap:.5rem;min-width:0}
.dis-route span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dis-route i{flex:1 0 14px;height:1px;
  background:repeating-linear-gradient(90deg,#C3CBD1 0 4px,transparent 4px 8px)}
.st{font-family:var(--font-mono);font-size:.52rem;letter-spacing:.1em;padding:.26rem .5rem;
  border-radius:3px;text-align:center;text-transform:uppercase}
.st.transit{background:rgba(47,128,237,.1);color:var(--blue-deep)}
.st.assigned{background:rgba(86,204,242,.18);color:#0B6FA8}
.st.queued{background:#EFF2F4;color:var(--t-faint)}
.st.complete{background:rgba(31,157,107,.1);color:#1F9D6B}
.st.flag{background:rgba(226,92,92,.1);color:#C44545}
/* ticket review view */
.view-tickets.on{display:flex;flex-direction:column}
.lifecycle{display:flex;align-items:center;gap:.55rem;padding:1rem 1.2rem;
  border-bottom:1px solid var(--line-light);overflow-x:auto}
.lc-step{display:flex;align-items:center;gap:.45rem;font-family:var(--font-mono);
  font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--t-mid);white-space:nowrap}
.lc-step i{width:7px;height:7px;border-radius:50%;background:#1F9D6B;flex:none}
.lc-step.live{color:var(--blue-deep)}
.lc-step.live i{background:var(--blue);animation:blink 1.6s ease-in-out infinite}
.lc-arrow{flex:none;width:16px;height:1px;
  background:repeating-linear-gradient(90deg,#C3CBD1 0 4px,transparent 4px 7px)}
.tk-row{display:grid;grid-template-columns:84px 1.5fr 1fr 112px;gap:1rem;align-items:center;
  padding:.8rem 1.2rem;border-bottom:1px solid rgba(14,24,32,.05);
  font-family:var(--font-mono);font-size:.64rem;color:var(--t-mid)}
.tk-row b{color:var(--t-dark);font-weight:500}
.tk-reason{grid-column:1/-1;margin:-.3rem 0 .2rem;padding:.55rem .8rem;border-radius:5px;
  background:rgba(226,92,92,.06);border:1px solid rgba(226,92,92,.2);
  font-size:.6rem;color:#C44545}
/* genie lamp icon */
.lamp{height:.8em;width:1.4em;display:inline-block;vertical-align:-.06em;color:var(--blue)}
.lamp.sky{color:var(--blue-sky)}
/* genie verified badge */
.badge{height:.95em;width:.95em;display:inline-block;vertical-align:-.12em;color:var(--blue)}
.app-map{position:relative;background:#F1F5F6;overflow:hidden}
.app-map > svg{position:absolute;inset:0;width:100%;height:100%}
.road{stroke:#DCE3E7;stroke-width:2.5;fill:none}
.map-route{stroke:rgba(47,128,237,.75);stroke-width:2;fill:none;
  stroke-dasharray:5 6;animation:routeflow 26s linear infinite}
.map-truck{fill:var(--blue)}
.map-pad{fill:#9AA8B3}
.map-swd{fill:#1F9D6B}
.map-pulse{fill:none;stroke:rgba(47,128,237,.5);stroke-width:1.5;
  transform-origin:center;transform-box:fill-box;animation:pulse 3s ease-out infinite}
.map-chip{position:absolute;left:6%;bottom:8%;background:var(--white);border:1px solid var(--line-light);
  border-radius:6px;padding:.55rem .85rem;font-family:var(--font-mono);font-size:.64rem;color:var(--t-mid);
  box-shadow:0 12px 28px -14px rgba(14,24,32,.3)}
.map-chip b{color:var(--t-dark);font-weight:500}
.map-chip .ok{color:#1F9D6B}
.app-drawer{border-left:1px solid var(--line-light);padding:1.1rem 1rem;display:flex;
  flex-direction:column;gap:.75rem;background:var(--white)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-mono);font-size:.72rem;color:var(--t-dark)}
.ok-chip{background:rgba(31,157,107,.1);color:#1F9D6B;border-radius:3px;
  padding:.2rem .5rem;font-size:.56rem;letter-spacing:.08em}
.sk{height:8px;border-radius:3px;background:#E9ECEE}
.sk.w40{width:40%}.sk.w60{width:60%}.sk.w75{width:75%}.sk.w90{width:90%}
.drawer-row{display:flex;justify-content:space-between;gap:1rem;align-items:center}
.drawer-row .sk{width:88px}
.drawer-label{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.14em;
  color:var(--t-faint);text-transform:uppercase}
.drawer-val{font-family:var(--font-mono);font-size:.66rem;color:var(--t-dark)}
.check-row{display:flex;justify-content:space-between;font-family:var(--font-mono);
  font-size:.62rem;color:var(--t-mid);border-top:1px solid var(--line-light);padding-top:.6rem}
.check-row b{color:#1F9D6B;font-weight:500}
.replay{margin-top:auto;border:1px solid var(--line-light);border-radius:6px;
  padding:.65rem .75rem;display:flex;align-items:center;gap:.65rem}
.replay .tri{width:0;height:0;border-left:9px solid var(--blue);
  border-top:5.5px solid transparent;border-bottom:5.5px solid transparent}
.replay .track{flex:1;height:4px;border-radius:2px;background:#E9ECEE;position:relative}
.replay .track::after{content:"";position:absolute;inset:0 62% 0 0;background:var(--blue);border-radius:2px}
.replay span{font-family:var(--font-mono);font-size:.56rem;color:var(--t-faint)}
.phone{position:absolute;right:clamp(0px,5vw,56px);bottom:-46px;width:222px;background:var(--white);
  border:7px solid var(--ink-800);border-radius:30px;
  box-shadow:0 44px 80px -32px rgba(14,24,32,.5);overflow:hidden;z-index:3}
.phone-head{background:var(--ink-800);color:var(--t-ondark);padding:1.4rem .95rem .75rem;
  font-family:var(--font-display);font-weight:500;font-size:.8rem;
  display:flex;justify-content:space-between;align-items:center}
.phone-head .live-chip{font-family:var(--font-mono);font-size:.52rem;color:var(--green);letter-spacing:.12em}
.phone-body{padding:.85rem .95rem 1rem;display:flex;flex-direction:column;gap:.65rem}
.geo-chip{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.56rem;
  letter-spacing:.06em;color:#1F9D6B;background:rgba(31,157,107,.08);
  border:1px solid rgba(31,157,107,.25);border-radius:4px;padding:.45rem .6rem}
.geo-chip::before{content:"";width:6px;height:6px;border-radius:50%;background:#1F9D6B;flex:none}
.vol-row{display:flex;justify-content:space-between;align-items:baseline;
  border:1px solid var(--line-light);border-radius:6px;padding:.55rem .75rem}
.vol-row b{font-family:var(--font-display);font-size:1.1rem;letter-spacing:-.02em;color:var(--t-dark)}
.vol-row span{font-family:var(--font-mono);font-size:.54rem;color:var(--t-faint);
  text-transform:uppercase;letter-spacing:.12em}
.sig{border:1px dashed rgba(14,24,32,.25);border-radius:6px;height:46px;
  display:flex;align-items:center;justify-content:center;color:var(--t-mid)}
.sig svg{height:24px;width:auto}
.phone-btn{background:var(--blue);color:#fff;text-align:center;font-family:var(--font-display);
  font-weight:500;font-size:.8rem;border-radius:6px;padding:.7rem}
.stage-captions{display:flex;gap:clamp(1.4rem,4vw,3.2rem);flex-wrap:wrap;margin-top:3.2rem}
.stage-captions div{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--t-faint);display:flex;gap:.6rem;align-items:baseline}
.stage-captions i{width:6px;height:6px;background:var(--blue);transform:rotate(45deg);flex:none}
.stage-captions b{color:var(--t-dark);font-weight:500}
@media(max-width:980px){
  .browser-body{grid-template-columns:1fr;min-height:340px}
  .app-rail{flex-direction:row;border-right:none;border-bottom:1px solid var(--line-light);
    overflow-x:auto;padding:.5rem .65rem}
  .view-fleet.on{grid-template-columns:1fr;min-height:300px}
  .app-drawer{display:none}
  .dis-head{display:none}
  .dis-row,.tk-row{grid-template-columns:80px 1fr 96px}
  .dis-driver,.tk-vol{display:none}
  .phone{position:static;margin:-70px 1rem 0 auto;display:block}
  .product-stage{padding-bottom:0}
}
/* hardware line art */
.hw-art{width:100%;height:auto;color:var(--t-ondark-mid);margin:.3rem 0 .4rem}
.hw-art .detail{opacity:.35}
.hw-art .sig{animation:sigpulse 2.8s ease-out infinite}
.hw-art .sig.s2{animation-delay:1.4s}
@keyframes sigpulse{0%,100%{opacity:.2}45%{opacity:1}}
.hw-art .flow{animation:dashflow 16s linear infinite}
@keyframes dashflow{to{stroke-dashoffset:-220}}
/* hardware showcase carousel */
.hw-show{margin-top:3rem;display:grid;grid-template-columns:1.15fr .85fr;gap:0;
  border:1px solid var(--line-dark);border-radius:10px;overflow:hidden;
  background:rgba(255,255,255,.02)}
.hw-stage{position:relative;min-height:320px;overflow:hidden;background:var(--ink-700)}
.hw-slide{position:absolute;inset:0;opacity:0;transform:scale(1.05);
  transition:opacity .5s ease,transform .8s ease;pointer-events:none}
.hw-slide.on{opacity:1;transform:none;pointer-events:auto}
.hw-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hw-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:40px;height:40px;
  border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(7,12,17,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:var(--t-ondark);
  font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s}
.hw-nav:hover{background:var(--blue);border-color:transparent}
.hw-nav.prev{left:14px}.hw-nav.next{right:14px}
.hw-count{position:absolute;left:16px;bottom:12px;z-index:4;font-family:var(--font-mono);
  font-size:.62rem;letter-spacing:.18em;color:rgba(255,255,255,.8);
  background:rgba(7,12,17,.5);padding:.3rem .6rem;border-radius:4px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hw-cap{padding:clamp(1.6rem,3vw,2.6rem);display:flex;flex-direction:column;
  justify-content:center;gap:1rem}
.hw-cap .mono-note{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--blue-sky);transition:opacity .25s}
.hw-cap h3{color:var(--t-ondark);font-size:1.35rem;transition:opacity .25s}
.hw-cap p{font-size:.92rem;color:var(--t-ondark-mid);transition:opacity .25s}
.hw-cap.fade .mono-note,.hw-cap.fade h3,.hw-cap.fade p{opacity:0}
.hw-dots{display:flex;gap:.5rem;margin-top:.4rem}
.hw-dot{width:24px;height:3px;border-radius:2px;background:rgba(255,255,255,.15);
  cursor:pointer;border:none;padding:0;transition:background .25s}
.hw-dot.on{background:var(--blue-sky)}
@media(max-width:900px){.hw-show{grid-template-columns:1fr}.hw-stage{min-height:240px;aspect-ratio:16/10}}
/* duotone field break */
.field-break{position:relative;padding:0;height:clamp(320px,44vw,540px);overflow:hidden;
  background:var(--ink-900)}
.field-break img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.08) brightness(.92)}
.fb-tint{position:absolute;inset:0;background:linear-gradient(155deg,#0757A4 0%,#212A5B 70%);
  mix-blend-mode:color}
.fb-shade{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(7,12,17,.62),rgba(7,12,17,.12) 45%,rgba(7,12,17,.72))}
.fb-text{position:absolute;inset:auto 0 clamp(2rem,5vw,3.5rem) 0;z-index:2}
.fb-line{font-family:var(--font-display);font-weight:500;letter-spacing:-.03em;
  font-size:clamp(1.8rem,4.4vw,3.4rem);line-height:1.05;color:var(--t-ondark);max-width:14em}

/* ---------- workflows ---------- */
.wf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.wf{background:var(--white);border:1px solid var(--line-light);border-radius:8px;
  padding:1.8rem 1.5rem;min-height:200px;display:flex;flex-direction:column;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;position:relative}
.wf:hover{transform:translateY(-5px);border-color:rgba(47,128,237,.55);
  box-shadow:0 20px 40px -24px rgba(14,24,32,.2)}
.wf h3{font-size:1.15rem;margin:0 0 .55rem}
.wf p{font-size:.86rem;color:var(--t-mid);flex:1}
.wf .entry{margin-top:1rem;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue-deep)}
@media(max-width:1000px){.wf-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.wf-grid{grid-template-columns:1fr}}

/* ---------- hardware ---------- */
.hw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.hw{border:1px solid var(--line-dark);border-radius:8px;padding:2.2rem 1.9rem;
  background:rgba(255,255,255,.02);display:flex;flex-direction:column;gap:1rem;
  transition:border-color .3s ease,background .3s ease}
.hw:hover{border-color:rgba(86,204,242,.45);background:rgba(86,204,242,.04)}
.hw .tag{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue-sky)}
.hw h3{color:var(--t-ondark);font-size:1.4rem}
.hw p{font-size:.92rem;color:var(--t-ondark-mid);flex:1}
.spec{border-top:1px solid var(--line-dark);font-family:var(--font-mono);font-size:.72rem}
.spec div{display:flex;justify-content:space-between;gap:1.2rem;padding:.55rem 0;
  border-bottom:1px solid rgba(255,255,255,.05)}
.spec span{color:var(--t-ondark-faint);letter-spacing:.1em;text-transform:uppercase;font-size:.62rem}
.spec b{color:var(--t-ondark);font-weight:500;text-align:right}
.hw-note{margin-top:2.4rem;font-family:var(--font-mono);font-size:.78rem;color:var(--t-ondark-faint);
  display:flex;gap:.8rem;align-items:baseline}
.hw-note::before{content:"※";color:var(--blue-sky)}
@media(max-width:900px){.hw-grid{grid-template-columns:1fr}}

/* ---------- partnership ---------- */
.steps{display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:auto 1fr 1.4fr;gap:clamp(1.5rem,4vw,4rem);
  align-items:start;padding:2.6rem 0;border-bottom:1px solid var(--line-light)}
.step:first-child{border-top:1px solid var(--line-light)}
.step .n{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,4vw,3.2rem);
  letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.5px var(--blue);line-height:1}
.step h3{font-size:1.5rem;padding-top:.4rem}
.step p{color:var(--t-mid);font-size:1rem;padding-top:.5rem}
@media(max-width:800px){.step{grid-template-columns:auto 1fr}.step p{grid-column:2}}
.quote{margin-top:clamp(3.5rem,7vw,6rem);max-width:56rem}
.quote blockquote{font-family:var(--font-display);font-weight:500;letter-spacing:-.02em;
  font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.32}
.quote blockquote .accent{color:var(--blue)}
.quote cite{display:block;margin-top:1.5rem;font-style:normal;font-family:var(--font-mono);
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--t-faint)}

/* ---------- data layer ---------- */
.data-sec{overflow:hidden}
.data-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2.5rem,6vw,5rem);align-items:start}
.data-points{list-style:none;display:flex;flex-direction:column}
.data-points li{padding:1.2rem 0;border-bottom:1px solid var(--line-dark);
  display:flex;gap:1rem;align-items:baseline}
.data-points li:first-child{border-top:1px solid var(--line-dark)}
.data-points i{width:7px;height:7px;background:var(--blue-sky);transform:rotate(45deg);flex:none}
.data-points b{font-family:var(--font-display);font-weight:500;color:var(--t-ondark);font-size:1.02rem}
.data-points span{color:var(--t-ondark-faint);font-size:.88rem}
.ai-line{margin-top:2.6rem;font-family:var(--font-display);font-weight:500;letter-spacing:-.02em;
  font-size:clamp(1.25rem,2.1vw,1.6rem);line-height:1.35;color:var(--t-ondark)}
.ai-line .accent{color:var(--blue)}
.ai-line.on-light{color:var(--t-dark)}
.ticker-band{margin-top:clamp(3.5rem,7vw,5.5rem);border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);padding:1.1rem 0;overflow:hidden;position:relative}
.ticker{display:flex;gap:3.5rem;white-space:nowrap;width:max-content;animation:tick 42s linear infinite}
.ticker span{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;
  color:var(--t-ondark-mid)}
.ticker span b{color:var(--green);font-weight:500}
.ticker span i{color:var(--blue-sky);font-style:normal}
@keyframes tick{to{transform:translateX(-50%)}}
@media(max-width:900px){.data-grid{grid-template-columns:1fr}}

/* ---------- outcomes ---------- */
.out-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.out{background:var(--white);border:1px solid var(--line-light);border-radius:8px;padding:2rem 1.7rem}
.out b{font-family:var(--font-display);font-weight:600;letter-spacing:-.03em;
  font-size:clamp(2rem,3.4vw,2.9rem);display:block;line-height:1.05;color:var(--t-dark)}
.out b .accent{color:var(--blue)}
.out span{display:block;margin-top:.8rem;font-size:.86rem;color:var(--t-mid)}
.out small{display:block;margin-top:1.2rem;font-family:var(--font-mono);font-size:.6rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--t-faint)}
.stat-arrow{height:.44em;width:auto;display:inline-block;color:var(--blue);
  margin:0 .12em;vertical-align:.04em}
@media(max-width:1000px){.out-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.out-grid{grid-template-columns:1fr}}

/* ---------- trust / security (coframe-style living cards) ---------- */
.trust-sec .sec-head{margin-bottom:clamp(2.5rem,5vw,4rem)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.tcard{border:1px solid var(--line-dark);border-radius:10px;background:rgba(255,255,255,.02);
  overflow:hidden;transition:border-color .3s ease,transform .3s ease}
.tcard:hover{border-color:rgba(47,128,237,.5);transform:translateY(-4px)}
.tviz{height:152px;position:relative;display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--line-dark);
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:24px 24px}
.tag-mono{position:absolute;bottom:9px;left:0;right:0;text-align:center;
  font-family:var(--font-mono);font-size:.52rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--t-ondark-faint)}
.tbody{padding:1.15rem 1.3rem 1.35rem}
.tbody h3{color:var(--t-ondark);font-size:1.02rem;margin-bottom:.4rem}
.tbody p{font-size:.82rem;color:var(--t-ondark-mid)}
/* soc2 seal */
.soc-badge{position:relative;width:64px;height:64px;color:var(--blue-sky);
  display:flex;align-items:center;justify-content:center;margin-bottom:.8rem}
.soc-badge svg{width:46px;height:46px}
.soc-ring{position:absolute;inset:0;border:1px solid rgba(86,204,242,.45);border-radius:50%;
  animation:ringpulse 3.2s ease-out infinite}
.soc-ring.r2{animation-delay:1.6s}
@keyframes ringpulse{0%{transform:scale(.68);opacity:.9}100%{transform:scale(1.85);opacity:0}}
/* uptime */
.up-wrap{display:flex;flex-direction:column;align-items:center;gap:.65rem;margin-bottom:.8rem}
.up-bars{display:flex;gap:3px;align-items:flex-end;height:32px}
.up-bars i{width:4px;border-radius:1px;background:var(--green);animation:upflick 2.6s ease-in-out infinite}
@keyframes upflick{0%,100%{opacity:.5}50%{opacity:1}}
.up-num{font-family:var(--font-display);font-weight:600;font-size:1.45rem;
  letter-spacing:-.02em;color:var(--t-ondark)}
/* server rack */
.rack{display:flex;flex-direction:column;gap:5px;margin-bottom:.8rem}
.rack-u{width:128px;height:23px;border:1px solid rgba(255,255,255,.22);border-radius:4px;
  display:flex;align-items:center;gap:5px;padding:0 9px}
.rack-u i{width:5px;height:5px;border-radius:50%;background:var(--green);
  animation:blink 2.2s ease-in-out infinite;flex:none}
.rack-u i.b{background:var(--blue-sky);animation-delay:.8s}
.rack-u .slots{margin-left:auto;display:flex;gap:3px}
.rack-u .slots b{width:11px;height:3px;background:rgba(255,255,255,.18);border-radius:1px}
/* integrations */
.intg{width:100%;height:100%}
.iflow{stroke:rgba(86,204,242,.45);stroke-width:1.2;stroke-dasharray:4 5;
  animation:dashflow 18s linear infinite}
.intg text{font-family:var(--font-mono);font-size:7px;letter-spacing:.1em;
  fill:rgba(255,255,255,.6)}
.intg .ichip{stroke:rgba(255,255,255,.22);fill:rgba(7,12,17,.6)}
@media(max-width:1000px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.trust-grid{grid-template-columns:1fr}}

/* ---------- cta ---------- */
.cta{position:relative;overflow:hidden;text-align:center}
.cta .wrap{position:relative;z-index:2;max-width:860px}
.cta h2{font-size:clamp(2.4rem,5.4vw,4.4rem);margin-bottom:1.4rem}
.cta .lead{margin:0 auto 2.6rem}
.cta-grid-bg{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 70% 90% at 50% 100%,black 20%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 70% 90% at 50% 100%,black 20%,transparent 70%)}
.cta-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
footer{background:var(--ink-900);color:var(--t-ondark-mid);
  border-top:1px solid var(--line-dark);padding:3.5rem 0 2.5rem}
.foot-inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.foot-links{display:flex;gap:2.2rem;flex-wrap:wrap}
.foot-links a{font-size:.85rem;transition:color .2s}
.foot-links a:hover{color:var(--t-ondark)}
.foot-legal{margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--line-dark);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:.68rem;color:var(--t-ondark-faint)}
.foot-legal .links{display:flex;gap:1.6rem}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ==================== subpages shared ==================== */
.nav-links a.on{color:var(--t-ondark)}
.page-hero{position:relative;background:var(--ink-900);color:var(--t-ondark);
  padding-top:10rem;overflow:hidden}
.page-hero .hero-bg-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 0%,black 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 0%,black 30%,transparent 80%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.2rem);margin:1rem 0 1.4rem;max-width:16em}
.page-hero .pad-b{padding-bottom:clamp(3rem,7vw,5.5rem)}
.grad{background:linear-gradient(92deg,#56CCF2 0%,#2D9CDB 45%,#2F80ED 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5.5rem);
  align-items:center;padding:clamp(3rem,6vw,5rem) 0}
.feature + .feature{border-top:1px solid var(--line-light)}
.f-kicker{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue-deep);margin-bottom:1rem}
.feature h2{font-size:clamp(1.7rem,3.2vw,2.6rem);margin-bottom:1.1rem}
.feature .lead{font-size:1.05rem}
.f-points{list-style:none;margin-top:1.5rem}
.f-points li{display:flex;gap:.85rem;align-items:baseline;padding:.5rem 0;
  font-size:.95rem;color:var(--t-mid)}
.f-points i{width:7px;height:7px;background:var(--blue);transform:rotate(45deg);flex:none}
.f-points b{color:var(--t-dark);font-weight:600}
.fstat-row{display:flex;gap:clamp(1.5rem,4vw,3rem);margin-top:2rem;flex-wrap:wrap;
  border-top:1px solid var(--line-light);padding-top:1.5rem}
.fstat b{display:block;font-family:var(--font-display);font-weight:600;font-size:1.5rem;
  letter-spacing:-.02em;color:var(--t-dark)}
.fstat span{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--t-faint)}
@media(max-width:900px){.feature{grid-template-columns:minmax(0,1fr)}.feature>*{min-width:0}.feature.rev .f-visual{order:-1}}
.x-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.xcard{background:var(--white);border:1px solid var(--line-light);border-radius:8px;
  padding:1.8rem 1.6rem;display:flex;flex-direction:column;
  transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.xcard:hover{transform:translateY(-5px);border-color:rgba(47,128,237,.5);
  box-shadow:0 20px 40px -24px rgba(14,24,32,.2)}
.xcard h3{font-size:1.2rem;margin:.9rem 0 .5rem;color:var(--t-dark)}
.xcard p{font-size:.88rem;color:var(--t-mid);margin-bottom:1rem}
.xcard ul{list-style:none;margin-top:auto;border-top:1px solid var(--line-light);padding-top:.9rem}
.xcard li{display:flex;gap:.6rem;align-items:baseline;padding:.28rem 0;
  font-size:.82rem;color:var(--t-mid)}
.xcard li i{width:5px;height:5px;background:var(--blue);transform:rotate(45deg);flex:none}
@media(max-width:1000px){.x-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.x-grid{grid-template-columns:1fr}}
/* contact form */
.cwrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,5rem);align-items:start}
.cform{background:var(--white);border:1px solid var(--line-light);border-radius:10px;
  padding:clamp(1.6rem,3vw,2.4rem);display:flex;flex-direction:column;gap:1.1rem;
  box-shadow:0 36px 70px -40px rgba(14,24,32,.25);
  /* light island on the dark site — keep native controls light */
  color-scheme:light}
.fld{display:flex;flex-direction:column;gap:.45rem}
.fld label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--t-faint)}
.fld input,.fld select,.fld textarea{font-family:var(--font-body);font-size:.95rem;
  color:var(--t-dark);background:var(--paper);border:1px solid var(--line-light);
  border-radius:6px;padding:.75rem .9rem;outline:none;transition:border-color .2s;
  width:100%;min-width:0}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--blue)}
.fld textarea{min-height:110px;resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.consent{font-size:.74rem;color:var(--t-faint);line-height:1.5}
.expect{list-style:none;display:flex;flex-direction:column}
.expect li{display:flex;gap:.9rem;align-items:baseline;padding:1rem 0;
  border-bottom:1px solid var(--line-light);font-size:.95rem;color:var(--t-mid)}
.expect li:first-child{border-top:1px solid var(--line-light)}
.expect i{width:7px;height:7px;background:var(--blue);transform:rotate(45deg);flex:none}
.expect b{color:var(--t-dark)}
@media(max-width:900px){.cwrap{grid-template-columns:1fr}}
/* comparison table */
.cmp{border:1px solid var(--line-dark);border-radius:10px;overflow:hidden}
.cmp-row{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;
  padding:1.1rem 1.4rem;border-bottom:1px solid var(--line-dark);align-items:baseline}
.cmp-row:last-child{border-bottom:none}
.cmp-row.head{background:rgba(255,255,255,.03);font-family:var(--font-mono);
  font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--t-ondark-faint)}
.cmp-row b{font-family:var(--font-display);font-weight:500;color:var(--t-ondark);font-size:.98rem}
.cmp-row p{font-size:.86rem;color:var(--t-ondark-mid)}
.cmp-row.win{background:rgba(47,128,237,.08)}
.cmp-row.win b{color:var(--blue-sky)}
@media(max-width:700px){.cmp-row{grid-template-columns:1fr;gap:.4rem}}
/* commissioning lists */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.duo-card{border:1px solid var(--line-dark);border-radius:10px;padding:1.8rem 1.7rem;
  background:rgba(255,255,255,.02)}
.duo-card h3{color:var(--t-ondark);font-size:1.1rem;margin-bottom:1rem}
.duo-card .tag{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blue-sky);display:block;margin-bottom:.6rem}
.duo-card ol{list-style:none;counter-reset:n}
.duo-card ol li{counter-increment:n;display:flex;gap:.8rem;padding:.45rem 0;
  font-size:.88rem;color:var(--t-ondark-mid)}
.duo-card ol li::before{content:counter(n,decimal-leading-zero);
  font-family:var(--font-mono);font-size:.62rem;color:var(--blue-sky);padding-top:.2rem}
@media(max-width:800px){.duo{grid-template-columns:1fr}}

/* ===== login + app store links ===== */
.nav-login{position:relative;padding-left:1.4rem}
.nav-login::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1px;height:14px;background:var(--line-dark)}
.foot-apps{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}
.foot-apps-label{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--t-ondark-faint);margin-right:.3rem}
.app-btn{display:inline-flex;align-items:center;gap:.55rem;padding:.55rem .95rem;
  border:1px solid var(--line-dark);border-radius:6px;font-family:var(--font-display);
  font-size:.82rem;font-weight:500;color:var(--t-ondark-mid);
  transition:border-color .2s,color .2s}
.app-btn:hover{border-color:var(--t-ondark-mid);color:var(--t-ondark)}
.app-btn svg{width:14px;height:14px;fill:currentColor;flex:none}
@media(max-width:860px){.nav-login{padding-left:0}.nav-login::before{display:none}}

/* ===== photo hero (duotone) ===== */
.photo-hero{position:relative;background:var(--ink-900);color:var(--t-ondark);overflow:hidden;
  display:flex;align-items:flex-end;min-height:clamp(540px,74vh,780px);
  padding:10rem 0 clamp(3rem,6vw,4.5rem)}
.photo-hero .ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.08) brightness(.95)}
.photo-hero .wrap{position:relative;z-index:2}
.photo-hero h1{font-size:clamp(2.4rem,5vw,4.2rem);margin:1rem 0 1.4rem;max-width:15em}
.ph-cap{position:absolute;right:clamp(1rem,4vw,3rem);bottom:1.2rem;z-index:2;
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.5)}
.photo-hero .fb-shade{background:linear-gradient(180deg,rgba(7,12,17,.55) 0%,rgba(7,12,17,.25) 38%,rgba(7,12,17,.9) 82%)}

/* ==================== facility analytics skeleton ==================== */
.fa-tabs{display:flex;gap:1.4rem;padding:.6rem 1.2rem 0;border-bottom:1px solid var(--line-light);background:var(--white);overflow-x:auto}
.fa-tab{font-family:var(--font-body);font-size:.78rem;font-weight:500;color:var(--t-faint);
  padding:.5rem .15rem .6rem;border:none;background:none;cursor:pointer;
  border-bottom:2px solid transparent;white-space:nowrap;transition:color .2s}
.fa-tab:hover{color:var(--t-mid)}
.fa-tab.on{color:var(--blue);border-bottom-color:var(--blue)}
.fa-views{background:#F4F6F7;padding:.9rem;min-height:340px}
.fa-view{display:none;grid-template-columns:repeat(3,1fr);gap:.8rem;align-content:start}
.fa-view.on{display:grid}
.fa-card{background:var(--white);border:1px solid var(--line-light);border-radius:8px;
  padding:.85rem .95rem;font-family:var(--font-mono);min-width:0}
.fa-card.span3{grid-column:1/-1}
.fa-head{display:flex;justify-content:space-between;gap:.6rem;font-size:.58rem;letter-spacing:.1em;
  color:var(--t-dark);text-transform:uppercase;font-weight:500;margin-bottom:.55rem}
.fa-status{font-size:.54rem;white-space:nowrap}
.fa-status.ok{color:#1F9D6B}.fa-status.warn{color:#C77B1B}.fa-status.bad{color:#C44545}
.fa-big{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--t-dark);letter-spacing:-.02em}
.fa-sub{font-size:.52rem;color:var(--t-faint);text-transform:uppercase;letter-spacing:.12em}
.fa-rows{display:flex;flex-direction:column}
.fa-rows > div{display:flex;justify-content:space-between;align-items:center;gap:.6rem;
  padding:.4rem 0;border-bottom:1px solid rgba(14,24,32,.05);font-size:.62rem;color:var(--t-mid)}
.fa-rows > div:last-child{border-bottom:none}
.fa-chip{font-size:.5rem;padding:.16rem .42rem;border-radius:3px;letter-spacing:.06em;
  text-transform:uppercase;white-space:nowrap}
.fa-chip.off{background:rgba(226,92,92,.12);color:#C44545}
.fa-chip.load{background:rgba(31,157,107,.12);color:#1F9D6B}
.fa-chip.empty{background:#EFF2F4;color:var(--t-faint)}
.fa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem .7rem;margin-top:.5rem}
.fa-kv span{display:block;font-size:.5rem;color:var(--t-faint);letter-spacing:.06em;text-transform:uppercase}
.fa-kv b{font-size:.64rem;color:var(--t-dark);font-weight:500}
.fa-kv.hot{background:rgba(226,92,92,.08);outline:1px solid rgba(226,92,92,.3);border-radius:4px;padding:.25rem .35rem}
.fa-kv.hot b{color:#C44545}
.fa-tankrow{display:flex;justify-content:space-between;gap:.8rem;align-items:center}
.fa-tank{width:50px;height:80px;border:1.5px solid #C7D0D6;border-radius:7px;position:relative;
  overflow:hidden;background:#fff;flex:none}
.fa-tank i{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#1D3F6E,#0E2A52)}
.fa-stat{margin-bottom:.55rem}
.fa-stat span{display:block;font-size:.5rem;color:var(--t-faint);letter-spacing:.08em;text-transform:uppercase}
.fa-stat b{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--t-dark)}
.fa-bay-truck{display:flex;flex-direction:column;align-items:center;gap:.45rem;
  padding:.7rem 0 .5rem;color:var(--blue);text-align:center}
.fa-bay-truck svg{width:34px;height:34px}
.fa-bay-truck small{font-size:.56rem;color:var(--t-mid);max-width:20em}
.fa-times{display:flex;gap:1rem;border-top:1px solid rgba(14,24,32,.06);padding-top:.5rem;margin-top:.55rem}
.fa-times div{flex:1}
.fa-times span{display:block;font-size:.48rem;color:var(--t-faint);letter-spacing:.06em;text-transform:uppercase}
.fa-times b{font-size:.66rem;color:var(--t-dark);font-weight:500}
.fa-bar{display:grid;grid-template-columns:110px 1fr 86px;gap:.7rem;align-items:center;
  padding:.34rem 0;font-size:.58rem;color:var(--t-mid)}
.fa-bar .track{height:12px;border-radius:3px;background:#EDF0F2;position:relative;overflow:hidden}
.fa-bar .track i{position:absolute;top:2px;bottom:2px;border-radius:2px;background:rgba(47,128,237,.55);
  outline:1px solid rgba(47,128,237,.7)}
.fa-bar b{color:var(--t-dark);font-weight:500;text-align:right;white-space:nowrap}
.fa-pipe-arrow{display:flex;flex-direction:column;align-items:center;gap:.45rem;padding:1rem 0;color:var(--blue)}
.fa-pipe-arrow .disc{width:44px;height:44px;border-radius:50%;background:rgba(47,128,237,.1);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.fa-warn{display:flex;align-items:center;gap:.4rem;font-size:.54rem;color:#C44545;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:760px){.fa-view{grid-template-columns:1fr}.fa-bar{grid-template-columns:80px 1fr 70px}}

/* ==================== genie verify skeleton ==================== */
.gv{display:grid;grid-template-columns:1fr auto 1.2fr;gap:clamp(1.2rem,3vw,2.2rem);align-items:stretch}
.gv-label{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--t-ondark-faint);display:block;margin-bottom:.7rem}
.gv-arrow{display:flex;align-items:center;justify-content:center;color:var(--blue-sky);
  font-size:1.6rem;animation:blink 2.4s ease-in-out infinite}
.gv-ticket{background:rgba(255,255,255,.02);border:1px solid var(--line-dark);border-radius:10px;
  padding:1.2rem 1.2rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}
.gv-ticket .drawer-head{color:var(--t-ondark)}
.gv-ticket .drawer-label{color:var(--t-ondark-faint)}
.gv-ticket .drawer-val{color:var(--t-ondark)}
.gv-ticket .check-row{border-top-color:var(--line-dark);color:var(--t-ondark-mid)}
.gv-step{opacity:.22;transition:opacity .45s ease}
.gv-step.lit{opacity:1}
.gv-badge{opacity:0;transform:scale(.3);transition:opacity .35s ease,transform .45s cubic-bezier(.2,1.6,.4,1)}
.gv-badge.lit{opacity:1;transform:scale(1)}
.gv-final{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;
  color:var(--blue-sky);border-top:1px solid var(--line-dark);padding-top:.7rem}
@media(max-width:860px){.gv{grid-template-columns:1fr}.gv-arrow{transform:rotate(90deg);padding:.2rem 0}}

/* ===== genie display replica ===== */
.gv-display{background:#23272C;border:none;border-radius:14px;padding:12px 12px 6px;
  display:flex;flex-direction:column;min-height:0;text-align:left;height:auto}
.gvd-screen{background:#ECEBE2;border-radius:5px;overflow:hidden}
.gvd-menu{display:flex;gap:1.1rem;padding:.32rem .65rem;font-family:var(--font-body);
  font-size:.6rem;color:#3a3f44;background:#E2E1D7;border-bottom:1px solid #CFCEC4}
.gvd-menu span:first-child{text-decoration:underline}
.gvd-mac{display:flex;justify-content:space-between;gap:.6rem;padding:.26rem .65rem;
  font-family:var(--font-body);font-size:.5rem;color:#6a6f74;background:#EEEDE4;
  border-bottom:1px solid #CFCEC4;flex-wrap:wrap}
.gvd-main{display:flex;gap:1rem;padding:.9rem .9rem .5rem;align-items:flex-start}
.gvd-left{display:flex;flex-direction:column;flex:none;font-family:Georgia,'Times New Roman',serif}
.gvd-cap-label{font-size:.55rem;font-weight:700;color:#23272C}
.gvd-cap-label em{color:#1F9D6B;font-style:normal}
.gvd-cap{font-size:1.7rem;font-weight:700;color:#15191D;line-height:1.05}
.gvd-run{background:#8FC791;font-size:.54rem;font-weight:700;color:#1d3a1f;
  text-align:center;padding:.12rem .45rem;margin-top:.45rem;border-radius:2px}
.gvd-run-label{font-size:.56rem;font-weight:700;color:#23272C;text-align:center;margin-top:.1rem}
.gvd-read{flex:1;text-align:center;font-family:Georgia,'Times New Roman',serif;padding-top:.3rem}
.gvd-read b{font-weight:700;font-size:clamp(2.1rem,3.6vw,3.1rem);color:#15191D;line-height:1;display:block}
.gvd-read small{font-weight:700;font-size:clamp(1.05rem,1.8vw,1.55rem);color:#15191D}
.gvd-status{display:flex;justify-content:space-between;gap:.5rem;padding:.3rem .65rem;
  font-family:var(--font-body);font-size:.5rem;color:#5c6166;border-top:1px solid #CFCEC4;
  background:#EEEDE4;flex-wrap:wrap}
.gvd-bezel{display:flex;justify-content:space-between;align-items:center;padding:.85rem .35rem .35rem}
.gvd-bezel img{height:20px;opacity:.92}
.gvd-btn{width:22px;height:22px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 35% 35%,#d4d9de,#788089);
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.25)}
/* ===== facility analytics photos ===== */
.fa-photos{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:2.4rem}
.fa-photos figure{position:relative;border-radius:10px;overflow:hidden;
  border:1px solid var(--line-dark);margin:0}
.fa-photos img{width:100%;height:320px;object-fit:cover;display:block}
.fa-photos figcaption{position:absolute;left:.9rem;bottom:.85rem;font-family:var(--font-mono);
  font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.88);
  background:rgba(7,12,17,.6);padding:.38rem .7rem;border-radius:4px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
@media(max-width:760px){.fa-photos{grid-template-columns:1fr}.fa-photos img{height:220px}}

/* ===== accessibility pass: AA contrast + minimum sizes ===== */
.dark .lead,.dark-7 .lead,.hero .lead,.page-hero .lead,.photo-hero .lead{color:var(--t-ondark-mid)}
.tag-mono{font-size:.58rem}
.fstat span{font-size:.62rem}
.stage-captions div{font-size:.66rem}
.hstat span{font-size:.7rem}
.spec span{font-size:.66rem}
.consent{font-size:.8rem}
.ph-cap{font-size:.6rem;color:rgba(255,255,255,.62)}
.foot-apps-label{font-size:.62rem}
.wf .entry{font-size:.64rem}
.foot-legal{font-size:.72rem}

/* ===== integrations orbit diagram ===== */
.orbit{width:100%;height:auto;display:block}
.orbit .o-line{stroke:rgba(14,24,32,.16);stroke-width:1.3}
.orbit .o-chip{fill:var(--white);stroke:rgba(14,24,32,.16);stroke-width:1.2;
  filter:drop-shadow(0 6px 14px rgba(14,24,32,.08))}
.orbit text{font-family:var(--font-mono);font-size:13px;letter-spacing:.08em;fill:#3D4A55}
.orbit .o-dot{fill:var(--blue)}
.orbit .o-dot.sky{fill:#2D9CDB}
.orbit .o-ring{fill:none;stroke:rgba(47,128,237,.4);stroke-width:1.5}
.orbit .o-ring.r2{stroke:rgba(47,128,237,.16)}
.orbit .o-pulse{fill:none;stroke:rgba(47,128,237,.4);stroke-width:1.2;
  transform-origin:center;transform-box:fill-box;animation:pulse 3.4s ease-out infinite}
.orbit .o-pulse.d1{animation-delay:1.7s}
@media(prefers-reduced-motion:reduce){.orbit .o-dot{display:none}.orbit .o-pulse{animation:none}}

/* ---------- portal mock: auto-tour + modernized chrome ---------- */
.browser{border-radius:16px;border:1px solid rgba(14,24,32,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65),0 24px 48px -20px rgba(7,87,164,.16),0 64px 110px -46px rgba(14,24,32,.45)}
.browser-bar{background:linear-gradient(180deg,#F7F9FA,#EDF0F2)}
.browser-bar i:nth-of-type(1){background:#FF5F57}
.browser-bar i:nth-of-type(2){background:#FEBC2E}
.browser-bar i:nth-of-type(3){background:#28C840}
.browser-url{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.06em;color:var(--t-mid);
  width:auto;min-width:min(260px,50%);height:22px;border-radius:11px;padding:0 .7rem}
.browser-url:not(:empty)::after{display:none}
.browser-url:not(:empty)::before{content:"";width:5px;height:5px;border-radius:50%;background:#28C840;
  margin-right:.5rem;flex:none}
.app-rail{background:linear-gradient(180deg,#FAFBFC,#F3F5F7)}
.rail-item{position:relative;overflow:hidden}
.rail-item.on{background:linear-gradient(135deg,rgba(47,128,237,.15),rgba(86,204,242,.10));
  color:var(--blue-deep);box-shadow:inset 0 1px 2px rgba(7,87,164,.08)}
.rail-item.on::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--blue),#56CCF2);transform-origin:left;transform:scaleX(0);
  animation:railProgress 4.8s linear infinite}
.app-rail[data-paused] .rail-item.on::after{animation:none;transform:scaleX(1);opacity:.35}
@keyframes railProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media(prefers-reduced-motion: reduce){.rail-item.on::after{animation:none;transform:scaleX(1)}}

/* de-skeletoned mock data */
.phone-row{display:flex;justify-content:space-between;align-items:baseline}
.phone-row span{font-family:var(--font-mono);font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--t-faint)}
.phone-row b{font-family:var(--font-mono);font-size:.62rem;color:var(--t-dark);font-weight:500}
.fa-op{font-family:var(--font-mono);font-size:.56rem;color:var(--t-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.browser-url{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:62%}

/* ---------- film sections ---------- */
.film-sec .sec-head{display:flex;align-items:flex-end;justify-content:space-between;
  flex-wrap:wrap;gap:1.2rem 2rem;max-width:none;margin-bottom:clamp(2rem,4vw,3rem)}
.film-sec .sec-head h2{margin-bottom:0}
.fs-note{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--t-ondark-faint);white-space:nowrap;padding-bottom:.55rem}
.film-frame{position:relative;border-radius:12px;overflow:hidden;
  border:1px solid var(--line-dark);background:var(--ink-900);
  box-shadow:0 40px 90px rgba(0,0,0,.45)}
.film-frame video{display:block;width:100%;aspect-ratio:16/9;object-fit:cover}
.film-play{position:absolute;inset:0;width:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1.2rem;border:0;cursor:pointer;
  color:var(--white);background:linear-gradient(0deg,rgba(7,12,17,.5),rgba(7,12,17,.12) 55%);
  transition:background .25s ease}
.film-play:hover{background:linear-gradient(0deg,rgba(7,12,17,.62),rgba(7,12,17,.2) 55%)}
.film-play .fp-btn{width:clamp(64px,7vw,88px);height:clamp(64px,7vw,88px);border-radius:50%;
  background:var(--blue);display:flex;align-items:center;justify-content:center;
  box-shadow:0 18px 50px rgba(7,87,164,.55);transition:transform .25s ease,background .25s ease}
.film-play .fp-btn svg{margin-left:5px;width:38%;height:auto}
.film-play:hover .fp-btn{transform:scale(1.08);background:var(--blue-mid)}
.film-play>span:last-child{font-family:var(--font-display);font-weight:500;
  font-size:.95rem;letter-spacing:.02em}
.film-frame.playing .film-play{display:none}

/* =====================================================================
   MOBILE ABBREVIATED VIEW (≤700px)
   Phones get a condensed homepage — teasers that link out instead of
   full subpage content repeated inline. Desktop and tablet untouched.
   Rationale + before/after scroll metrics: MOBILE_AUDIT.md
   ===================================================================== */
@media(max-width:700px){
  /* Tighter section rhythm on phones (all pages) */
  :root{--sec-y:clamp(60px,9vw,160px)}
  /* Shorter reveal travel so the scroll never feels gated (all pages) */
  .reveal{transform:translateY(12px);transition-duration:.45s}

  /* --- Homepage abbreviation: sections that exist verbatim on a subpage
     become teasers (or step aside) and link out instead. --- */
  /* Problem: keep all four pain-point headlines, clamp the prose */
  .home #problem .problem-points p{display:-webkit-box;-webkit-box-orient:vertical;
    -webkit-line-clamp:2;overflow:hidden}
  /* Partnership: keep 01/02/03 + quote, clamp the step prose (full story on /how-we-work) */
  .home #partnership .step p{display:-webkit-box;-webkit-box-orient:vertical;
    -webkit-line-clamp:2;overflow:hidden}
  /* Pillars: headline + proof stat carry it (full prose on /platform) */
  .home #platform .pillar p{display:none}
  /* Control layer diagram: verbatim /platform dupe — pillars + product mock
     already tell this story on the phone */
  .home #how{display:none}
  /* Workflows: lead with the top three entry points; all nine live on /workflows */
  .home #workflows .wf-grid .wf:nth-child(n+4){display:none}
  /* Hardware: one device teaser + the proof photo; full lineup and spec
     tables live on /hardware */
  .home #hardware .hw-grid .hw:nth-child(n+2){display:none}
  .home #hardware .hw .spec,.home #hardware .hw-art,.home #hardware .hw-note{display:none}
  .home #hardware .hw-nav,.home #hardware .hw-count,.home #hardware .hw-dots{display:none}
  /* Data layer: verbatim /platform dupe — outcomes + trust carry the proof here */
  .home #data{display:none}
  /* Trust: keep the claims, drop the decorative visuals */
  .home .trust-sec .tviz{display:none}
}
