/* Homepage shell on top of tokens.css */
html,body{background:var(--bg);color:var(--fg);overscroll-behavior:none}
body{font-family:var(--font-sans)}
body{padding-top:var(--nav-h,64px)}
:root{--nav-h:64px}
.nav{position:fixed;top:0;left:0;right:0;z-index:40;height:var(--nav-h);
  background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-weight:500;letter-spacing:-0.01em;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{width:28px;height:28px;display:inline-flex;color:var(--ds-purple-900);flex-shrink:0}
.brand-mark path{fill:var(--ds-purple-900);stroke:var(--ds-purple-700);stroke-width:4;paint-order:stroke}
.brand-name{font-size:18px;color:var(--fg);letter-spacing:-0.015em}
.brand-by{color:var(--fg-muted);font-size:14px;font-weight:400;margin-left:4px;letter-spacing:-0.005em}
.nav-links{display:flex;gap:4px;font-size:14px}
.nav-links a{padding:8px 12px;color:var(--fg-secondary);border-radius:var(--radius-base);text-decoration:none}
.nav-links a:hover{color:var(--fg);background:var(--surface)}
.nav-actions{display:flex;gap:8px;align-items:center}
/* buttons: Radix-inspired semi-raised treatment.
   - 1px "shiny" border via box-shadow (color-mix for tinted alpha)
   - inner top highlight (inset) for the subtle gloss
   - soft outer shadow stack for the lift
   - hover bumps every alpha, active presses back in */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;padding:0 14px;
  border-radius:var(--radius-base);font-size:14px;font-weight:500;letter-spacing:-0.005em;
  border:none;cursor:pointer;text-decoration:none;white-space:nowrap;position:relative;isolation:isolate;
  transition:background 160ms ease,box-shadow 160ms ease,color 160ms ease,transform 160ms ease}
.btn:active{transform:translateY(0.5px)}

/* primary: white-on-black, restrained raised treatment */
.btn-primary{background:var(--fg);color:var(--bg);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.6),
    0 0 0 1px rgba(0,0,0,0.12),
    0 1px 1px 0 rgba(0,0,0,0.10)}
.btn-primary:hover{background:color-mix(in srgb,var(--fg) 94%,var(--bg));
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.7),
    0 0 0 1px rgba(0,0,0,0.16),
    0 1px 2px 0 rgba(0,0,0,0.14),
    0 3px 8px -2px rgba(0,0,0,0.18)}
.btn-primary:active{box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.4),
    0 0 0 1px rgba(0,0,0,0.20)}

/* ghost: transparent with restrained border */
.btn-ghost{background:transparent;color:var(--fg);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.03),
    0 0 0 1px rgba(255,255,255,0.09),
    0 1px 1px 0 rgba(0,0,0,0.14)}
.btn-ghost:hover{background:rgba(255,255,255,0.03);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.05),
    0 0 0 1px rgba(255,255,255,0.14),
    0 1px 2px 0 rgba(0,0,0,0.18),
    0 3px 8px -2px rgba(0,0,0,0.18)}
.btn-ghost:active{background:rgba(255,255,255,0.05);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.02),
    0 0 0 1px rgba(255,255,255,0.10),
    0 1px 1px 0 rgba(0,0,0,0.22)}

/* blue: solid accent, subtle tinted border */
.btn-blue{background:var(--ds-blue-700);color:#fff;
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.18),
    0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 45%,transparent),
    0 1px 2px 0 rgba(0,0,0,0.24)}
.btn-blue:hover{background:color-mix(in srgb,var(--ds-blue-700) 92%,white);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.24),
    0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 60%,transparent),
    0 1px 2px 0 rgba(0,0,0,0.28),
    0 4px 10px -3px color-mix(in srgb,var(--ds-blue-700) 35%,transparent)}
.btn-blue:active{background:color-mix(in srgb,var(--ds-blue-700) 96%,black);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.12),
    0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 55%,transparent),
    0 1px 2px 0 rgba(0,0,0,0.32)}

.btn-sm{height:32px;padding:0 12px;font-size:13px}
.btn-lg{height:44px;padding:0 18px;font-size:15px}

/* layout */
.section{max-width:1200px;margin:0 auto;padding:96px 24px}
.section.tight{padding:48px 24px}
.section h2{font-family:var(--font-sans);font-size:var(--text-heading-32);line-height:1.15;
  letter-spacing:-.02em;font-weight:500;margin:0 0 12px;max-width:780px}
.section .h-sub{color:var(--fg-secondary);font-size:16px;line-height:1.55;max-width:680px;margin:0 0 32px}
.eyebrow{font-size:12px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;
  letter-spacing:0.08em;margin:0 0 12px}

