/* ============================================================================
   Steve·AI — FOUNDATION (CANONICAL SOURCE, not a reference)
   This is the locked mockup's exact CSS: tokens, brand, shell (rail/top bar/
   breadcrumbs/account), atomics, new-indicators, gallery. PORT VERBATIM into the
   new site — do NOT re-author, rename classes, change spacing, or drop components.
   Single brand token = --primary (--indigo is its alias). No hardcoded hex in product pages.
   ============================================================================ */
:root{
 /* CANONICAL brand token = --primary. --indigo is a documented compatibility alias of it (no competing tokens). */
 --primary:#6D28D9; --primary-bright:#A855F7; --primary-deep:#581C87; --primary-soft:rgba(109,40,217,0.10);
 --indigo:var(--primary); --indigo-bright:var(--primary-bright); --indigo-deep:var(--primary-deep); --indigo-soft:var(--primary-soft);
 --ink:#0B1020; --bg:#F6F7FB; --surface:#FFFFFF; --line:rgba(11,16,32,0.08); --muted:#5B6478;
 --on-dark:rgba(255,255,255,0.95); --on-dark-muted:rgba(255,255,255,0.62);
 --green:#16A34A; --green-soft:rgba(22,163,74,0.10); --amber:#D97706; --amber-soft:rgba(217,119,6,0.12); --red:#DC2626; --red-soft:rgba(220,38,38,0.10); --grey:#9AA3B2; --grey-soft:rgba(154,163,178,0.16);
 --display:'Space Grotesk',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif; --mono:'JetBrains Mono',ui-monospace,monospace;
 --r-sm:8px; --r-md:14px; --r-lg:18px; --r-pill:999px;
 --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px;
 --t-micro:11px; --t-xs:12.5px; --t-sm:14px; --t-base:15px; --t-md:16.5px; --t-lg:19px; --t-xl:22px; --t-2xl:28px; --t-3xl:34px;
 --shadow-rest:0 1px 2px rgba(11,16,32,0.05),0 8px 24px rgba(11,16,32,0.06); --shadow-pop:0 12px 32px rgba(11,16,32,0.12),0 40px 90px rgba(11,16,32,0.18);
 --ease:cubic-bezier(.4,0,.2,1);
 --header-h:104px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55;display:flex}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;text-align:left}
