/* ============================================================
   RESTROBOT. Agentic hospitality, infrastructure-grade.
   Dark cinematic. One signal accent. Sharp grotesk + mono.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  /* ---- surfaces ---- */
  --bg:        #08080A;
  --bg-1:      #0C0C0F;
  --bg-2:      #121217;
  --line:      rgba(255,255,255,0.08);
  --line-soft: rgba(255,255,255,0.05);

  /* ---- text ---- */
  --fg:   #ECEAE3;
  --fg-2: #9B9AA4;
  --fg-3: #66656F;
  --fg-4: #3E3D46;

  /* ---- signal accent (electric lime, sibling color to Restrobot's orange) ---- */
  --accent:     #C7F22E;
  --accent-hi:  #DBFF5C;
  --accent-dim: #9BC014;
  --accent-rgb: 199,242,46;
  --on-accent:  #10140A;

  /* ---- glass ---- */
  --glass:        rgba(255,255,255,0.035);
  --glass-2:      rgba(255,255,255,0.055);
  --glass-border: rgba(255,255,255,0.09);

  /* ---- type ---- */
  --display: 'Space Grotesk', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  /* ---- motion ---- */
  --ease: cubic-bezier(0.22,0.61,0.36,1);
  --snap: cubic-bezier(0.32,0.72,0,1);

  --maxw: 1200px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
html{ overflow-x:clip; }
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--display);
  font-size:16px;
  line-height:1.55;
  overflow-x:clip;
  position:relative;
}
::selection{ background:rgba(var(--accent-rgb),0.28); color:#fff; }

/* ---------- drifting gradient mesh (fixed, behind everything) ---------- */
.mesh{
  position:fixed; inset:-20%; z-index:-2; pointer-events:none;
  background:
    radial-gradient(38% 42% at 18% 22%, rgba(var(--accent-rgb),0.16), transparent 70%),
    radial-gradient(34% 38% at 82% 30%, rgba(120,90,255,0.10), transparent 70%),
    radial-gradient(46% 50% at 60% 88%, rgba(var(--accent-rgb),0.10), transparent 72%),
    radial-gradient(30% 34% at 30% 78%, rgba(40,160,255,0.07), transparent 70%);
  filter:saturate(1.05);
  animation:meshDrift 34s ease-in-out infinite alternate;
  opacity:.9;
}
@keyframes meshDrift{
  0%  { transform:translate3d(0,0,0) scale(1); }
  50% { transform:translate3d(-3%,2%,0) scale(1.08); }
  100%{ transform:translate3d(3%,-2%,0) scale(1.04); }
}

/* ---------- grain overlay ---------- */
.grain{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
/* faint scanline vignette at very edges */
.vignette{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(120% 120% at 50% 0%, transparent 55%, rgba(0,0,0,0.55) 100%);
}

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
section{ position:relative; }
.eyebrow{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 12px 1px rgba(var(--accent-rgb),0.9); animation:pulseDot 2.4s var(--ease) infinite; }
@keyframes pulseDot{ 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:.4;transform:scale(.7);} }

.kicker{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--fg-3);
}

h1,h2,h3{ font-weight:600; letter-spacing:-0.025em; line-height:1.02; }
h2.section-title{ font-size:clamp(30px,4.4vw,52px); margin-top:14px; }
.lead{ color:var(--fg-2); font-size:clamp(16px,1.4vw,19px); line-height:1.6; max-width:62ch; }