/* hero */
.hero{padding:80px 24px 64px;max-width:1280px;margin:0 auto}
.hero-top{display:grid;grid-template-columns:1.05fr 0.95fr;gap:48px;align-items:center;margin-bottom:40px}
@media(max-width:1000px){.hero-top{grid-template-columns:1fr;gap:32px}}
.hero-copy{max-width:620px}
.hero h1{font-size:56px;line-height:1.05;letter-spacing:-.03em;font-weight:500;margin:0 0 18px}
.hero h1 strong{color:var(--ds-blue-900);font-weight:700}
.hero .lede{font-size:17px;line-height:1.55;color:var(--fg-secondary);margin:0 0 28px;font-weight:350}
.hero .ctas{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero-viz{min-height:420px;position:relative}
.hero-term{
  margin-top:48px;max-width:780px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-medium);overflow:hidden;box-shadow:var(--shadow-elevation-2)
}
.hero-term-chrome{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--surface) 60%,var(--bg))}
.hero-term-chrome .dots{display:inline-flex;gap:8px}
.hero-term-chrome .dots i{width:11px;height:11px;border-radius:9999px;display:inline-block}
.hero-term-chrome .dots i.r{background:#ff5f57;box-shadow:inset 0 0 0 1px rgba(0,0,0,0.15)}
.hero-term-chrome .dots i.y{background:#febc2e;box-shadow:inset 0 0 0 1px rgba(0,0,0,0.15)}
.hero-term-chrome .dots i.g{background:#28c840;box-shadow:inset 0 0 0 1px rgba(0,0,0,0.15)}
.hero-term-chrome .path{margin-left:12px;color:var(--fg-muted);font-family:var(--font-mono);font-size:12px}
.hero-term pre{margin:0;padding:18px 20px;font-family:var(--font-mono);font-size:13.5px;line-height:1.7;
  color:var(--fg);white-space:pre;overflow-x:auto}
.hero-term .cmt{color:var(--fg-muted)}
.hero-term .dollar{color:var(--ds-teal-900);margin-right:6px}
.hero-term .cmd{color:var(--fg)}
.hero-term .tool{color:var(--ds-teal-900);font-weight:500}
.hero-term .sub{color:var(--fg)}
.hero-term .flag{color:var(--ds-amber-900)}
.hero-term .val{color:var(--ds-blue-900)}
.hero-term .arg{color:var(--fg-secondary)}
.hero-term .url{color:var(--accent-fg)}
.hero-term .ok{color:var(--success-fg);font-weight:500}
.hero-term pre{height:340px;min-height:340px;overflow-y:auto;scrollbar-width:none}
.hero-term pre::-webkit-scrollbar{display:none}
.hero-cursor{display:inline-block;width:8px;height:14px;background:var(--ds-blue-700);
  vertical-align:-2px;margin-left:2px;animation:blink 1.05s steps(1) infinite;opacity:0.9}

/* hero prompt + dossbot row */
.hero-stage{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;align-items:stretch}
@media(max-width:900px){.hero-stage{grid-template-columns:1fr}}
.stage-col{display:flex;flex-direction:column;gap:10px}
.stage-lede h3{font-size:13px;font-weight:500;letter-spacing:-0.005em;margin:0 0 2px;color:var(--fg-secondary)}
.stage-lede p{font-size:12.5px;color:var(--fg-muted);line-height:1.5;margin:0}

/* DOSSBOT card */
.dossbot-card{flex:1;display:flex;flex-direction:column;
  background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden}
.dossbot-head{display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:color-mix(in srgb,var(--surface) 60%,var(--bg));border-bottom:1px solid var(--border)}
.dossbot-avatar{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:9999px;background:rgba(255,255,255,0.04);color:var(--fg-secondary);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08)}
.dossbot-avatar svg{width:16px;height:16px}
.dossbot-ident{display:flex;flex-direction:column;gap:0;flex:1}
.dossbot-name{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--fg)}
.dossbot-status{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-muted);letter-spacing:0.04em;display:inline-flex;align-items:center;gap:5px}
.dossbot-status i{display:inline-block;width:6px;height:6px;border-radius:9999px;background:var(--ds-green-700);
  box-shadow:0 0 6px var(--ds-green-700)}
.dossbot-badges{display:inline-flex;gap:6px}
.dossbot-badges span{font-family:var(--font-mono);font-size:10.5px;padding:2px 7px;border-radius:9999px;
  background:rgba(255,255,255,0.04);color:var(--fg-secondary);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08)}
.dossbot-body{flex:1;padding:18px 18px 10px;display:flex;flex-direction:column;gap:10px}
.dossbot-msg{font-size:13.5px;line-height:1.55;color:var(--fg);padding:10px 13px;
  background:transparent;
  border-radius:4px 12px 12px 12px;
  box-shadow:inset 0 0 0 1px var(--border)}