a{color:var(--indigo);text-decoration:none} a:hover{text-decoration:underline}
.ai{color:var(--indigo)}
@media (prefers-reduced-motion: reduce){ *{transition:none !important; scroll-behavior:auto !important} }
.ribbon{position:fixed;bottom:0;right:0;z-index:200;background:var(--indigo);color:#fff;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-top-left-radius:10px;opacity:.92}

/* ===== RAIL ===== */
.rail{width:240px;flex:0 0 240px;background:var(--surface);border-right:1px solid var(--line);height:100vh;height:100dvh;position:sticky;top:0;display:flex;flex-direction:column;padding:var(--s-5) var(--s-3) var(--s-4);transition:width .22s var(--ease),flex-basis .22s var(--ease)}
.brand{display:flex;align-items:center;gap:11px;padding:0 8px var(--s-5);flex:0 0 auto}
.mark{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--indigo),var(--indigo-bright));display:grid;place-items:center;color:#fff;flex:0 0 32px;box-shadow:0 4px 12px rgba(109,40,217,.32),inset 0 1px 0 rgba(255,255,255,.35)}
.mark svg{width:62%;height:62%;stroke:currentColor;fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.wm{font-family:var(--display);font-weight:700;font-size:var(--t-md)}
.nav-scroll{flex:1 1 auto;overflow-y:auto;min-height:0;margin:0 -4px;padding:0 4px}
.rail .k{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:0 10px var(--s-2)}
.nav{display:flex;align-items:center;gap:11px;padding:0 11px;min-height:44px;border-radius:var(--r-sm);color:var(--muted);font-weight:600;font-size:var(--t-sm);margin-bottom:2px;width:100%}
.nav .ic{width:18px;height:18px;flex:0 0 18px;display:grid;place-items:center}
.nav .ic svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.9}
.nav.on{background:var(--indigo);color:#fff;box-shadow:0 6px 16px rgba(109,40,217,.26)}
.nav:not(.on):hover{background:var(--indigo-soft);color:var(--indigo-deep)}
.nav.muted{color:var(--grey)} .nav .tag{margin-left:auto;font-size:8px;letter-spacing:.05em;text-transform:uppercase;font-weight:700;color:var(--grey);background:rgba(11,16,32,.05);padding:2px 6px;border-radius:var(--r-pill)}
.rail .foot{flex:0 0 auto;display:flex;flex-direction:column;gap:10px;padding-top:var(--s-3);border-top:1px solid var(--line);padding-bottom:max(0px,env(safe-area-inset-bottom))}
.foot-row{display:flex;align-items:center;gap:10px}
.collapse{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);color:var(--muted);display:grid;place-items:center;font-size:14px;flex:0 0 auto}
.collapse:hover{border-color:var(--indigo);color:var(--indigo-deep)}
.foot .ver{font-size:10px;color:var(--grey);font-family:var(--mono);padding:0 4px}
.account-wrap{position:relative}
.account{display:flex;align-items:center;gap:10px;width:100%;min-height:48px;padding:7px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface)}
.account:hover{border-color:var(--indigo);background:var(--indigo-soft)}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--indigo),var(--indigo-bright));background-size:cover;background-position:center;color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:12px;flex:0 0 32px}
.acct-info{display:flex;flex-direction:column;line-height:1.25;min-width:0;text-align:left}
.acct-name{font-size:var(--t-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct-sub{font-size:var(--t-xs);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct-chev{margin-left:auto;font-size:10px;color:var(--muted);flex:0 0 auto}
.acct-menu{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;display:none;z-index:130}
.acct-menu.open{display:block}
.acct-item{display:flex;align-items:center;justify-content:space-between;min-height:44px;padding:0 11px;border-radius:var(--r-sm);font-size:var(--t-sm)}
.acct-item:hover{background:var(--bg)} .acct-item span{color:var(--muted)} .acct-item b{font-weight:600}
body.rail-collapsed .rail{width:68px;flex-basis:68px;padding-left:var(--s-2);padding-right:var(--s-2)}
body.rail-collapsed .rail .wm,body.rail-collapsed .rail .k,body.rail-collapsed .rail .nav span:not(.ic):not(.ndot),body.rail-collapsed .rail .nav .tag,body.rail-collapsed .rail .ver,body.rail-collapsed .rail .acct-info,body.rail-collapsed .rail .acct-chev{display:none}
body.rail-collapsed .rail .brand{flex-direction:column;align-items:center;gap:var(--s-3);padding:0 0 var(--s-5)}
body.rail-collapsed .rail .nav{width:44px;height:44px;min-height:44px;margin:0 auto 6px;padding:0;justify-content:center;border-radius:11px}
body.rail-collapsed .account{justify-content:center;padding:5px;width:auto}
body.rail-collapsed .foot-row{justify-content:center}
body.rail-collapsed .acct-menu{left:0;right:auto;width:214px}

/* ===== TOP BAR — compact: breadcrumb + page name + tabs (no subtitle) ===== */
.main{flex:1;min-width:0;height:100vh;height:100dvh;overflow:auto;scroll-padding-top:var(--header-h)}
.topbar{position:sticky;top:0;z-index:20;background:rgba(246,247,251,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:var(--s-4) var(--s-8);transition:padding .2s var(--ease),box-shadow .2s var(--ease)}
.crumbs{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:var(--t-xs);min-height:22px}
.crumbs a{color:var(--muted)} .crumbs a:hover{color:var(--indigo);text-decoration:none}
.crumbs .sep{color:var(--grey)} .crumbs .crumb-cur{color:var(--ink);font-weight:700}
.tb-title{font-family:var(--display);font-weight:700;font-size:var(--t-xl);letter-spacing:-.01em;margin-top:2px}
.secnav{display:flex;gap:6px;margin-top:var(--s-3);flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;transition:margin .2s var(--ease)}
.secnav::-webkit-scrollbar{display:none}
.secnav a{font-family:var(--display);font-weight:600;font-size:var(--t-xs);color:var(--muted);padding:6px 12px;border-radius:var(--r-pill);min-height:32px;display:inline-flex;align-items:center;white-space:nowrap}
.secnav a.on,.secnav a:hover{background:var(--indigo-soft);color:var(--indigo-deep);text-decoration:none}
/* scrollable tabs: edge fade signals "more →"; active tab auto-scrolls into view */
.secnav-wrap{position:relative}
.secnav-wrap::before,.secnav-wrap::after{content:'';position:absolute;top:0;bottom:0;width:48px;pointer-events:none;opacity:0;transition:opacity .2s var(--ease);z-index:2}
.secnav-wrap::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.secnav-wrap::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.secnav-wrap.can-left::before{opacity:1} .secnav-wrap.can-right::after{opacity:1}
.snav-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:30px;height:30px;border-radius:50%;background:var(--indigo-soft);border:none;box-shadow:0 2px 8px rgba(11,16,32,.10);display:none;place-items:center;color:var(--indigo-deep);font-size:16px;font-weight:700;padding-bottom:2px;transition:background .15s var(--ease),color .15s var(--ease)}
.snav-arrow:hover{background:var(--primary);color:#fff}
.snav-arrow.left{left:-2px} .snav-arrow.right{right:-2px}
.secnav-wrap.can-left .snav-arrow.left{display:grid}
.secnav-wrap.can-right .snav-arrow.right{display:grid}
.topbar.shrunk{padding-top:10px;padding-bottom:10px;box-shadow:0 4px 16px rgba(11,16,32,.06)}
.topbar.shrunk .tb-title{display:none}   /* breadcrumb stays — it already carries the page name; drop the redundant big title */
.topbar.shrunk .secnav{margin-top:8px}

.page{padding:var(--s-6) var(--s-8) var(--s-12);max-width:1000px}

/* ===== SECTION HEADER (self-explanatory, like the reference) ===== */
.section{margin:var(--s-12) 0 var(--s-4);scroll-margin-top:var(--header-h)}
.section:first-of-type{margin-top:0}  /* first section sits tight under the top bar on EVERY page (was #brand-only) */
.sec-kicker{font-family:var(--display);font-weight:700;font-size:var(--t-sm);letter-spacing:.02em;color:var(--indigo-deep)}
.sec-name{font-family:var(--display);font-weight:700;font-size:var(--t-2xl);letter-spacing:-.015em;margin-top:5px}
.sec-desc{color:var(--muted);font-size:var(--t-md);line-height:1.6;margin-top:8px;max-width:66ch}

/* gallery */
.grid{display:grid;gap:var(--s-3);margin-top:var(--s-4)} .cols-4{grid-template-columns:repeat(4,1fr)} .cols-3{grid-template-columns:repeat(3,1fr)} .cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-rest);overflow:hidden}
.sw{height:52px} .sw-meta{padding:9px 12px} .sw-name{font-family:var(--display);font-weight:700;font-size:var(--t-sm)} .sw-var{font-family:var(--mono);font-size:var(--t-xs);color:var(--muted);margin-top:2px}
.state{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);font-size:var(--t-sm)}
.dot{width:12px;height:12px;border-radius:50%;flex:0 0 12px}
.dot.passed{background:var(--green)} .dot.failed{background:var(--red)} .dot.running{background:var(--amber)} .dot.ns{background:var(--grey)} .dot.pending{background:transparent;border:1.5px dashed var(--grey)} .dot.skipped{background:transparent;border:1.5px dashed var(--grey);opacity:.7}
.state b{font-weight:600} .state .desc{color:var(--muted);margin-left:auto;font-size:var(--t-xs)}
.brandcard{padding:var(--s-5);display:flex;align-items:center;gap:var(--s-3)}
.usage{font-family:var(--mono);font-size:var(--t-xs);color:var(--muted);margin-top:var(--s-3);padding:10px 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm)}
.comp{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);font-size:var(--t-sm);font-weight:600;box-shadow:var(--shadow-rest)}
.comp .st{margin-left:auto;font-family:var(--display);font-weight:700;font-size:9px;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:var(--r-pill);white-space:nowrap}
.comp .st.done{background:var(--green-soft);color:var(--green)} .comp .st.todo{background:transparent;color:var(--muted);border:1px dashed var(--grey)}
.rule-note{font-size:var(--t-sm);color:var(--muted);background:var(--surface);border:1px dashed var(--line);border-radius:var(--r-sm);padding:var(--s-4);margin:var(--s-8) 0 0} .rule-note b{color:var(--ink)}