/* ---------- buttons ---------- */
.btn{
  font-family:var(--display); font-size:15px; font-weight:500; letter-spacing:-0.01em;
  display:inline-flex; align-items:center; gap:10px; cursor:pointer;
  padding:13px 22px; border-radius:10px; border:1px solid transparent;
  text-decoration:none; transition:all .2s var(--ease); white-space:nowrap;
}
.btn-primary{
  background:var(--accent); color:var(--on-accent); font-weight:600;
  box-shadow:0 0 0 1px rgba(var(--accent-rgb),.4), 0 8px 30px -6px rgba(var(--accent-rgb),.55);
}
.btn-primary:hover{ background:var(--accent-hi); box-shadow:0 0 0 1px rgba(var(--accent-rgb),.6), 0 10px 42px -4px rgba(var(--accent-rgb),.75); transform:translateY(-1px); }
.btn-primary:active{ transform:translateY(0); }
.btn-ghost{ background:rgba(255,255,255,0.02); color:var(--fg); border-color:var(--line); }
.btn-ghost:hover{ border-color:rgba(var(--accent-rgb),.5); color:#fff; background:rgba(var(--accent-rgb),0.06); }
.btn .ico{ width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.6; }

/* ---------- glass card ---------- */
.glass{
  background:var(--glass); border:1px solid var(--glass-border); border-radius:16px;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  position:relative; overflow:hidden;
}
.glass::before{ /* thin luminous top edge */
  content:""; position:absolute; inset:0 0 auto 0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  opacity:.5;
}
.glass.glow:hover{
  border-color:rgba(var(--accent-rgb),.35);
  box-shadow:inset 0 0 40px -16px rgba(var(--accent-rgb),.4), 0 0 0 1px rgba(var(--accent-rgb),.18);
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50; height:64px;
  display:flex; align-items:center;
  transition:background .3s var(--ease), border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:rgba(8,8,10,0.72); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-color:var(--line-soft); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:18px; letter-spacing:-0.03em; color:#fff; text-decoration:none; }
.brand .glyph{ width:22px; height:22px; display:grid; place-items:center; }
.brand b{ font-weight:600; }
.brand .dot{ color:var(--accent); }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ color:var(--fg-2); text-decoration:none; font-size:14px; transition:color .2s var(--ease); }
.nav-links a:hover{ color:#fff; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
@media(max-width:860px){ .nav-links{ display:none; } }

/* =========================================================
   HERO
   ========================================================= */
.hero{ padding:150px 0 90px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:54px; align-items:center; }
@media(max-width:980px){ .hero-grid{ grid-template-columns:1fr; gap:40px; } }
.hero h1{ font-size:clamp(40px,6.4vw,80px); margin:22px 0 22px; letter-spacing:-0.04em; }
.hero h1 .grad{
  background:linear-gradient(180deg,#fff 30%, var(--accent) 160%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero .lead{ font-size:clamp(17px,1.6vw,21px); max-width:48ch; }
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-meta{ margin-top:30px; display:flex; gap:26px; flex-wrap:wrap; }
.hero-meta div{ font-family:var(--mono); font-size:12px; color:var(--fg-3); letter-spacing:.04em; }
.hero-meta b{ color:var(--fg); font-weight:500; }

/* --- transcript console (hero visual) --- */
.console{
  border-radius:18px; padding:0; min-height:430px; display:flex; flex-direction:column;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.9), 0 0 0 1px var(--glass-border);
}
.console-bar{
  display:flex; align-items:center; gap:8px; padding:13px 16px; border-bottom:1px solid var(--line-soft);
  font-family:var(--mono); font-size:11px; color:var(--fg-3);
}
.console-bar .dots{ display:flex; gap:6px; margin-right:6px; }
.console-bar .dots i{ width:9px; height:9px; border-radius:50%; background:var(--fg-4); display:block; }
.console-bar .live{ margin-left:auto; color:var(--accent); display:flex; align-items:center; gap:6px; }
.console-bar .live::before{ content:""; width:6px;height:6px;border-radius:50%; background:var(--accent); box-shadow:0 0 8px var(--accent); animation:pulseDot 1.6s infinite; }
.transcript{ flex:1; padding:20px 18px; display:flex; flex-direction:column; gap:14px; overflow:hidden; }
.msg{ display:flex; flex-direction:column; gap:5px; opacity:0; transform:translateY(8px); animation:msgIn .5s var(--ease) forwards; }
.msg .who{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--fg-3); }
.msg .bubble{ font-size:15px; line-height:1.5; max-width:90%; padding:10px 14px; border-radius:12px; }
.msg.guest .who{ color:var(--fg-3); }
.msg.guest .bubble{ background:rgba(255,255,255,0.05); color:var(--fg); border-bottom-left-radius:4px; align-self:flex-start; }
.msg.agent .who{ color:var(--accent); }
.msg.agent .bubble{ background:rgba(var(--accent-rgb),0.10); border:1px solid rgba(var(--accent-rgb),0.22); color:#fff; border-bottom-left-radius:4px; align-self:flex-start; }
@keyframes msgIn{ to{ opacity:1; transform:none; } }
.caret{ display:inline-block; width:8px; height:1.05em; background:var(--accent); margin-left:2px; vertical-align:-2px; animation:blink 1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

/* waveform under transcript */
.waveform{ display:flex; align-items:flex-end; gap:3px; height:34px; padding:0 18px 16px; }
.waveform i{ flex:1; background:linear-gradient(180deg,var(--accent),var(--accent-dim)); border-radius:2px; opacity:.65; animation:wave 1.3s ease-in-out infinite; }
@keyframes wave{ 0%,100%{ height:18%; } 50%{ height:90%; } }

/* floating glass chips */
.float{ position:absolute; z-index:3; font-family:var(--mono); font-size:12px; padding:10px 13px; display:flex; align-items:center; gap:9px; border-radius:12px;
  background:rgba(18,18,23,0.72); border:1px solid var(--glass-border); backdrop-filter:blur(10px); box-shadow:0 16px 40px -18px rgba(0,0,0,.8); animation:floaty 6s ease-in-out infinite; }
.float .tick{ width:18px;height:18px;border-radius:50%; display:grid;place-items:center; background:rgba(var(--accent-rgb),.16); }
.float .tick svg{ width:11px;height:11px; stroke:var(--accent); fill:none; stroke-width:2; }
.float small{ color:var(--fg-3); display:block; font-size:10px; letter-spacing:.08em; }
.float b{ color:#fff; font-weight:500; }
.float.f1{ top:-22px; right:-14px; animation-delay:0s; }
.float.f2{ bottom:64px; left:-30px; animation-delay:1.5s; }
.float.f3{ bottom:-18px; right:24px; animation-delay:3s; }
@media(max-width:980px){ .float.f2{ left:-8px; } .float.f1{ right:0; } }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }
.console-wrap{ position:relative; }

/* =========================================================
   THE SHIFT, manifesto strip
   ========================================================= */
.shift{ padding:90px 0; border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
.shift h2{ font-size:clamp(26px,3.4vw,40px); max-width:18ch; letter-spacing:-0.03em; }
.shift h2 em{ font-style:normal; color:var(--accent); }
.beats{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:54px; }
@media(max-width:760px){ .beats{ grid-template-columns:1fr; } }
.beat{ padding:26px 28px; border-left:1px solid var(--line); position:relative; }
.beat:first-child{ border-left:none; padding-left:0; }
@media(max-width:760px){ .beat{ border-left:none; border-top:1px solid var(--line); padding:22px 0; } .beat:first-child{ border-top:none; } }
.beat .n{ font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:.1em; }
.beat p{ font-size:clamp(19px,2vw,24px); margin-top:14px; letter-spacing:-0.02em; line-height:1.2; }
.beat span{ color:var(--fg-2); }

/* =========================================================
   SECTION HEADER (shared)
   ========================================================= */
.sec{ padding:104px 0; }
.sec-head{ max-width: 960px; margin: 0 auto 54px; text-align: center; }
.sec-head .lead{ margin: 18px auto 0; max-width: 56ch; }
.sec-head.center{ text-align: center; }
.sec-head .kicker.cinema{ justify-content: center; }

/* =========================================================
   CAPABILITIES
   ========================================================= */
.caps{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media(max-width:760px){ .caps{ grid-template-columns:1fr; } }
.cap{ padding:30px; display:flex; flex-direction:column; gap:16px; min-height:230px; transition:all .25s var(--ease); }
.cap .cap-ico{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:rgba(var(--accent-rgb),0.10); border:1px solid rgba(var(--accent-rgb),0.2); }
.cap .cap-ico svg{ width:22px; height:22px; stroke:var(--accent); fill:none; stroke-width:1.6; }
.cap h3{ font-size:21px; letter-spacing:-0.02em; }
.cap p{ color:var(--fg-2); font-size:15px; line-height:1.55; }
.cap .chips{ margin-top:auto; display:flex; flex-wrap:wrap; gap:7px; }
.cap .chips span{ font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--fg-2); padding:4px 9px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,0.02); }

/* =========================================================
   THE STACK
   ========================================================= */
.stack{ display:flex; flex-direction:column; gap:14px; max-width:840px; margin:0 auto; }
.layer{ padding:22px 26px; border-radius:14px; position:relative; }
.layer-label{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--fg-3); margin-bottom:14px; }
.layer .nodes{ display:flex; flex-wrap:wrap; gap:10px; }
.node{ display:flex; align-items:center; gap:8px; padding:10px 15px; border-radius:10px; border:1px solid var(--line); background:rgba(255,255,255,0.02); font-size:14px; color:var(--fg); }
.node svg{ width:16px; height:16px; stroke:var(--fg-2); fill:none; stroke-width:1.6; }
.layer.agent{ background:linear-gradient(180deg, rgba(var(--accent-rgb),0.14), rgba(var(--accent-rgb),0.04)); border:1px solid rgba(var(--accent-rgb),0.3); box-shadow:0 0 60px -22px rgba(var(--accent-rgb),0.6); }
.layer.agent .agent-row{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.layer.agent .agent-mark{ width:48px;height:48px;border-radius:12px; background:var(--accent); display:grid;place-items:center; box-shadow:0 0 24px rgba(var(--accent-rgb),.6); flex:none; }
.layer.agent .agent-mark svg{ width:26px;height:26px; stroke:var(--on-accent); fill:none; stroke-width:1.8; }
.layer.agent h3{ font-size:22px; letter-spacing:-0.02em; }
.layer.agent p{ color:var(--fg-2); font-size:14px; }
.stack-connector{ height:26px; display:flex; justify-content:center; }
.stack-connector::before{ content:""; width:1px; background:linear-gradient(var(--line),rgba(var(--accent-rgb),.5)); }

/* =========================================================
   LIVE CONSOLE
   ========================================================= */
.live-grid{ display:grid; grid-template-columns:1.25fr 0.85fr; gap:18px; }
@media(max-width:880px){ .live-grid{ grid-template-columns:1fr; } }
.chat{ display:flex; flex-direction:column; min-height:520px; border-radius:18px; }
.chat-head{ display:flex; align-items:center; gap:10px; padding:16px 20px; border-bottom:1px solid var(--line-soft); font-family:var(--mono); font-size:12px; color:var(--fg-3); }
.chat-head .live{ margin-left:auto; color:var(--accent); display:flex; align-items:center; gap:6px; }
.chat-head .live::before{ content:""; width:6px;height:6px;border-radius:50%; background:var(--accent); box-shadow:0 0 8px var(--accent); animation:pulseDot 1.6s infinite; }
.chat-log{ flex:1; padding:20px; display:flex; flex-direction:column; gap:14px; overflow-y:auto; max-height:420px; }
.chat-log::-webkit-scrollbar{ width:6px; } .chat-log::-webkit-scrollbar-thumb{ background:var(--line); border-radius:3px; }
.chat-form{ display:flex; gap:10px; padding:14px; border-top:1px solid var(--line-soft); }
.chat-form input{ flex:1; background:rgba(255,255,255,0.04); border:1px solid var(--line); border-radius:10px; padding:12px 14px; color:var(--fg); font-family:var(--display); font-size:14px; outline:none; transition:border-color .2s var(--ease); }
.chat-form input:focus{ border-color:rgba(var(--accent-rgb),.6); }
.chat-form button{ flex:none; }
.suggest{ display:flex; gap:8px; padding:0 14px 14px; flex-wrap:wrap; }
.suggest button{ font-family:var(--mono); font-size:11px; color:var(--fg-2); background:rgba(255,255,255,0.02); border:1px solid var(--line); border-radius:999px; padding:6px 12px; cursor:pointer; transition:all .2s var(--ease); }
.suggest button:hover{ border-color:rgba(var(--accent-rgb),.5); color:#fff; }

.reason{ display:flex; flex-direction:column; border-radius:18px; min-height:520px; }
.reason-head{ padding:16px 20px; border-bottom:1px solid var(--line-soft); font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--fg-3); text-transform:uppercase; }
.reason-body{ flex:1; padding:18px 20px; display:flex; flex-direction:column; gap:0; overflow-y:auto; max-height:430px; font-family:var(--mono); font-size:12.5px; }
.reason-body::-webkit-scrollbar{ width:6px; } .reason-body::-webkit-scrollbar-thumb{ background:var(--line); border-radius:3px; }
.trace{ display:flex; gap:11px; padding:11px 0; border-bottom:1px dashed var(--line-soft); opacity:0; transform:translateX(6px); animation:msgIn .4s var(--ease) forwards; }
.trace:last-child{ border-bottom:none; }
.trace .t-ico{ flex:none; width:22px; height:22px; border-radius:6px; display:grid; place-items:center; background:rgba(var(--accent-rgb),.12); margin-top:1px; }
.trace .t-ico svg{ width:13px;height:13px; stroke:var(--accent); fill:none; stroke-width:1.8; }
.trace .t-body b{ color:var(--fg); font-weight:500; display:block; letter-spacing:.02em; }
.trace .t-body span{ color:var(--fg-3); }
.reason-foot{ padding:14px 20px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; color:var(--fg-3); }
.reason-foot b{ color:var(--accent); }

.typing{ display:inline-flex; gap:4px; align-items:center; }
.typing i{ width:6px;height:6px;border-radius:50%; background:var(--accent); animation:wave 1s infinite; }
.typing i:nth-child(2){ animation-delay:.15s; } .typing i:nth-child(3){ animation-delay:.3s; }

/* =========================================================
   TELEMETRY
   ========================================================= */
.tele{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
@media(max-width:760px){ .tele{ grid-template-columns:repeat(2,1fr); } }
.metric{ padding:48px 28px; border-left:1px solid var(--line-soft); }
.metric:first-child{ border-left:none; }
@media(max-width:760px){ .metric:nth-child(odd){ border-left:none; } .metric:nth-child(n+3){ border-top:1px solid var(--line-soft); } }
.metric .val{ font-family:var(--mono); font-weight:600; font-size:clamp(34px,4.5vw,54px); letter-spacing:-0.03em; color:#fff; line-height:1; }
.metric .val .u{ color:var(--accent); }
.metric .lbl{ margin-top:14px; color:var(--fg-2); font-size:14px; }

/* =========================================================
   DEPLOYMENTS
   ========================================================= */
.logos{ display:flex; flex-wrap:wrap; gap:14px 44px; align-items:center; justify-content:center; padding:8px 0; }
.logos .logo{ font-family:var(--display); font-weight:600; font-size:21px; letter-spacing:-0.02em; color:var(--fg-3); opacity:.8; transition:color .2s var(--ease), opacity .2s; display:flex; align-items:center; gap:8px; }
.logos .logo:hover{ color:var(--fg); opacity:1; }
.logos .logo svg{ width:18px;height:18px; stroke:currentColor; fill:none; stroke-width:1.5; }
.deploy-note{ text-align:center; color:var(--fg-3); font-family:var(--mono); font-size:12px; letter-spacing:.06em; margin-bottom:34px; }

/* =========================================================
   PRICING
   ========================================================= */
.toggle{ display:inline-flex; align-items:center; gap:0; padding:4px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,0.02); font-family:var(--mono); font-size:13px; }
.toggle button{ background:none; border:none; color:var(--fg-2); padding:8px 18px; border-radius:999px; cursor:pointer; transition:all .2s var(--ease); font-family:var(--mono); }
.toggle button.on{ background:var(--accent); color:var(--on-accent); font-weight:600; }
.toggle .save{ color:var(--accent); margin-left:4px; font-size:11px; }
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px; }
@media(max-width:860px){ .tiers{ grid-template-columns:1fr; } }
.tier{ padding:32px; display:flex; flex-direction:column; gap:8px; }
.tier.feat{ border-color:rgba(var(--accent-rgb),.4); box-shadow:0 0 60px -26px rgba(var(--accent-rgb),.7); }
.tier .badge{ position:absolute; top:18px; right:18px; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); border:1px solid rgba(var(--accent-rgb),.4); border-radius:999px; padding:4px 10px; }
.tier .t-name{ font-family:var(--mono); font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--fg-2); }
.tier .price{ font-size:46px; font-weight:600; letter-spacing:-0.03em; color:#fff; display:flex; align-items:baseline; gap:6px; margin:6px 0; }
.tier .price .per{ font-family:var(--mono); font-size:13px; color:var(--fg-3); font-weight:400; }
.tier .price.enter{ font-size:34px; }
.tier .t-desc{ color:var(--fg-2); font-size:14px; min-height:42px; }
.tier ul{ list-style:none; margin:18px 0 24px; display:flex; flex-direction:column; gap:11px; }
.tier li{ display:flex; gap:10px; align-items:flex-start; font-size:14px; color:var(--fg); }
.tier li svg{ width:16px;height:16px; flex:none; stroke:var(--accent); fill:none; stroke-width:2; margin-top:3px; }
.tier .btn{ margin-top:auto; justify-content:center; width:100%; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ max-width:840px; margin:0 auto; border-top:1px solid var(--line-soft); }
.qa{ border-bottom:1px solid var(--line-soft); }
.qa button{ width:100%; text-align:left; background:none; border:none; color:var(--fg); padding:24px 0; font-family:var(--display); font-size:clamp(17px,1.8vw,20px); font-weight:500; letter-spacing:-0.02em; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:20px; }
.qa .pm{ flex:none; width:22px; height:22px; position:relative; transition:transform .3s var(--ease); }
.qa .pm::before,.qa .pm::after{ content:""; position:absolute; background:var(--accent); border-radius:1px; }
.qa .pm::before{ top:50%; left:0; right:0; height:1.5px; transform:translateY(-50%); }
.qa .pm::after{ left:50%; top:0; bottom:0; width:1.5px; transform:translateX(-50%); transition:opacity .3s var(--ease); }
.qa.open .pm::after{ opacity:0; }
.qa .ans{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.qa .ans p{ padding-bottom:24px; color:var(--fg-2); font-size:15px; line-height:1.65; max-width:70ch; }
.qa.open .ans{ max-height:240px; }

/* =========================================================
   FOOTER, terminal
   ========================================================= */
.footer{ border-top:1px solid var(--line-soft); padding:72px 0 40px; font-family:var(--mono); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
@media(max-width:760px){ .foot-grid{ grid-template-columns:1fr; gap:32px; } }
.foot-cta h3{ font-family:var(--display); font-size:clamp(24px,3vw,34px); letter-spacing:-0.03em; margin-bottom:8px; }
.foot-cta p{ color:var(--fg-3); font-size:13px; margin-bottom:18px; }
.terminal{ display:flex; align-items:center; gap:10px; background:#0A0A0C; border:1px solid var(--line); border-radius:10px; padding:13px 15px; max-width:420px; }
.terminal .prompt{ color:var(--accent); font-size:13px; }
.terminal input{ flex:1; background:none; border:none; color:var(--fg); font-family:var(--mono); font-size:13px; outline:none; }
.terminal input::placeholder{ color:var(--fg-4); }
.terminal .tcaret{ width:8px; height:15px; background:var(--accent); animation:blink 1s steps(1) infinite; }
.terminal button{ background:none; border:none; color:var(--accent); cursor:pointer; font-family:var(--mono); font-size:13px; }
.foot-col h4{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--fg-3); margin-bottom:16px; font-weight:500; }
.foot-col a{ display:block; color:var(--fg-2); text-decoration:none; font-size:13px; padding:5px 0; transition:color .2s var(--ease); }
.foot-col a:hover{ color:var(--accent); }
.foot-bottom{ margin-top:56px; padding-top:24px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:11px; color:var(--fg-4); letter-spacing:.04em; }
.foot-bottom .brand-sm{ color:var(--fg-2); }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.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; }

/* =========================================================
   CUSTOM CURSOR + MAGNETIC CTAs
   ========================================================= */
.cursor-dot, .cursor-ring{
  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%); will-change:transform, width, height;
}
.cursor-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 14px var(--accent), 0 0 30px rgba(var(--accent-rgb),.6); }
.cursor-ring{ width:36px; height:36px; border:1px solid rgba(var(--accent-rgb),.65);
  border-radius:50%;
  transition:width .25s var(--ease), height .25s var(--ease),
    background .25s var(--ease), border-color .25s var(--ease); }
.cursor-ring.hot{ width:62px; height:62px; background:rgba(var(--accent-rgb),.08);
  border-color:rgba(var(--accent-rgb),.9); }
[data-magnetic]{ transition:transform .25s var(--ease); will-change:transform; }
@media(max-width:980px), (pointer:coarse){
  .cursor-dot, .cursor-ring{ display:none; }
}

/* =========================================================
   BACKGROUND PARTICLE CANVAS
   ========================================================= */
.bg-canvas{
  position:fixed; inset:0; z-index:-3; pointer-events:none; opacity:.55;
}

/* =========================================================
   AURORA OVERLAY
   ========================================================= */
.aurora{
  position:fixed; top:-180px; left:0; right:0; height:560px; z-index:-1;
  pointer-events:none; opacity:.55;
  background:
    radial-gradient(58% 70% at 18% 50%, rgba(var(--accent-rgb),.18), transparent 60%),
    radial-gradient(50% 70% at 82% 30%, rgba(120,90,255,.15), transparent 60%);
  filter:blur(60px);
  animation:auroraDrift 26s ease-in-out infinite alternate;
}
@keyframes auroraDrift{
  0%   { transform:translate3d(-4%,0,0) scale(1); }
  100% { transform:translate3d(4%,2%,0) scale(1.1); }
}

/* =========================================================
   TOP LIVE-NETWORK TICKER
   ========================================================= */
.ticker{
  position:fixed; top:0; left:0; right:0; z-index:49; height:34px;
  background:rgba(8,8,10,0.82);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft); overflow:hidden;
  display:flex; align-items:center;
}
.ticker::before{
  content:"LIVE NETWORK"; flex:none;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.18em;
  color:var(--accent); padding:0 18px; border-right:1px solid var(--line-soft);
  height:100%; display:flex; align-items:center;
  background: #0A0A0D;
  position: relative;
  z-index: 2;
}
.ticker-track{
  display:inline-flex; gap:48px; white-space:nowrap;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.04em;
  color:var(--fg-2); padding-left:28px;
  animation:tickerFlow 60s linear infinite;
}
.ticker-item{ display:inline-flex; align-items:center; gap:10px; }
.ticker-item .tdot{
  width:5px; height:5px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 8px var(--accent); flex:none;
}
.ticker-item b{ color:var(--fg); font-weight:500; }
.ticker-item .tms{ color:var(--accent); }
@keyframes tickerFlow{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}
body.with-ticker .nav{ top:34px; }
body.with-ticker .hero{ padding-top:170px; }

/* =========================================================
   PHONE-RING PULSE on console-bar
   ========================================================= */
.ph{ position:relative; width:18px; height:18px; display:inline-flex;
  align-items:center; justify-content:center; }
.ph::before, .ph::after{
  content:""; position:absolute; inset:-5px;
  border:1px solid rgba(var(--accent-rgb),.55); border-radius:50%;
  animation:phRing 2.2s ease-out infinite;
}
.ph::after{ animation-delay:1.1s; }
@keyframes phRing{
  0%   { transform:scale(.45); opacity:1; }
  100% { transform:scale(1.7); opacity:0; }
}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  overflow:hidden; padding:26px 0;
  border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);
  background:linear-gradient(180deg, rgba(var(--accent-rgb),.02), transparent);
}
.marquee-track{
  display:inline-flex; gap:54px; white-space:nowrap;
  font-family:var(--display); font-weight:600;
  font-size:clamp(26px,3.2vw,42px); letter-spacing:-0.025em;
  color:var(--fg-3);
  animation:mqFlow 38s linear infinite;
}
.marquee-track .mq{ display:inline-flex; align-items:center; gap:54px; }
.marquee-track .mq::after{
  content:""; width:9px; height:9px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 14px var(--accent); flex:none;
}
.marquee-track .hi{ color:var(--accent); font-style:italic; }
@keyframes mqFlow{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}