.dossbot-msg-sub{background:transparent;color:var(--fg-muted);font-size:12.5px;
  box-shadow:inset 0 0 0 1px var(--border)}
.dossbot-foot{padding:12px 14px 14px;border-top:1px solid var(--border);
  background:color-mix(in srgb,var(--surface) 60%,var(--bg))}
.dossbot-cta{display:inline-flex;align-self:flex-start;height:36px;align-items:center;gap:6px;padding:0 14px;
  font-size:13px;font-weight:500;white-space:nowrap;max-width:100%}
.dossbot-cta .cta-lbl{flex-shrink:0}
.dossbot-cta .cta-arrow{margin-left:6px;opacity:0.8}

/* vertical verb rotator inside the CTA */
.verb-rotator{position:relative;display:inline-block;height:1.2em;overflow:hidden;vertical-align:baseline;min-width:170px;padding-left:6px}
.verb-list{display:flex;flex-direction:column;animation:verbroll 12s infinite;will-change:transform}
.verb-list > span{height:1.2em;line-height:1.2em;white-space:nowrap}
@keyframes verbroll{
  0%,16%   {transform:translateY(0)}
  20%,36%  {transform:translateY(-1.2em)}
  40%,56%  {transform:translateY(-2.4em)}
  60%,76%  {transform:translateY(-3.6em)}
  80%,96%  {transform:translateY(-4.8em)}
  100%     {transform:translateY(0)}
}

/* agent prompt block */
.prompt-card{position:relative;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 92%,black) 0%,var(--surface) 100%);
  border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;display:flex;flex-direction:column;
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04),0 4px 18px -4px rgba(0,0,0,0.5)}
.prompt-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;
  background:color-mix(in srgb,var(--surface) 60%,var(--bg));border-bottom:1px solid var(--border)}
.prompt-head .label{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:0.05em;
  text-transform:uppercase;color:var(--fg-muted);display:flex;align-items:center;gap:8px}
.prompt-head .label .sparkle{display:inline-block;width:6px;height:6px;border-radius:9999px;
  background:var(--ds-blue-700);box-shadow:0 0 10px var(--ds-blue-700)}
.prompt-head .badges{display:inline-flex;gap:6px}
.prompt-head .badges span{font-family:var(--font-mono);font-size:10.5px;padding:2px 7px;border-radius:9999px;
  background:rgba(255,255,255,0.04);color:var(--fg-secondary);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08)}
.prompt-body{flex:1;padding:16px 18px;font-family:var(--font-mono);font-size:12.5px;line-height:1.75;color:var(--fg);
  white-space:pre-wrap;counter-reset:ln}
.prompt-body .ln{display:block;position:relative;padding-left:26px}
.prompt-body .ln::before{counter-increment:ln;content:counter(ln,decimal-leading-zero);
  position:absolute;left:0;top:0;color:var(--fg-muted);opacity:0.45;font-size:10.5px;letter-spacing:0.04em}
.prompt-body .cmt{color:var(--fg-muted);font-style:normal}
.prompt-body .p{color:var(--ds-blue-900);margin-right:6px}
.prompt-body .cmd{color:var(--fg);font-weight:500}
.prompt-body .flag{color:var(--ds-amber-900)}
.prompt-body .val{color:var(--ds-blue-900)}
.prompt-body .arg{color:var(--fg-secondary)}
.prompt-body .cursor{display:inline-block;width:8px;height:13px;background:var(--ds-blue-700);
  vertical-align:-2px;margin-left:2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.prompt-foot{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);
  background:color-mix(in srgb,var(--surface) 60%,var(--bg))}
.copy-btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;cursor:pointer;
  font-family:var(--font-sans);font-size:12.5px;font-weight:500;color:var(--fg);background:transparent;border:none;
  border-radius:var(--radius-base);
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04),0 0 0 1px rgba(255,255,255,0.10),0 1px 1px 0 rgba(0,0,0,0.18);
  transition:box-shadow 160ms,background 160ms}
.copy-btn:hover{background:rgba(255,255,255,0.04);
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.08),0 0 0 1px rgba(255,255,255,0.18),0 2px 4px 0 rgba(0,0,0,0.24)}
.copy-btn svg{width:14px;height:14px;color:var(--fg-muted)}
.copy-btn.copied{color:var(--ds-green-900)}
.copy-btn.copied svg{color:var(--ds-green-900)}

/* cells viz — nested boxes: fleet > [operator, cluster > pods] */
.cells-viz{position:relative;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;padding:20px 16px 16px;
  display:flex;flex-direction:column;gap:14px;min-height:420px}