/* ===== atomic components (token-driven, no one-off styles) ===== */
.comp-demo{margin-top:var(--s-4);padding:var(--s-5);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-rest)}
.demo-label{font-family:var(--mono);font-size:var(--t-xs);color:var(--muted);margin-bottom:var(--s-3)}
.demo-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.btn{font-family:var(--display);font-weight:700;font-size:var(--t-sm);color:#fff;background:var(--indigo);border-radius:var(--r-sm);padding:0 16px;min-height:40px;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 12px rgba(109,40,217,.22);transition:filter .15s}
.btn:hover{filter:brightness(1.08)} .btn:active{filter:brightness(.95)}
.btn-ghost{background:transparent;color:var(--indigo-deep);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--indigo);background:var(--indigo-soft);filter:none}
.btn-sm{min-height:32px;font-size:var(--t-xs);padding:0 12px}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;filter:none}
.select{font-family:var(--body);font-size:var(--t-sm);color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);min-height:40px;padding:0 12px;display:inline-flex;align-items:center;gap:10px;min-width:190px;justify-content:space-between}
.select:hover{border-color:var(--indigo)} .select .chev{color:var(--muted);font-size:11px}
.select-menu{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;width:200px}
.select-opt{padding:9px 11px;border-radius:var(--r-sm);font-size:var(--t-sm)}
.select-opt.sel,.select-opt:hover{background:var(--indigo-soft);color:var(--indigo-deep)}
.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-size:var(--t-xs);font-weight:700;padding:4px 11px;border-radius:var(--r-pill)}
.chip .cd{width:7px;height:7px;border-radius:50%;flex:0 0 7px}
.chip.passed{background:var(--green-soft);color:var(--green)} .chip.passed .cd{background:var(--green)}
.chip.running{background:var(--amber-soft);color:var(--amber)} .chip.running .cd{background:var(--amber)}
.chip.failed{background:var(--red-soft);color:var(--red)} .chip.failed .cd{background:var(--red)}
.chip.ns{background:var(--grey-soft);color:var(--muted)} .chip.ns .cd{background:var(--grey)}
.chip.pending{background:transparent;border:1px dashed var(--grey);color:var(--muted)} .chip.pending .cd{border:1.5px dashed var(--grey)}
.chip.skipped{background:transparent;border:1px dashed var(--grey);color:var(--grey);opacity:.85} .chip.skipped .cd{display:none}
.score{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-weight:700;font-size:var(--t-sm);padding:5px 12px;border-radius:var(--r-pill)}
.score .lbl{font-family:var(--display);font-size:var(--t-xs);opacity:.85}
.score.pass{background:var(--green-soft);color:var(--green)}
.score.fail{background:var(--red-soft);color:var(--red)}
.metric{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-weight:700;font-size:var(--t-xs);padding:5px 10px;border-radius:var(--r-sm);background:var(--bg);border:1px solid var(--line);color:var(--ink)}
.metric .ml{font-family:var(--display);color:var(--muted);font-weight:600}
.metric.muted{color:var(--muted);font-style:italic}
.tag-pill{display:inline-flex;align-items:center;font-family:var(--display);font-weight:600;font-size:var(--t-xs);padding:4px 11px;border-radius:var(--r-pill);background:var(--indigo-soft);color:var(--indigo-deep)}
/* contextual "new" indicators — a DOT on the menu item that has new content (where), a slim BANNER on the new section (what) */
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(109,40,217,.40)}70%{box-shadow:0 0 0 7px rgba(109,40,217,0)}100%{box-shadow:0 0 0 0 rgba(109,40,217,0)}}
.nav{position:relative}
.ndot{position:absolute;top:10px;right:11px;width:8px;height:8px;border-radius:50%;background:var(--primary);animation:pulse 2.2s infinite}
.nav.on .ndot{background:#fff;animation:none}
.new-badge{display:inline-flex;align-items:center;font-family:var(--display);font-weight:700;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--primary);padding:3px 8px;border-radius:var(--r-pill);flex:0 0 auto;box-shadow:0 2px 6px rgba(109,40,217,.30)}
.new-badge.corner{position:absolute;top:12px;right:12px;z-index:2}
.new-flag{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--r-sm);background:var(--indigo-soft);border-left:3px solid var(--primary);font-size:var(--t-sm);margin-bottom:var(--s-3)}
.new-flag.hidden{display:none}
.new-flag .nft{flex:1;color:var(--ink)} .new-flag .nft b{color:var(--indigo-deep)}
.new-flag-x{width:26px;height:26px;border-radius:var(--r-sm);color:var(--muted);display:grid;place-items:center;font-size:17px;flex:0 0 26px}
.new-flag-x:hover{background:var(--surface);color:var(--ink)}