/* =========================================================
   3D TILT CAPABILITY CARDS
   parent gets perspective; cards rotate in 2D-transformed space
   (no preserve-3d, no translateZ, keeps backdrop-filter compositing happy)
   ========================================================= */
.caps{ perspective:1200px; perspective-origin:50% 50%; }
.tilt{
  will-change:transform;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.tilt::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),
    rgba(var(--accent-rgb),.22), transparent 60%);
  opacity:0; transition:opacity .25s var(--ease); z-index:1;
}
.tilt:hover::after{ opacity:1; }

/* =========================================================
   LIVE OPS DASHBOARD
   ========================================================= */
.ops-head{
  display:flex; align-items:center; gap:14px;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--fg-3);
  margin-bottom:8px;
}
.ops-head .now{ color:var(--accent); display:inline-flex; align-items:center; gap:6px; }
.ops-head .now::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 8px var(--accent);
  animation:pulseDot 1.6s infinite;
}
.ops-grid{ display:grid; grid-template-columns:1.25fr 0.85fr; gap:18px; margin-top:36px; }
@media(max-width:880px){ .ops-grid{ grid-template-columns:1fr; } }
.ops-panel{ padding:24px; border-radius:18px; }
.sparkrow{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.spark{
  padding:16px; border-radius:12px; border:1px solid var(--line-soft);
  background:rgba(255,255,255,0.015);
  position:relative; overflow:hidden;
}
.spark .lbl{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--fg-3);
}
.spark .val{
  font-family:var(--mono); font-weight:600; font-size:24px;
  color:#fff; margin-top:4px; display:flex; align-items:baseline; gap:5px;
  letter-spacing:-0.02em;
}
.spark .val .u{ color:var(--accent); font-size:13px; font-weight:500; }
.spark .delta{
  font-family:var(--mono); font-size:10.5px; color:var(--accent);
  margin-top:2px;
}
.spark svg.chart{ width:100%; height:46px; margin-top:10px; display:block; }
.spark .line{ stroke:var(--accent); stroke-width:1.6; fill:none; stroke-linejoin:round; }
.spark .fill{ opacity:.32; stroke:none; }
.spark .dot{ fill:var(--accent); }