.cells-viz .cv-meta{font-family:var(--font-mono);font-size:10px;color:var(--fg-muted);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:4px}
.cells-viz .cv-operator{border:1px solid var(--border);border-radius:var(--radius-base);padding:12px 14px;
  background:color-mix(in srgb,var(--bg) 40%,var(--surface))}
.cells-viz .cv-op-label{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--fg);letter-spacing:0.04em}
.cells-viz .cv-op-sub{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-muted);letter-spacing:0.02em;margin-top:2px}
.cells-viz .cv-cluster{flex:1;border:1px solid var(--border);border-radius:var(--radius-base);padding:12px;
  background:color-mix(in srgb,var(--bg) 40%,var(--surface));display:flex;flex-direction:column;gap:10px;min-height:0}
.cells-viz .cv-cluster-label{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--fg);letter-spacing:0.1em;text-transform:uppercase;padding-left:2px}
.cells-viz .cv-pods{display:grid;grid-template-columns:1fr 1fr;gap:8px;flex:1;min-height:0}
.cells-viz .cv-pod{border:1px solid var(--border);border-radius:var(--radius-base);padding:12px;
  background:var(--surface);display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-content:start}
.cells-viz .cv-pod-name{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--fg);letter-spacing:0.02em;grid-column:1/-1}
.cells-viz .cv-pod-sub{font-family:var(--font-mono);font-size:10px;color:var(--fg-muted);letter-spacing:0.02em;grid-column:1/-1}
.cells-viz .cv-bar{position:relative;height:4px;background:rgba(255,255,255,0.06);border-radius:9999px;overflow:hidden;margin-top:6px}
.cells-viz .cv-bar span{display:block;height:100%;background:var(--fg-muted);border-radius:9999px}
.cells-viz .cv-pod-pct{font-family:var(--font-mono);font-size:10px;color:var(--fg-muted);text-align:right;align-self:center;margin-top:6px}

/* live strip */
.live-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--surface) 40%,var(--bg))}
.live-inner{max-width:1200px;margin:0 auto;padding:20px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.live-label{font-size:11px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;letter-spacing:0.08em;
  display:flex;align-items:center;gap:8px}
.live-dot{width:6px;height:6px;border-radius:9999px;background:var(--success-fg);
  box-shadow:0 0 8px color-mix(in srgb,var(--success-fg) 60%,transparent)}
.live-links{display:flex;gap:8px;flex-wrap:wrap;font-family:var(--font-mono);font-size:12px}
.live-links a{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 6px;color:var(--fg-secondary);
  text-decoration:none;border-radius:9999px;background:rgba(255,255,255,0.03);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08);transition:box-shadow 160ms,color 160ms,background 160ms}
.live-links a:hover{color:var(--fg);background:rgba(0,112,243,0.06);
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 35%,transparent)}
.live-links .svc{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:9999px;color:var(--ds-blue-900);background:rgba(0,112,243,0.1);
  box-shadow:inset 0 0 0 1px rgba(0,112,243,0.22)}
.live-links .svc svg{width:10px;height:10px}
.live-links .svc.web{color:var(--ds-blue-900);background:rgba(0,112,243,0.10);box-shadow:inset 0 0 0 1px rgba(0,112,243,0.25)}
.live-links .svc.api{color:var(--ds-teal-900);background:rgba(18,165,148,0.10);box-shadow:inset 0 0 0 1px rgba(18,165,148,0.30)}
.live-links .svc.design{color:var(--ds-purple-900);background:rgba(142,78,198,0.10);box-shadow:inset 0 0 0 1px rgba(142,78,198,0.30)}
.live-links .svc.tetris{color:var(--ds-amber-900);background:rgba(245,166,35,0.10);box-shadow:inset 0 0 0 1px rgba(245,166,35,0.30)}
.live-links .svc.docs{color:var(--ds-pink-900);background:rgba(233,61,130,0.10);box-shadow:inset 0 0 0 1px rgba(233,61,130,0.30)}
.live-links .svc.debug{color:var(--ds-amber-900);background:rgba(245,166,35,0.10);box-shadow:inset 0 0 0 1px rgba(245,166,35,0.30)}
.live-links .svc.admin{color:var(--ds-green-900);background:rgba(69,165,87,0.10);box-shadow:inset 0 0 0 1px rgba(69,165,87,0.30)}
.live-links .svc.hero{color:var(--ds-pink-900);background:rgba(233,61,130,0.10);box-shadow:inset 0 0 0 1px rgba(233,61,130,0.30)}
.live-links .svc.main{color:var(--ds-blue-900);background:rgba(0,112,243,0.10);box-shadow:inset 0 0 0 1px rgba(0,112,243,0.25)}
.live-links a .host{color:inherit}