/* ===== mobile menu (≤1024 = one affordance) ===== */
.hamburger{display:none;position:fixed;top:12px;left:12px;z-index:120;width:44px;height:44px;border-radius:11px;background:var(--surface);border:1px solid var(--line);color:var(--ink);font-size:18px;place-items:center;box-shadow:var(--shadow-rest)}
.rail-scrim{display:none;position:fixed;inset:0;background:rgba(11,16,32,.42);backdrop-filter:blur(2px);z-index:55}
@media(max-width:1024px){
 .hamburger{display:grid}
 .collapse{display:none}
 .rail{position:fixed;left:-300px;width:300px;max-width:86vw;z-index:60;transition:left .24s var(--ease)}
 body.rail-open .rail{left:0;box-shadow:var(--shadow-pop)}
 body.rail-open .rail-scrim{display:block}
 .topbar{padding-left:68px}
}
@media(max-width:760px){
 :root{--t-micro:12px;--t-xs:13px;--t-sm:14.5px;--t-base:15.5px;--t-md:17px;--t-lg:19px;--t-xl:22px;--t-2xl:26px;--t-3xl:30px;}
 body{line-height:1.6}
 .cols-4,.cols-3,.cols-2{grid-template-columns:1fr 1fr}
 .page{padding:var(--s-5)}
}
@media(max-width:480px){ .cols-4,.cols-3,.cols-2{grid-template-columns:1fr} }