.event-feed{
  display:flex; flex-direction:column; gap:10px; margin-top:16px;
}
.event{
  display:flex; align-items:center; gap:11px;
  padding:12px 14px; border-radius:10px;
  background:rgba(255,255,255,0.02); border:1px solid var(--line-soft);
  font-family:var(--mono); font-size:12px;
  opacity:0; transform:translateY(-6px);
  animation:eventIn .35s var(--ease) forwards;
}
.event .e-ico{
  width:24px; height:24px; border-radius:7px; flex:none;
  display:grid; place-items:center; background:rgba(var(--accent-rgb),.14);
}
.event .e-ico svg{ width:13px; height:13px; stroke:var(--accent); fill:none; stroke-width:1.8; }
.event .e-body{ flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.event .e-body b{ color:var(--fg); font-weight:500; }
.event .e-body .e-sub{ color:var(--fg-3); margin-left:6px; }
.event .e-time{ color:var(--fg-3); font-size:10.5px; flex:none; }
@keyframes eventIn{ to{ opacity:1; transform:none; } }

/* world map blip panel */
.world{
  position:relative; width:100%; aspect-ratio:2.1/1; margin-top:14px;
  border-radius:12px; border:1px solid var(--line-soft); overflow:hidden;
  background:radial-gradient(60% 70% at 50% 50%, rgba(var(--accent-rgb),.06), transparent 70%);
}
.world svg{ position:absolute; inset:0; width:100%; height:100%; }
.world .dotmap circle{
  fill:var(--fg-4); opacity:.55;
}
.world .blip{
  fill:var(--accent); opacity:0;
}
.world .blip.on{ animation:blipPulse 1.4s ease-out forwards; }
@keyframes blipPulse{
  0%   { opacity:1; r:1; filter:drop-shadow(0 0 0 var(--accent)); }
  40%  { opacity:1; r:5; filter:drop-shadow(0 0 8px var(--accent)); }
  100% { opacity:0; r:12; filter:drop-shadow(0 0 0 transparent); }
}

/* latency gauge bar */
.gauge{
  display:flex; flex-direction:column; gap:10px; padding:14px;
  border-radius:12px; border:1px solid var(--line-soft);
  background:rgba(255,255,255,0.015); margin-top:14px;
}
.gauge .grow{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--fg-3);
  display:flex; justify-content:space-between;
}
.gauge .grow b{ color:var(--accent); }
.gauge .bar{
  height:6px; border-radius:99px; background:rgba(255,255,255,0.04);
  position:relative; overflow:hidden;
}
.gauge .bar i{
  position:absolute; inset:0 auto 0 0; width:42%;
  background:linear-gradient(90deg, var(--accent-dim), var(--accent), var(--accent-hi));
  border-radius:99px;
  box-shadow:0 0 12px rgba(var(--accent-rgb),.6);
  transition:width .8s var(--ease);
}