/* features */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;margin-top:24px}
@media(max-width:900px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.feature-grid{grid-template-columns:1fr}}
.feature{background:var(--bg);padding:28px 24px 24px;display:flex;flex-direction:column;gap:8px;text-decoration:none}
.feature-link{color:inherit;cursor:pointer;transition:background 160ms}
.feature-link:hover{background:color-mix(in srgb,var(--ds-blue-700) 4%,var(--bg))}
.feature-link:hover .feature-more{color:var(--ds-blue-900)}
.feature-ico{width:24px;height:24px;margin-bottom:12px;color:var(--fg-muted);display:inline-flex}
.feature h3{font-size:15px;font-weight:500;letter-spacing:-0.005em;margin:0;color:var(--fg)}
.feature p{font-size:13.5px;line-height:1.55;color:var(--fg-secondary);margin:0}
.feature code{font-family:var(--font-mono);font-size:12px;background:var(--surface);
  padding:2px 6px;border-radius:3px;color:var(--fg);border:1px solid var(--border)}
.feature-more{margin-top:auto;padding-top:10px;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-muted);
  letter-spacing:0.02em;transition:color 160ms}

/* architecture */
.arch{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:24px}
@media(max-width:800px){.arch{grid-template-columns:1fr}}
.arch-diagram{position:relative;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 94%,black) 0%,var(--surface) 100%);
  border:1px solid var(--border);border-radius:var(--radius-medium);padding:20px 24px 24px;
  font-family:var(--font-mono);font-size:12px;line-height:1.55;color:var(--fg);overflow:hidden;
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04)}
.arch-diagram::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(to right,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:24px 24px;
  mask-image:linear-gradient(to bottom,transparent,black 15%,black 85%,transparent)}
.arch-diagram .rail{position:absolute;left:36px;top:40px;bottom:40px;width:2px;border-radius:2px;
  background:linear-gradient(to bottom,transparent,rgba(255,255,255,0.08) 12%,rgba(255,255,255,0.08) 88%,transparent)}
.arch-diagram .packet{position:absolute;left:33px;width:8px;height:8px;border-radius:9999px;
  background:var(--ds-blue-900);opacity:0.72;
  box-shadow:0 0 4px color-mix(in srgb,var(--ds-blue-700) 50%,transparent);
  animation:packetTravel 7s linear infinite}
@keyframes packetTravel{
  0%{top:36px;opacity:0}
  5%{opacity:0.72}
  95%{opacity:0.72}
  100%{top:calc(100% - 36px);opacity:0}}
.arch-diagram .step{position:relative;display:grid;grid-template-columns:24px 120px 1fr auto;gap:14px;align-items:center;
  padding:10px 0 10px 36px;border-bottom:1px dashed var(--border)}
.arch-diagram .step:last-of-type{border-bottom:none}
.arch-diagram .step .ico{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:4px;background:rgba(255,255,255,0.04);color:var(--fg-secondary);
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04),0 0 0 1px rgba(255,255,255,0.08)}
.arch-diagram .step .ico svg{width:13px;height:13px}
.arch-diagram .step.active .ico{color:var(--ds-blue-900);
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04),0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 40%,transparent)}
.arch-diagram .step .k{color:var(--fg-muted);text-transform:lowercase}
.arch-diagram .step .v{color:var(--fg)}
.arch-diagram .step .v b{font-weight:500;color:var(--fg)}
.arch-diagram .step .tag{font-size:10.5px;padding:2px 7px;border-radius:9999px;color:var(--fg-secondary);
  background:rgba(255,255,255,0.03);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08)}
.arch-diagram .step .tag{color:var(--fg-secondary);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.10);background:rgba(255,255,255,0.02)}
.arch-diagram .step.tag-accent .tag{color:var(--ds-blue-900);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 35%,transparent);background:color-mix(in srgb,var(--ds-blue-700) 8%,transparent)}
.arch-diagram .arrow{padding:2px 0 2px 36px;color:var(--fg-muted);font-size:11px;letter-spacing:0.02em;
  display:flex;align-items:center;gap:8px}
.arch-diagram .arrow .dash{flex:1;border-top:1px dashed var(--border)}
.arch-notes h3{font-size:16px;font-weight:500;margin:0 0 8px;color:var(--fg)}
.arch-notes p{color:var(--fg-secondary);font-size:14px;line-height:1.6;margin:0 0 20px}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
@media(max-width:1000px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.price-grid{grid-template-columns:1fr}}
.price{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-medium);
  padding:28px 24px;display:flex;flex-direction:column;gap:14px;position:relative}
.price.featured{border-color:rgba(255,255,255,0.22);box-shadow:0 0 0 1px rgba(255,255,255,0.22)}
.price .tag{position:absolute;top:-10px;right:16px;background:var(--fg);color:var(--bg);
  font-size:10.5px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:9999px}
.price-name{font-size:12px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;letter-spacing:0.08em}
.price-num{display:flex;align-items:baseline;gap:4px}
.price-num .amt{font-size:36px;font-weight:500;letter-spacing:-0.02em;color:var(--fg)}
.price-num .unit{font-size:13px;color:var(--fg-muted)}
.price-annual{font-size:12px;color:var(--fg-muted);font-family:var(--font-mono);margin:-4px 0 0;min-height:16px}
.price-annual b{color:var(--ds-blue-900);font-weight:500}
.price-tag{font-size:13px;color:var(--fg-secondary);min-height:40px;line-height:1.4;margin:-2px 0 4px}
.price-credit{font-size:12px;color:var(--fg-secondary);font-family:var(--font-mono);margin:0 0 4px;
  padding:6px 10px;background:var(--ga200);border:1px dashed var(--border);border-radius:4px}
.price-credit b{color:var(--fg);font-weight:500}
.price ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.price li{font-size:13px;color:var(--fg-secondary);padding-left:20px;position:relative;line-height:1.5}
.price li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:1px;background:var(--fg-muted)}
.price .btn{margin-top:auto;justify-content:center}
.price ul{flex:0 0 auto}

/* specs (runtime classes) */
.specs{margin-top:24px;border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden}
.specs table{width:100%;border-collapse:collapse;font-size:13.5px}
.specs th,.specs td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--border)}
.specs tr:last-child td{border-bottom:none}
.specs th{background:var(--surface);color:var(--fg-secondary);font-weight:500;font-size:11.5px;
  text-transform:uppercase;letter-spacing:0.06em}
.specs td{color:var(--fg);font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.specs td:first-child{font-family:var(--font-sans);color:var(--fg);font-size:16px;font-weight:500;letter-spacing:-0.01em;padding:18px 16px}
.specs td:first-child .class-cell{display:flex;align-items:center;gap:12px}
.specs td:first-child .cico{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:4px;background:rgba(0,112,243,0.06);color:var(--ds-blue-900);
  box-shadow:inset 0 0 0 1px rgba(0,112,243,0.22)}
.specs td:first-child .cico svg{width:16px;height:16px}
.specs td:first-child .cname{display:flex;flex-direction:column;gap:2px}
.specs td:first-child .cname .cn{font-size:16px;font-weight:500;color:var(--fg);line-height:1.1}
.specs td:first-child .cname .cd{font-size:11.5px;font-family:var(--font-mono);font-weight:400;color:var(--fg-muted);letter-spacing:0.02em}
.specs .muted{color:var(--fg-muted)}
.meters-note{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;margin:12px 0 4px;
  border-radius:var(--radius-base);background:color-mix(in srgb,var(--ds-blue-700) 6%,transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 25%,transparent);
  color:var(--fg-secondary);font-size:13px;line-height:1.55;max-width:720px}
.meters-note svg{width:16px;height:16px;flex-shrink:0;color:var(--ds-blue-900);margin-top:2px}
.meters-note span b{color:var(--fg);font-weight:500}
.specs .bar{display:block;position:relative;margin-top:6px;height:4px;width:100%;max-width:140px;
  border-radius:9999px;background:rgba(255,255,255,0.05);overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.03)}
.specs .bar::after{content:"";display:block;height:100%;width:var(--w,0%);border-radius:9999px;
  box-shadow:0 0 10px -1px currentColor;background:currentColor}
.specs .bar.cpu{color:var(--ds-blue-700)}
.specs .bar.ram{color:var(--ds-purple-700)}
.specs .bar.disk{color:var(--ds-teal-700)}
.specs .bar.gpu{color:var(--ds-pink-700)}
.specs .bar.cost{color:var(--ds-amber-700)}

/* get started mock flow */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;margin-top:24px}
@media(max-width:900px){.flow{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.flow{grid-template-columns:1fr}}
.flow-step{background:var(--bg);padding:28px 24px;display:flex;flex-direction:column;gap:10px;min-height:220px}
.flow-step .n{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted)}
.flow-step h4{font-size:15px;font-weight:500;margin:0;color:var(--fg)}
.flow-step p{font-size:13px;line-height:1.5;color:var(--fg-secondary);margin:0 0 8px}
.flow-step .mini{margin-top:auto;background:var(--surface);border:1px solid var(--border);border-radius:4px;
  padding:10px 12px;font-family:var(--font-mono);font-size:12px;color:var(--fg);line-height:1.6;
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.04)}
.flow-step .mini .mute{color:var(--fg-muted)}
.flow-step .mini .key{color:var(--ds-amber-900);font-weight:500}
.flow-step .mini .check{color:var(--ds-green-900)}
.flow-step .mini .val{color:var(--ds-blue-900)}
.flow-step .mini .tool{color:var(--ds-teal-900);font-weight:500}
.flow-step .mini .url{color:var(--ds-purple-900)}
.flow-step .mini .chip{display:inline-block;padding:0 6px;border-radius:9999px;
  background:rgba(69,165,87,0.12);color:var(--ds-green-900);
  box-shadow:inset 0 0 0 1px rgba(69,165,87,0.35);font-size:11px}