/* =========================================================
   PRICING. Holographic cursor shine
   ========================================================= */
.tier{ position:relative; overflow:hidden; }
.tier::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,0%),
    rgba(255,255,255,.08), transparent 55%);
  opacity:0; transition:opacity .25s var(--ease);
}
.tier:hover::after{ opacity:1; }

/* =========================================================
   SCRAMBLE-TEXT helper (keep dimensions stable)
   ========================================================= */
.scramble{ min-height:1em; }
.scramble .sb{ color:var(--accent); opacity:.7; }

/* =========================================================
   FUTURISTIC OVERHAUL
   massive type, char-split color cascade, notch dividers,
   odometer counters, path-line backgrounds, manifesto
   ========================================================= */

/* ---- Character split with color cascade ---- */
@keyframes splitCascade{
  0%   { color: var(--fg-4); transform: translateY(2px); }
  35%  { color: var(--accent); transform: translateY(-1px); }
  100% { color: var(--fg); transform: translateY(0); }
}
h1.splittext, h2.splittext, h3.splittext{ display:block; }
.splittext .ch{
  display: inline-block;
  color: var(--fg-4);
  will-change: color, transform;
}
.splittext.in .ch{
  animation: splitCascade .9s var(--ease) forwards;
  animation-delay: var(--cd, 0s);
}
.splittext.grad.in .ch{
  background: linear-gradient(180deg, #fff 30%, var(--accent) 160%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: splitFade .8s var(--ease) forwards;
}
@keyframes splitFade{
  0% { opacity: 0; transform: translateY(8px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* ---- Massive typography upgrades ---- */
h1.huge{
  font-size: clamp(48px, 6.4vw, 96px);
  letter-spacing: -0.045em;
  line-height: 0.94;
  font-weight: 600;
}
.section-title.mega{
  font-size: clamp(40px, 6.4vw, 92px);
  letter-spacing: -0.045em;
  line-height: 0.98;
  font-weight: 600;
}
/* sec-head.center now declared above with sec-head */

/* ---- Cinematic kicker ---- */
.kicker.cinema{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-2);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.kicker.cinema::before{
  content: "";
  width: 24px;
  height: 1px;
  background: var(--accent);
  display: inline-block;
}

/* ---- Notch separators between sections ---- */
.notch{
  position: relative;
  height: 36px;
  background: transparent;
  pointer-events: none;
  z-index: 5;
}
.notch::before{
  content: "";
  position: absolute;
  top: -1px;
  left: 50%;
  width: 380px;
  height: 36px;
  background: var(--bg);
  border-radius: 0 0 20px 20px;
  border-bottom: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  transform: translateX(-50%);
}
.notch::after{
  content: "";
  position: absolute;
  top: 16px;
  left: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent);
  transform: translateX(-50%);
  animation: pulseDot 2.4s var(--ease) infinite;
}

/* ---- Odometer counters ---- */
.odo-wrap{
  display: inline-flex;
  font-family: var(--mono);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  line-height: 1;
  align-items: baseline;
}
.odo-col{
  display: inline-block;
  height: 1em;
  overflow: hidden;
  position: relative;
  vertical-align: top;
}
.odo-stack{
  display: flex;
  flex-direction: column;
  transition: transform 1.6s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: transform;
}
.odo-stack span{
  display: block;
  height: 1em;
  line-height: 1;
}

/* ---- Path-line subtle SVG backgrounds (between sections) ---- */
.pathlines{
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.45;
  z-index: 0;
}
.pathlines svg{ width: 100%; height: 100%; display: block; }
.pathlines path.fade{
  stroke: var(--line);
  stroke-width: 1;
  fill: none;
}
.pathlines path.live{
  stroke: rgba(var(--accent-rgb), 0.55);
  stroke-width: 1;
  fill: none;
  stroke-dasharray: 4 8;
  animation: pathFlow 28s linear infinite;
}
@keyframes pathFlow{
  to { stroke-dashoffset: -240; }
}

/* ---- Cinematic manifesto section ---- */
.manifesto{
  position: relative;
  padding: 200px 0 220px;
  text-align: center;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  overflow: hidden;
}
.manifesto-eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  display: block;
  margin-bottom: 32px;
}
.manifesto h2{
  font-size: clamp(40px, 7.2vw, 112px);
  letter-spacing: -0.05em;
  line-height: 0.95;
  font-weight: 600;
  max-width: 16ch;
  margin: 0 auto;
  color: var(--fg);
}
.manifesto h2 em{
  font-style: normal;
  color: var(--accent);
}

/* ---- Tighter section rhythm with the new notches ---- */
.sec.with-notch{ padding-top: 120px; }

/* ---- Big stat row in hero ---- */
.hero-stats{
  margin-top: 44px;
  display: flex;
  gap: 56px;
  flex-wrap: wrap;
}
.hero-stats .stat{
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hero-stats .stat .v{
  font-family: var(--mono);
  font-weight: 600;
  font-size: clamp(22px, 2.4vw, 34px);
  color: var(--fg);
  letter-spacing: -0.02em;
}
.hero-stats .stat .v .u{
  color: var(--accent);
  font-size: 0.55em;
  margin-left: 4px;
}
.hero-stats .stat .l{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-3);
}

/* ---- Disable the old scramble look ---- */
.scramble .sb{ display: none; }

/* ---- Shift section cinematic upgrade ---- */
.shift{ padding: 180px 0; }
.shift h2{
  font-size: clamp(40px, 6.8vw, 108px);
  letter-spacing: -0.045em;
  line-height: 0.98;
  font-weight: 600;
  max-width: 16ch;
  margin: 0 auto;
  text-align: center;
}
.beats{ max-width: 1100px; margin: 120px auto 0; }

/* ---- Hero h1 spacing for huge type ---- */
.hero h1.huge{ margin: 28px 0 32px; }
.hero .lead{ font-size: clamp(18px, 1.6vw, 22px); max-width: 52ch; line-height: 1.55; }
.hero{ padding: 180px 0 140px; }
body.with-ticker .hero{ padding-top: 200px; }

/* =========================================================
   YOS-STYLE LETTER REVEAL (sticky scroll, letters scale)
   ========================================================= */
.yos-reveal{
  position: relative;
  height: 260vh;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}
.yos-reveal-bg{
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(45% 50% at 50% 50%, rgba(var(--accent-rgb), 0.10), transparent 70%),
    radial-gradient(60% 50% at 50% 100%, rgba(var(--accent-rgb), 0.06), transparent 70%);
  z-index: 0;
}
.yos-sticky{
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 30px;
  text-align: center;
  overflow: hidden;
  z-index: 1;
}
.yos-eyebrow{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.yos-eyebrow.in{ opacity: 1; transform: none; }
.yos-eyebrow::before{
  content: "";
  width: 32px;
  height: 1px;
  background: var(--accent);
}
.yos-title{
  display: inline-flex;
  font-family: var(--display);
  font-size: 92px;
  font-weight: 700;
  letter-spacing: -0.06em;
  line-height: 1;
  color: var(--fg);
  will-change: font-size, letter-spacing;
  white-space: nowrap;
}
.yos-title .ltr{
  display: inline-block;
  opacity: 0.18;
  transition: opacity .35s var(--ease);
}
.yos-title .ltr.on{ opacity: 1; }
.yos-title .ltr.dot{ color: var(--accent); }
.yos-sub{
  font-family: var(--mono);
  font-size: 13px;
  color: var(--fg-3);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.yos-sub.in{ opacity: 1; transform: none; }
.yos-progress{
  position: absolute;
  bottom: 48px;
  left: 50%;
  transform: translateX(-50%);
  width: 240px;
  height: 1px;
  background: var(--line);
}
.yos-progress i{
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  width: 100%;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(var(--p, 0));
  transition: transform .08s linear;
  box-shadow: 0 0 8px var(--accent);
}
.yos-progress::before{
  content: "0" counter(yos-counter, decimal);
  position: absolute;
  bottom: 14px;
  left: 0;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--fg-3);
  letter-spacing: 0.14em;
}
.yos-progress::after{
  content: "scroll";
  position: absolute;
  bottom: 14px;
  right: 0;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--accent);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* =========================================================
   STICKY-SCROLL CAPABILITY EXPLORER
   left: scrolling features list, right: sticky media that swaps
   ========================================================= */
.cap-explorer{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  position: relative;
  margin-top: 80px;
}
@media (max-width: 880px){
  .cap-explorer{ grid-template-columns: 1fr; gap: 24px; }
}
.cap-track{
  display: flex;
  flex-direction: column;
  gap: 0;
}
.cap-slide{
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: 50px 0;
  position: relative;
}
@media (max-width: 880px){
  .cap-slide{ min-height: auto; padding: 30px 0; }
}
.cap-slide .ce-num{
  font-family: var(--mono);
  font-size: 13px;
  color: var(--accent);
  letter-spacing: 0.14em;
  font-weight: 500;
}
.cap-slide h3{
  font-size: clamp(28px, 3.4vw, 52px);
  letter-spacing: -0.035em;
  line-height: 1.04;
  font-weight: 600;
  max-width: 14ch;
}
.cap-slide p{
  color: var(--fg-2);
  font-size: 16px;
  max-width: 38ch;
  line-height: 1.6;
}
.cap-slide .ce-chips{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.cap-slide .ce-chips span{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-2);
  padding: 6px 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.02);
  letter-spacing: 0.02em;
}
.cap-slide.active h3{ color: var(--fg); }
.cap-slide:not(.active) h3{ color: var(--fg-3); transition: color .4s var(--ease); }
.cap-slide:not(.active) p{ color: var(--fg-3); transition: color .4s var(--ease); opacity: 0.7; }

.cap-stage{
  position: sticky;
  top: 100px;
  height: 70vh;
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  overflow: hidden;
  background:
    radial-gradient(70% 70% at 50% 0%, rgba(var(--accent-rgb), 0.12), transparent 70%),
    var(--glass);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
@media (max-width: 880px){
  .cap-stage{ position: relative; top: 0; height: 320px; margin-bottom: 40px; }
}
.cap-stage::before{
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  opacity: 0.6;
}
.cap-stage .ce-bar{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--line-soft);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.cap-stage .ce-bar b{ color: var(--accent); font-weight: 600; }
.ce-vis{
  position: absolute;
  inset: 50px 0 0 0;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: scale(0.96);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
  padding: 40px;
}
.ce-vis.active{ opacity: 1; transform: scale(1); }

/* visual 1: phone ring */
.ce-vis-ring{
  position: relative;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  display: grid;
  place-items: center;
}
.ce-vis-ring::before, .ce-vis-ring::after, .ce-vis-ring span.r{
  content: "";
  position: absolute;
  inset: 0;
  border: 1.5px solid rgba(var(--accent-rgb), 0.6);
  border-radius: 50%;
  animation: yosRing 2.4s ease-out infinite;
}
.ce-vis-ring::after{ animation-delay: 0.8s; }
.ce-vis-ring span.r{ animation-delay: 1.6s; display: block; }
.ce-vis-ring .core{
  width: 80px; height: 80px;
  border-radius: 50%;
  background: linear-gradient(180deg, var(--accent), var(--accent-dim));
  display: grid;
  place-items: center;
  box-shadow: 0 0 40px var(--accent);
  position: relative;
  z-index: 2;
}
.ce-vis-ring .core svg{ width: 30px; height: 30px; stroke: var(--on-accent); fill: none; stroke-width: 2; }
@keyframes yosRing{
  0%   { transform: scale(0.45); opacity: 1; }
  100% { transform: scale(1.2); opacity: 0; }
}
.ce-vis .ce-stats{
  position: absolute;
  bottom: 30px;
  left: 30px;
  right: 30px;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.06em;
}
.ce-vis .ce-stats b{ color: var(--accent); font-weight: 500; }

/* visual 2: menu intelligence (allergen tags swirl) */
.ce-vis-menu{
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 360px;
}
.ce-vis-menu .row{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  font-family: var(--mono);
  font-size: 12px;
  color: var(--fg);
}
.ce-vis-menu .row .dish{ flex: 1; color: var(--fg); }
.ce-vis-menu .row .tag{
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 10px;
  letter-spacing: 0.08em;
}
.ce-vis-menu .row .tag.gf{ background: rgba(var(--accent-rgb), 0.15); color: var(--accent); }
.ce-vis-menu .row .tag.v{ background: rgba(120, 200, 120, 0.15); color: rgb(120, 200, 120); }
.ce-vis-menu .row .tag.x{ background: rgba(255, 100, 100, 0.12); color: rgb(255, 130, 130); text-decoration: line-through; }
.ce-vis-menu .row.dim{ opacity: 0.35; }

/* visual 3: POS sync flow */
.ce-vis-pos{
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  max-width: 400px;
}
.ce-vis-pos .pos-row{
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  background: rgba(255,255,255,0.02);
  font-family: var(--mono);
  font-size: 12px;
}
.ce-vis-pos .pos-row .badge{
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 5px;
  background: rgba(var(--accent-rgb), 0.15);
  color: var(--accent);
  letter-spacing: 0.08em;
}
.ce-vis-pos .pos-row .arrow{
  color: var(--accent);
  font-size: 16px;
  animation: posArrow 1.4s var(--ease) infinite;
}
@keyframes posArrow{
  0%, 100% { transform: translateX(0); opacity: 0.4; }
  50% { transform: translateX(4px); opacity: 1; }
}
.ce-vis-pos .pos-row .name{ flex: 1; color: var(--fg); }
.ce-vis-pos .pos-row.confirm{ background: rgba(var(--accent-rgb), 0.08); border-color: rgba(var(--accent-rgb), 0.3); }

/* visual 4: guest memory card */
.ce-vis-guest{
  width: 100%;
  max-width: 340px;
  padding: 22px;
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  background: rgba(255,255,255,0.03);
}
.ce-vis-guest .gv-head{
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.ce-vis-guest .gv-avi{
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-dim));
  display: grid;
  place-items: center;
  font-family: var(--mono);
  font-weight: 600;
  color: var(--on-accent);
  font-size: 16px;
}
.ce-vis-guest .gv-name{ font-weight: 600; color: var(--fg); font-size: 15px; }
.ce-vis-guest .gv-meta{ font-family: var(--mono); font-size: 11px; color: var(--fg-3); }
.ce-vis-guest .gv-vip{ margin-left: auto; font-size: 10px; color: var(--accent); background: rgba(var(--accent-rgb), 0.15); padding: 4px 8px; border-radius: 5px; letter-spacing: 0.1em; }
.ce-vis-guest .gv-rows{ display: flex; flex-direction: column; gap: 8px; font-family: var(--mono); font-size: 11.5px; }
.ce-vis-guest .gv-row{ display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px dashed var(--line-soft); }
.ce-vis-guest .gv-row:last-child{ border-bottom: none; }
.ce-vis-guest .gv-row span:first-child{ color: var(--fg-3); }
.ce-vis-guest .gv-row span:last-child{ color: var(--fg); }

/* =========================================================
   MEGA CTA pre-footer
   ========================================================= */
.mega-cta{
  padding: 140px 0;
  text-align: center;
  position: relative;
  border-top: 1px solid var(--line-soft);
}
.mega-cta h2{
  font-size: clamp(40px, 7vw, 116px);
  font-weight: 600;
  letter-spacing: -0.05em;
  line-height: 0.96;
  max-width: 18ch;
  margin: 0 auto;
}
.mega-cta h2 em{ font-style: normal; color: var(--accent); }
.mega-cta .mega-actions{
  margin-top: 56px;
  display: inline-flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

/* ---- Telemetry values for odometer ---- */
.metric .val{
  font-family: var(--mono);
  font-weight: 600;
  font-size: clamp(38px, 5.2vw, 64px);
  letter-spacing: -0.04em;
  color: #fff;
  line-height: 1;
}
.metric .val .odo-wrap{ font-size: inherit; }
.metric .val .u{ color: var(--accent); font-size: 0.5em; margin-left: 6px; vertical-align: middle; }
.metric .lbl{ margin-top: 18px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-3); }
.metric{ padding: 56px 32px; }

@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
  .cursor-dot, .cursor-ring, .bg-canvas, .aurora{ display:none !important; }
  .splittext .ch{ color: var(--fg) !important; }
  .odo-stack{ transform: none !important; }
}