/* github-style shiny button in step 01 */
.gh-btn{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:40px;padding:0 14px;border-radius:var(--radius-base);font-size:13.5px;font-weight:500;
  color:#fff;background:var(--ds-blue-700);border:none;text-decoration:none;cursor:pointer;
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.18),
    0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 45%,transparent),
    0 1px 2px 0 rgba(0,0,0,0.24);
  transition:box-shadow 160ms,background 160ms,transform 160ms}
.gh-btn:hover{background:color-mix(in srgb,var(--ds-blue-700) 92%,white);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.24),
    0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 60%,transparent),
    0 1px 2px 0 rgba(0,0,0,0.28),
    0 4px 10px -3px color-mix(in srgb,var(--ds-blue-700) 35%,transparent)}
.gh-btn:active{transform:translateY(0.5px)}
.gh-btn svg{width:18px;height:18px}

/* panel mock (dashboard preview) */
.panel{margin-top:24px;border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;
  background:var(--surface)}
.panel-chrome{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;
  background:color-mix(in srgb,var(--surface) 60%,var(--bg));border-bottom:1px solid var(--border);
  font-family:var(--font-mono);font-size:12px;color:var(--fg-secondary)}
.panel-body{padding:24px;display:grid;grid-template-columns:240px 1fr;gap:24px}
@media(max-width:800px){.panel-body{grid-template-columns:1fr}}
.panel-side{display:flex;flex-direction:column;gap:4px;font-size:13px}
.panel-side .item{padding:8px 10px;border-radius:4px;color:var(--fg-secondary);display:flex;justify-content:space-between;
  align-items:center}
.panel-side .item:hover{background:var(--surface-hover);color:var(--fg)}
.panel-side .item.active{background:var(--surface-hover);color:var(--fg)}
.panel-side .item .count{font-family:var(--font-mono);font-size:11px;color:var(--fg-muted)}
.panel-main{display:flex;flex-direction:column;gap:16px}
.panel-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:600px){.panel-kpis{grid-template-columns:repeat(2,1fr)}}
.kpi-card{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:14px}
.kpi-card .l{font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:0.06em}
.kpi-card .v{font-family:var(--font-mono);font-size:20px;color:var(--fg);font-weight:500;margin-top:6px;
  font-variant-numeric:tabular-nums}
.panel-links{background:var(--bg);border:1px solid var(--border);border-radius:4px;overflow:hidden}
.panel-links table{width:100%;border-collapse:collapse;font-size:13px}
.panel-links th,.panel-links td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--border)}
.panel-links tr:last-child td{border-bottom:none}
.panel-links th{font-size:11px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;letter-spacing:0.06em}
.panel-links td{color:var(--fg);font-family:var(--font-mono);font-size:12.5px}
.panel-links .badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:9999px;
  font-size:11px;font-family:var(--font-sans);letter-spacing:0;
  background:color-mix(in srgb,var(--success-fg) 12%,transparent);color:var(--success-fg);
  border:1px solid color-mix(in srgb,var(--success-fg) 35%,transparent)}
.panel-links .badge.private{background:color-mix(in srgb,var(--accent-fg) 12%,transparent);
  color:var(--accent-fg);border-color:color-mix(in srgb,var(--accent-fg) 35%,transparent)}

/* cta */
.cta{text-align:center;padding:96px 24px;border-top:1px solid var(--border);margin-top:48px}
.cta h2{font-size:40px;line-height:1.1;letter-spacing:-0.03em;font-weight:500;margin:0 0 16px}
.cta p{font-size:17px;color:var(--fg-secondary);max-width:580px;margin:0 auto 28px;line-height:1.5}
.cta .ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* footer */
footer{border-top:1px solid var(--border);padding:48px 24px 32px;background:var(--surface)}
.foot-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:800px){.foot-inner{grid-template-columns:1fr 1fr}}
.foot-brand{display:flex;flex-direction:column;gap:12px}
.foot-brand p{font-size:13px;line-height:1.55;color:var(--fg-secondary);max-width:320px;margin:0}
.foot-col h4{font-size:11px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;letter-spacing:0.08em;margin:0 0 12px}
.foot-col a{display:block;padding:4px 0;font-size:13.5px;color:var(--fg-secondary);text-decoration:none}
.foot-col a:hover{color:var(--fg)}
.foot-bottom{max-width:1200px;margin:32px auto 0;padding-top:24px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;font-size:12px;color:var(--fg-muted);font-family:var(--font-mono)}

/* CENTARI mark (borrowed until remoco has its own) */
.mark-centari{width:24px;height:24px}
.mark-centari path{fill:var(--ds-purple-900);stroke:var(--ds-purple-700);stroke-width:4;paint-order:stroke fill}

/* ============================================================ */
/* Use-case estimator */
/* ============================================================ */
/* use-case driven estimator */
.est-cases{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
@media(max-width:1100px){.est-cases{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.est-cases{grid-template-columns:1fr}}
.est-case{display:flex;flex-direction:column;align-items:flex-start;gap:10px;
  background:var(--surface);border:none;border-radius:var(--radius-medium);padding:18px 18px 16px;
  cursor:pointer;text-align:left;
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.03),0 0 0 1px var(--border),0 1px 1px 0 rgba(0,0,0,0.12);
  transition:box-shadow 160ms,background 160ms}
.est-case:hover{background:color-mix(in srgb,var(--ds-blue-700) 4%,var(--surface));
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.05),0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 25%,transparent),0 2px 6px -1px rgba(0,0,0,0.18)}
.est-case.active{background:color-mix(in srgb,var(--ds-blue-700) 8%,var(--surface));
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.07),0 0 0 1px color-mix(in srgb,var(--ds-blue-900) 55%,transparent),0 2px 8px -1px color-mix(in srgb,var(--ds-blue-700) 25%,transparent)}
.est-case .cico{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:4px;background:rgba(0,112,243,0.08);color:var(--ds-blue-900);
  box-shadow:inset 0 0 0 1px rgba(0,112,243,0.28)}
.est-case .cico svg{width:16px;height:16px}
.est-case h4{font-size:15px;font-weight:500;margin:0;color:var(--fg);letter-spacing:-0.005em}
.est-case p{font-size:13px;color:var(--fg-secondary);margin:0;line-height:1.55}
.est-case .est-case-spec{font-size:11.5px;color:var(--fg-muted);font-family:var(--font-mono);
  letter-spacing:0.02em;margin-top:auto;padding-top:4px}

.est-out{display:grid;grid-template-columns:1.05fr 1fr;gap:16px;margin-top:24px;align-items:start}
@media(max-width:900px){.est-out{grid-template-columns:1fr}}
.est-out-left{display:flex;flex-direction:column;gap:16px}
.est-total{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-medium);padding:26px;display:flex;flex-direction:column;gap:12px}
.est-total-amt{font-family:var(--font-sans);font-size:52px;font-weight:500;letter-spacing:-0.02em;color:var(--fg);display:flex;align-items:baseline;gap:8px;line-height:1}
.est-only{font-size:18px;font-weight:400;color:var(--fg-muted);letter-spacing:-0.005em}
.est-total-sub{font-size:15px;font-weight:400;color:var(--fg-muted)}
/* tagline: marketing copy, prominent */
.est-total-label{font-size:22px;font-weight:500;color:var(--fg);line-height:1.3;letter-spacing:-0.01em;margin-top:-2px}
.est-total-note{font-size:12px;color:var(--fg-muted);font-family:var(--font-mono);letter-spacing:0.02em;margin-top:6px;text-transform:uppercase}
.est-term-row{display:flex;gap:10px;align-items:center}
/* segmented-control switcher: compact, sized to content */
.est-toggle{display:inline-flex;flex:0 0 auto;background:rgba(255,255,255,0.03);border-radius:9999px;padding:3px;
  box-shadow:inset 0 0 0 1px var(--border)}
.est-t{flex:0 0 auto;min-width:96px;height:28px;padding:0 14px;background:transparent;color:var(--fg-muted);border:none;border-radius:9999px;
  font-size:12.5px;font-weight:500;cursor:pointer;letter-spacing:-0.002em;
  transition:background 180ms,color 180ms}
.est-t:hover:not(.active){color:var(--fg)}
.est-t.active{background:var(--ds-blue-700);color:#fff;
  box-shadow:inset 0 1px 0 0 rgba(255,255,255,0.22),0 1px 2px 0 rgba(0,0,0,0.24)}
.est-t .t-save{opacity:0.72;margin-left:4px;font-weight:400}
.est-t.active .t-save{opacity:0.9}
#est-cta{height:36px}
.est-break{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden}
.est-break th{font-size:11px;text-transform:uppercase;letter-spacing:0.05em;color:var(--fg-muted);font-weight:500;text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 60%,var(--bg))}
.est-break td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--fg)}
.est-break td:nth-child(2),.est-break th:nth-child(2){color:var(--fg-muted);font-family:var(--font-mono);font-size:12px}
.est-break td:nth-child(3),.est-break th:nth-child(3){text-align:right;font-family:var(--font-mono)}
.est-break tr:last-child td{border-bottom:none}
