/* ============================================================================
   VirtualBytes Tools — main stylesheet
   Extracted from inline <style> block in index.html for cacheability.
   ============================================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ff:'DM Sans',sans-serif;
  --fm:'DM Mono',monospace;
  --fd:'Outfit',sans-serif;
  --ac:#2563eb;--ac2:#1d4ed8;
  --green:#059669;--red:#dc2626;--amber:#d97706;
  --radius:10px;--radius-sm:6px;--radius-lg:14px;
  --nav-h:48px;

  /* ── Theme tokens (dark — default) ─────────────────────────────── */
  --bg:           #0d1117;
  --bg-1:         #161b22;
  --bg-2:         #21262d;
  --border:       #30363d;
  --border-soft:  #21262d;
  --text:         #e2e8f0;
  --text-2:       #8b949e;
  --text-3:       #6e7681;
  --text-4:       #484f58;
  --link:         #58a6ff;
  --link-2:       #79c0ff;
  --hero-title:   #f1f5f9;
  --hero-title-fade: rgba(241,245,249,.32);
  --shadow:       0 8px 28px rgba(0,0,0,.5);
  --shadow-strong:0 16px 64px rgba(0,0,0,.7);
  --shadow-card:  0 0 0 3px rgba(59,130,246,.12);
  --overlay-bg:   rgba(0,0,0,.6);
}

/* ── Light theme overrides ─────────────────────────────────────────── */
:root[data-theme="light"]{
  --bg:           #f6f8fa;
  --bg-1:         #ffffff;
  --bg-2:         #eaeef2;
  --border:       #c0c8d0;
  --border-soft:  #d8dee4;
  --text:         #0a0c0f;
  --text-2:       #424a53;
  --text-3:       #57606a;
  --text-4:       #6e7781;
  --link:         #0550ae;
  --link-2:       #033d8b;
  --hero-title:   #0a0c0f;
  --hero-title-fade: rgba(10,12,15,.38);
  --shadow:       0 8px 28px rgba(31,35,40,.08);
  --shadow-strong:0 16px 64px rgba(31,35,40,.18);
  --shadow-card:  0 0 0 3px rgba(9,105,218,.12);
  --overlay-bg:   rgba(31,35,40,.45);
}

/* Tool tags need stronger contrast in light mode — the default dark-grey
   background doesn't read well against off-white card body */
:root[data-theme="light"] .tool-tag{
  background:#eaeef2;
  color:#1f2328;
  border-color:#c0c8d0;
  font-weight:500;
}

/* Tool card itself slightly elevated in light mode */
:root[data-theme="light"] .tool-card{
  background:#ffffff;
  border-color:#d0d7de;
  box-shadow:0 1px 0 rgba(31,35,40,.04);
}
:root[data-theme="light"] .tool-card:hover{
  border-color:#0969da;
  box-shadow:0 8px 24px rgba(31,35,40,.12);
}

/* Tool card footer needs visible separation */
:root[data-theme="light"] .tool-card-footer{
  background:#f6f8fa;
}

/* Search wrap, filter pills, code-style elements — bump backgrounds */
:root[data-theme="light"] .search-wrap,
:root[data-theme="light"] .f-pill,
:root[data-theme="light"] .jb-inner,
:root[data-theme="light"] .jb-pill{
  background:#ffffff;
  border-color:#d0d7de;
}
:root[data-theme="light"] .f-pill.on{
  background:#0969da;
  border-color:#0969da;
  color:#fff;
}

/* Status-pill / nav badges, group headers, eyebrow */
:root[data-theme="light"] .stat-lbl,
:root[data-theme="light"] .group-desc,
:root[data-theme="light"] .group-count,
:root[data-theme="light"] .arch-badge,
:root[data-theme="light"] .wf-badge,
:root[data-theme="light"] .ticker-label,
:root[data-theme="light"] .hero-eyebrow{
  color:#424a53;
}

/* Architecture / workflow toggles need readable label color */
:root[data-theme="light"] .arch-toggle,
:root[data-theme="light"] .wf-toggle{
  color:#1f2328;
}

/* Ticker items — were near-invisible */
:root[data-theme="light"] .ticker-wrap{
  background:#ffffff;
  border-bottom-color:#d0d7de;
}
:root[data-theme="light"] .ticker-item{
  color:#424a53;
  border-right-color:#eaeef2;
}
:root[data-theme="light"] .ticker-label{
  background:#f6f8fa;
  color:#0969da;
}

/* Hero subtitle */
:root[data-theme="light"] .hero-sub{
  color:#424a53;
}

/* Section dividers need slight bump in light mode for visibility */
:root[data-theme="light"] .group-hdr{
  border-bottom-color:#d0d7de;
}
:root[data-theme="light"] .stats{
  border-top-color:#d0d7de;
}
:root[data-theme="light"] .stat{
  border-right-color:#d0d7de;
}

/* Footer */
:root[data-theme="light"] .footer{
  background:#f6f8fa;
  border-top-color:#d0d7de;
}

/* Filter banner */
:root[data-theme="light"] .filter-banner{
  background:rgba(9,105,218,.06);
  border-color:rgba(9,105,218,.2);
  color:#0550ae;
}
html{scroll-behavior:smooth}
body{font-family:var(--ff);background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;transition:background-color .2s,color .2s}

/* ── Ticker ── */
.ticker-wrap{height:34px;overflow:hidden;background:var(--bg-1);border-bottom:1px solid var(--border-soft);display:flex;align-items:center}
.ticker-label{font-family:var(--fm);font-size:10px;color:var(--link);letter-spacing:.1em;text-transform:uppercase;padding:0 16px;border-right:1px solid var(--border);height:100%;display:flex;align-items:center;white-space:nowrap;background:var(--bg);flex-shrink:0}
.ticker-outer{overflow:hidden;flex:1}
.ticker-track{display:flex;align-items:center;animation:ticker 32s linear infinite;white-space:nowrap}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:8px;padding:0 32px;border-right:1px solid var(--border-soft);font-family:var(--fm);font-size:11px;color:var(--text-2);white-space:nowrap}
.ticker-pill{font-size:9px;font-weight:700;padding:1px 7px;border-radius:8px;letter-spacing:.04em;flex-shrink:0}
.ticker-pill.new{background:rgba(31,111,235,.25);color:var(--link);border:1px solid rgba(31,111,235,.4)}

.ticker-pill.live{background:rgba(139,148,158,.1);color:var(--text-3);border:1px solid var(--border)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){
  .ticker-track{animation:none}
  .tool-card.animate-in{animation:none}
  html{scroll-behavior:auto}
}

/* ── Nav ── */
.nav{position:sticky;top:0;z-index:200;background:linear-gradient(135deg,#0d2061,#1d4ed8);height:var(--nav-h);display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 2px 20px rgba(0,0,0,.4)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-brand{display:flex;align-items:center;gap:9px;text-decoration:none}
.nav-icon{width:28px;height:28px;border-radius:7px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center}
.nav-wordmark{font-family:var(--fd);font-size:14px;font-weight:700;color:#fff;letter-spacing:-.02em}
.nav-wordmark span{color:rgba(255,255,255,.35)}
.nav-wordmark-sub{display:block;font-family:var(--fm);font-size:9px;color:rgba(255,255,255,.3);letter-spacing:.06em;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.65);text-decoration:none;padding:5px 10px;border-radius:6px;transition:all .15s}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-sep{width:1px;height:16px;background:rgba(255,255,255,.18);margin:0 4px}

/* ── Hero ── */
.hero{padding:52px 32px 36px;text-align:center;border-bottom:1px solid var(--border-soft)}
.hero-eyebrow{font-family:var(--fm);font-size:10px;color:#3b82f6;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}
.hero-title{font-family:var(--fd);font-size:clamp(28px,4.5vw,44px);font-weight:800;color:var(--hero-title);letter-spacing:-.04em;line-height:1.08;margin-bottom:12px}
.hero-title span{color:var(--hero-title-fade)}
.hero-sub{font-size:15px;color:var(--text-2);max-width:460px;margin:0 auto 28px;line-height:1.65;font-weight:300}

/* ── Search ── */
.search-wrap{max-width:500px;margin:0 auto 18px;display:flex;align-items:center;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:4px 4px 4px 14px;gap:8px;transition:border-color .2s,box-shadow .2s;position:relative}
.search-wrap:focus-within{border-color:var(--link);box-shadow:var(--shadow-card)}
.search-wrap svg{color:var(--text-4);flex-shrink:0}
.search-btn{flex:1;display:flex;align-items:center;justify-content:flex-start;gap:10px;background:transparent;border:none;outline:none;font-family:var(--fm);font-size:13px;color:var(--text);padding:8px 0;cursor:pointer;text-align:left;min-height:30px}
.search-btn-text{color:var(--text-4)}
.search-btn-hint{color:var(--text-4);font-size:11px;display:flex;align-items:center;gap:4px}
.search-btn-hint kbd{font-family:var(--fm);font-size:10px;color:var(--text-3);background:var(--bg-2);border:1px solid var(--border);border-radius:3px;padding:0 4px}
@media(max-width:480px){.search-btn-hint{display:none}}

/* ── Global focus-visible ring (a11y) ── */
:where(a,button,input,[tabindex]):focus-visible{outline:2px solid var(--link);outline-offset:2px;border-radius:4px}

/* ── Filters ── */
.filter-row{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.f-pill{font-family:var(--fm);font-size:11px;padding:5px 14px;border-radius:6px;border:1px solid var(--border);background:var(--bg-1);color:var(--text-2);cursor:pointer;transition:all .15s;letter-spacing:.02em;user-select:none;font-weight:inherit}
.f-pill:hover{border-color:var(--link);color:var(--link)}
.f-pill.on{background:var(--link);border-color:var(--link);color:#fff}
.f-count{font-size:9px;opacity:.7;margin-left:3px}

/* ── Stats ── */
.stats{display:flex;justify-content:center;border-top:1px solid var(--border-soft);margin-top:44px;padding-top:32px;flex-wrap:wrap;max-width:500px;margin-left:auto;margin-right:auto}
.stat{text-align:center;padding:0 32px;border-right:1px solid var(--border-soft)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--fd);font-size:28px;font-weight:800;color:var(--link);letter-spacing:-.04em;line-height:1}
.stat-lbl{font-family:var(--fm);font-size:10px;color:var(--text-4);letter-spacing:.08em;text-transform:uppercase;margin-top:5px}

/* ── Main content ── */
.main{max-width:1100px;margin:0 auto;padding:32px 24px 72px}

/* ── Jump back in ── */
.jump-back{margin-bottom:24px}
.jb-inner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap}
.jb-label{font-family:var(--fm);font-size:10px;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;flex-shrink:0}
.jb-divider{width:1px;height:16px;background:var(--border);flex-shrink:0}
.jb-pills{display:flex;gap:6px;flex-wrap:wrap}
.jb-pill{font-family:var(--fm);font-size:11px;padding:4px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-2);text-decoration:none;transition:all .15s}
.jb-pill:hover{border-color:var(--link);color:var(--link)}

/* ── Workflow groups ── */
.group{margin-bottom:36px}
.group.hidden{display:none}
.group-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border-soft)}
.group-icon{width:30px;height:30px;border-radius:8px;background:var(--bg-1);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-2)}
.group-icon svg{width:14px;height:14px}
.group-label{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text)}
.group-new{font-family:var(--fm);font-size:9px;font-weight:700;padding:2px 8px;border-radius:8px;background:rgba(31,111,235,.25);color:var(--link);border:1px solid rgba(31,111,235,.35);letter-spacing:.04em;flex-shrink:0}
.group-desc{font-family:var(--fm);font-size:11px;color:var(--text-4);margin-left:auto;text-align:right}
.group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}

/* ── Tool cards — dark overrides ── */
.tool-card{display:flex;flex-direction:column;background:var(--bg-1);border:1px solid var(--border);border-radius:10px;text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s;overflow:hidden;position:relative}
.tool-card:hover{border-color:var(--link);transform:translateY(-3px);box-shadow:var(--shadow)}

/* #4 Primary group (Pre-Deployment) gets a subtle "this is where to start"
   treatment: stronger label color and a "Start here" affordance. */
.group[data-group="predeployment"] > .group-hdr > .group-label{color:var(--text)}
.group[data-group="predeployment"] > .group-hdr > .group-label::before{content:"";display:inline-block;width:3px;height:14px;background:var(--link);border-radius:2px;margin-right:8px;vertical-align:-2px}
.group[data-group="predeployment"] > .group-hdr > .group-desc::after{content:" · Start here";color:var(--link);font-weight:600;font-family:var(--fm)}
.tool-card-accent{height:3px;background:var(--card-color,#2563eb);opacity:.7;flex-shrink:0}
.tool-card-body{padding:14px 16px 10px;display:flex;flex-direction:column;flex:1}
.tool-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;flex-shrink:0}
.tool-card-name{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3;display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.tool-card-arrow{opacity:0;transform:translateX(-4px);transition:opacity .15s,transform .15s;color:var(--link);flex-shrink:0;margin-top:1px}
.tool-card:hover .tool-card-arrow{opacity:1;transform:translateX(0)}
.tool-card-desc{font-size:11px;color:var(--text-2);line-height:1.6;margin-bottom:10px;flex:1;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}
.tool-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.tool-tag{font-family:var(--fm);font-size:11px;padding:3px 8px;border-radius:5px;background:var(--bg-2);color:var(--text-3);border:1px solid var(--border);letter-spacing:.02em}
.tool-card-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg);border-top:1px solid var(--border-soft);flex-shrink:0}
.tool-card-status{display:flex;align-items:center;gap:5px;font-family:var(--fm);font-size:10px}
.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.status-live{background:#3fb950;box-shadow:0 0 6px rgba(63,185,80,.45)}
.tool-card-btn{font-family:var(--fd);font-size:10px;font-weight:700;padding:4px 12px;border-radius:5px;display:flex;align-items:center;gap:4px;transition:all .15s;cursor:pointer;border:none}
.btn-live{background:var(--link);color:#fff}
.btn-live:hover{background:var(--link-2)}
.tool-card-new-badge{position:absolute;top:10px;right:10px;font-family:var(--fm);font-size:9px;font-weight:700;padding:2px 7px;border-radius:8px;background:rgba(31,111,235,.3);color:var(--link);border:1px solid rgba(58,140,255,.4);letter-spacing:.04em}

/* ── No results ── */
.no-results{display:none;text-align:center;padding:56px 24px;font-family:var(--fm);font-size:13px;color:var(--text-4)}
.no-results.show{display:block}

/* ── Footer ── */
.footer{background:var(--bg-1);border-top:1px solid var(--border-soft);padding:16px 24px}
.vb-status-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:11px;color:var(--text-2);text-decoration:none;padding:5px 12px;border-radius:20px;border:1px solid var(--border-soft);background:rgba(0,0,0,.2);transition:border-color .15s,color .15s}
.vb-status-pill:hover{border-color:var(--border);color:var(--text)}
.vb-status-pill .vb-dot{width:8px;height:8px;border-radius:50%;background:var(--text-4);flex-shrink:0;box-shadow:0 0 0 3px rgba(110,118,129,.12)}
.vb-status-pill.s-operational .vb-dot{background:#3fb950;box-shadow:0 0 0 3px rgba(63,185,80,.18)}
.vb-status-pill.s-degraded .vb-dot{background:#f0883e;box-shadow:0 0 0 3px rgba(240,136,62,.18);animation:vb-pulse 2s ease-in-out infinite}
.vb-status-pill.s-down .vb-dot{background:#f85149;box-shadow:0 0 0 3px rgba(248,81,73,.18);animation:vb-pulse 2s ease-in-out infinite}
.vb-status-pill.s-operational{color:#3fb950;border-color:rgba(63,185,80,.3)}
.vb-status-pill.s-degraded{color:#f0883e;border-color:rgba(240,136,62,.3)}
.vb-status-pill.s-down{color:#f85149;border-color:rgba(248,81,73,.3)}
@keyframes vb-pulse{0%,100%{opacity:1}50%{opacity:.45}}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-copy{font-family:var(--fm);font-size:11px;color:var(--text-4)}
.footer-copy a{color:var(--link);text-decoration:none}
.footer-copy a:hover{color:var(--link-2)}
.footer-links{display:flex;align-items:center;gap:12px}
.footer-link{font-family:var(--fm);font-size:11px;color:var(--text-4);text-decoration:none;transition:color .15s}
.footer-link:hover{color:var(--link)}

/* ── Hidden ── */
.hidden{display:none !important}

/* ── Theme toggle in nav ───────────────────────────────────────────── */
.nav-link-btn{background:none;border:none;cursor:pointer;font:inherit}
.nav-icon-btn{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.7);margin-left:6px;transition:all .15s;flex-shrink:0}
.nav-icon-btn:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25)}
.theme-icon-light{display:none}
:root[data-theme="light"] .theme-icon-dark{display:none}
:root[data-theme="light"] .theme-icon-light{display:block}

/* ── Stat as clickable button (About modal trigger) ────────────────── */
.stat-btn{background:none;border:none;cursor:pointer;font-family:inherit;color:inherit;padding:0 32px;border-right:1px solid var(--border-soft);transition:transform .15s}
.stat-btn:last-child{border-right:none}
.stat-btn:hover .stat-info{color:var(--link);opacity:1}
.stat-btn:hover .stat-num{transform:scale(1.04)}
.stat-btn .stat-num{transition:transform .15s}
.stat-info{margin-left:4px;font-size:9px;color:var(--text-4);opacity:.5;transition:all .15s}

/* ── About modal ───────────────────────────────────────────────────── */
.about-overlay{position:fixed;inset:0;background:var(--overlay-bg);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:5vh 20px;overflow-y:auto}
.about-overlay[hidden]{display:none}
.about-overlay.open{display:flex}
.about-box{width:min(680px,100%);background:var(--bg-1);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 64px rgba(0,0,0,.5);overflow:hidden;animation:cmdS .15s ease-out;margin:auto 0}
.about-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border-soft)}
.about-title{font-family:var(--fd);font-size:17px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:10px;margin:0}
.about-title svg{color:#3fb950;flex-shrink:0}
.about-close{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:none;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transition:all .15s}
.about-close:hover{border-color:#f85149;color:#f85149}
.about-body{padding:18px 24px 8px;max-height:70vh;overflow-y:auto}
.about-lede{font-size:14px;color:var(--text);line-height:1.6;margin-bottom:18px;padding:14px 16px;background:rgba(63,185,80,.08);border:1px solid rgba(63,185,80,.2);border-radius:10px;border-left:3px solid #3fb950}
.about-lede strong{color:#3fb950}
.about-h3{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text);margin:18px 0 10px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.about-h3::before{content:"";width:3px;height:14px;background:var(--link);border-radius:2px}
.about-list{list-style:none;padding:0;margin:0 0 6px}
.about-list li{font-size:12.5px;color:var(--text-2);line-height:1.7;padding:6px 0 6px 22px;position:relative}
.about-list li::before{content:"›";position:absolute;left:6px;top:6px;color:var(--link);font-weight:700}
.about-list li strong{color:var(--text);font-weight:600}
.about-list li code{font-family:var(--fm);font-size:11px;background:var(--bg-2);padding:1px 6px;border-radius:4px;color:var(--text);border:1px solid var(--border-soft)}
.about-p{font-size:12.5px;color:var(--text-2);line-height:1.65;margin:8px 0 12px}
.about-p a, .about-list li a{color:var(--link);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}
.about-p a:hover, .about-list li a:hover{border-bottom-color:var(--link)}
.about-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid var(--border-soft);background:var(--bg);gap:14px;flex-wrap:wrap}
.about-footer-meta{font-family:var(--fm);font-size:10px;color:var(--text-4)}
.about-footer-meta a{color:var(--text-3);text-decoration:none}
.about-footer-meta a:hover{color:var(--link)}
.about-footer-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--fd);font-size:12px;font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer;background:var(--link);color:#fff;border:none;text-decoration:none;transition:all .15s}
.about-footer-btn:hover{background:var(--link-2);color:#fff}
.about-footer-btn svg{flex-shrink:0}

/* ── #1 Sticky mini-nav (appears after scroll past hero) ──────────── */
.sticky-nav{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(13,17,23,.78);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--border);transform:translateY(-100%);transition:transform .2s ease-out,opacity .2s;opacity:0;pointer-events:none}
:root[data-theme="light"] .sticky-nav{background:rgba(255,255,255,.82)}
.sticky-nav.visible{transform:translateY(0);opacity:1;pointer-events:auto}
.sticky-nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:48px;display:flex;align-items:center;gap:12px}
.sticky-nav-brand{display:inline-flex;align-items:center;gap:8px;font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text);text-decoration:none;flex-shrink:0}
.sticky-nav-brand:hover{color:var(--link)}
.sticky-nav-search{flex:1;max-width:480px;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-1);color:var(--text-3);font-family:var(--ff);font-size:12px;cursor:pointer;transition:all .15s}
.sticky-nav-search:hover{border-color:var(--link);color:var(--text-2)}
.sticky-nav-search > span{flex:1;text-align:left}
.sticky-nav-kbd{font-family:var(--fm);font-size:9px;color:var(--text-3);background:var(--bg-2);border:1px solid var(--border-soft);border-radius:3px;padding:1px 5px}
.sticky-nav-status{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-1);text-decoration:none;flex-shrink:0;transition:all .15s}
.sticky-nav-status:hover{border-color:var(--link)}
.sticky-nav-status .vb-dot{width:8px;height:8px;border-radius:50%;background:#3fb950;box-shadow:0 0 0 2px rgba(63,185,80,.2)}
.sticky-nav-status.s-degraded .vb-dot{background:#fbbf24;box-shadow:0 0 0 2px rgba(251,191,36,.2)}
.sticky-nav-status.s-down .vb-dot{background:#f85149;box-shadow:0 0 0 2px rgba(248,81,73,.2)}
.sticky-nav-status.s-unknown .vb-dot{background:#6e7681;box-shadow:0 0 0 2px rgba(110,118,129,.2)}
.sticky-nav-theme{margin-left:auto}
@media (max-width: 640px){
  .sticky-nav-inner{padding:0 12px;gap:8px}
  .sticky-nav-search > span{display:none}
  .sticky-nav-kbd{display:none}
  .sticky-nav-search{flex:0;padding:6px 10px}
  .sticky-nav-brand span{display:none}
}

/* ── #23 Skip-to-content link ──────────────────────────────────────── */
.skip-to-content{position:absolute;left:8px;top:-100px;z-index:10000;padding:8px 14px;border-radius:6px;background:var(--link);color:#fff;font-family:var(--fd);font-size:13px;font-weight:600;text-decoration:none;transition:top .15s}
.skip-to-content:focus{top:8px;outline:2px solid var(--text);outline-offset:2px}

/* ── #24 ARIA live region for filter announcements (visually hidden) ─ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── #6 Empty state for "no results" ──────────────────────────────── */
.no-results{display:none;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;text-align:center;color:var(--text-3)}
.no-results.show{display:flex}
.no-results svg{color:var(--text-4);margin-bottom:6px}
.no-results-title{font-family:var(--fd);font-size:15px;font-weight:600;color:var(--text)}
.no-results-hint{font-size:12px;color:var(--text-2)}
.no-results-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:8px}
.no-results-chip{font-family:var(--fm);font-size:11px;padding:6px 14px;border-radius:14px;border:1px solid var(--border);background:var(--bg-1);color:var(--text-2);cursor:pointer;transition:all .15s}
.no-results-chip:hover{border-color:var(--link);color:var(--link);background:var(--bg-2)}
.no-results-query{font-family:var(--fm);background:var(--bg-2);padding:1px 8px;border-radius:5px;border:1px solid var(--border);color:var(--link);font-size:14px}

/* ── #32 Jump-Back empty state ─────────────────────────────────────── */
.jump-back.jump-back-empty{display:none}
.jump-back.jump-back-empty.show{display:block}
.jb-empty-hint{font-family:var(--fm);font-size:11px;color:var(--text-3);font-style:italic}

/* ── #37 Updated timestamp in footer ───────────────────────────────── */
.updated-stamp{font-family:var(--fm);font-size:10px;color:var(--text-4);opacity:.7}

/* ── #22 Mobile touch target sizing — 44px minimum on small screens ── */
@media (max-width: 640px) {
  .f-pill{min-height:38px;padding:8px 14px}
  .nav-link{min-height:38px;padding:8px 12px;display:inline-flex;align-items:center}
  .nav-icon-btn{width:38px;height:38px}
  .jb-pill{min-height:36px;display:inline-flex;align-items:center}
  .copy-btn{min-width:38px;min-height:38px}
  .footer-link{min-height:36px;display:inline-flex;align-items:center}
  .no-results-chip{min-height:36px;padding:8px 16px}
}

/* ── #26 Reduced-motion audit: disable non-essential animations ────── */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .ticker-track{animation:none !important}
  .skip-to-content{transition:none}
}

/* ── #23 No-JS fallback banner ─────────────────────────────────────── */
.noscript-banner{padding:14px 20px;background:#fbbf24;color:#1f2328;font-family:var(--ff);font-size:13px;font-weight:500;text-align:center;border-bottom:1px solid #d97706}

/* ── #35 Print stylesheet ──────────────────────────────────────────── */
@media print {
  /* Hide chrome that doesn't make sense on paper */
  .vb-nav, .ticker-wrap, .search-wrap, .filters, .stats, .nav-icon-btn,
  .skip-to-content, .filter-banner, .footer, .changelog, .arch-section,
  .wf-section, .jump-back, .jump-back-empty, .deploy-cta, .copy-link-btn,
  .tool-card-arrow, .group-new, .tool-card-new-badge, .stat-info,
  .cmd-overlay, .wiz-overlay, .about-overlay, .updated-stamp,
  #LIVE_REGION, .noscript-banner {
    display: none !important;
  }

  /* Force light styling for print regardless of theme */
  html, body { background: #fff !important; color: #000 !important; }
  .hero { padding: 0 0 16pt; text-align: left; }
  .hero-title { font-size: 24pt; color: #000; }
  .hero-title span { color: #444; opacity: 1; }
  .hero-eyebrow { font-size: 9pt; color: #666; margin-bottom: 6pt; }
  .hero-sub { font-size: 11pt; color: #333; margin-bottom: 0; }

  /* Make groups print as flat sections, two-column tool grids */
  .group { page-break-inside: avoid; margin-bottom: 16pt; }
  .group-hdr { border-bottom: 1pt solid #999; padding-bottom: 4pt; margin-bottom: 8pt; }
  .group-label { color: #000; font-size: 13pt; }
  .group-desc, .group-count { color: #555; }
  .group-icon { display: none; }

  .group-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8pt;
  }

  /* Tool cards: simplified for paper */
  .tool-card {
    border: 1pt solid #999 !important;
    border-left: 3pt solid #555 !important;
    background: #fff !important;
    padding: 6pt;
    page-break-inside: avoid;
    box-shadow: none !important;
    transform: none !important;
  }
  .tool-card-icon, .tool-card-accent, .chain-badge { display: none; }
  .tool-card-name { font-size: 11pt; color: #000; font-weight: 700; }
  .tool-card-desc { font-size: 9pt; color: #333; margin-top: 4pt; }
  .tool-card-tags { margin-top: 4pt; }
  .tool-tag {
    background: transparent !important;
    border: 1pt solid #aaa !important;
    color: #555 !important;
    font-size: 8pt;
    padding: 1pt 4pt;
  }
  .tool-card-footer { display: none; }

  /* URL after each tool name so printed copies are useful */
  .tool-card[href]::after {
    content: " → " attr(href);
    font-family: monospace;
    font-size: 8pt;
    color: #666;
    display: block;
    margin-top: 2pt;
  }

  /* No animations; no hover states */
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

/* ── Responsive ── */
@media(max-width:600px){
  .hero{padding:36px 20px 28px}
  .main{padding:24px 16px 48px}
  .stats{gap:0}.stat{padding:0 16px}
  .group-desc{display:none}
  .ticker-label{display:none}
}

.copy-link-btn{width:24px;height:24px;border-radius:5px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all .15s;flex-shrink:0}
.copy-link-btn svg{width:11px;height:11px;color:var(--text-3)}
.tool-card:hover .copy-link-btn{opacity:1}
.copy-link-btn:hover{background:rgba(255,255,255,.1)}
.copy-link-btn.copied{background:rgba(63,185,80,.2);border-color:rgba(63,185,80,.4)}
.copy-link-btn.copied svg{color:#3fb950}
.group-count{font-family:var(--fm);font-size:10px;color:var(--text-4);background:var(--bg-2);border:1px solid var(--border-soft);padding:2px 8px;border-radius:10px;margin-left:8px}
.changelog-wrap{margin-bottom:0;background:var(--bg-1);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.changelog-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;user-select:none}
.changelog-hdr:hover{background:var(--bg-2)}
.changelog-hdr-left{display:flex;align-items:center;gap:10px}
.changelog-hdr-icon{width:28px;height:28px;border-radius:7px;background:rgba(188,140,255,.15);border:1px solid rgba(188,140,255,.2);display:flex;align-items:center;justify-content:center}
.changelog-hdr-icon svg{width:14px;height:14px;color:#bc8cff}
.changelog-title{font-family:var(--fm);font-size:12px;font-weight:700;color:var(--text)}
.changelog-sub{font-family:var(--fm);font-size:10px;color:var(--text-4);margin-left:8px}
.changelog-chev{color:var(--text-4);transition:transform .2s}
.changelog-chev.open{transform:rotate(180deg)}
.changelog-body{display:none;border-top:1px solid var(--border-soft)}
.changelog-body.open{display:block}
.cl-entry{padding:14px 18px;border-bottom:1px solid var(--border-soft);display:flex;gap:14px}
.cl-entry:last-child{border-bottom:none}
.cl-date{font-family:var(--fm);font-size:10px;color:var(--text-4);white-space:nowrap;min-width:72px;padding-top:2px}
.cl-items{display:flex;flex-direction:column;gap:5px}
.cl-item{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--text-2);line-height:1.5}
.cl-pill{font-family:var(--fm);font-size:9px;font-weight:700;padding:1px 6px;border-radius:4px;flex-shrink:0;margin-top:2px}
.pill-new{background:rgba(63,185,80,.2);color:#3fb950}
.pill-improved{background:rgba(37,99,235,.2);color:var(--link-2)}

/* ── Card entrance animation ── */
@keyframes cardIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tool-card.animate-in {
  animation: cardIn .35s cubic-bezier(.22,.68,0,1.2) both;
}

/* ── Active filter banner ── */
.filter-banner {
  display: none;
  align-items: center;
  justify-content: space-between;
  background: rgba(31,111,235,.1);
  border: 1px solid rgba(31,111,235,.25);
  border-radius: 8px;
  padding: 9px 14px;
  margin-bottom: 20px;
  font-family: var(--fm);
  font-size: 11px;
  color: var(--link);
}
.filter-banner.show { display: flex; }
.filter-banner-clear {
  background: none;
  border: none;
  color: var(--link);
  font-family: var(--fm);
  font-size: 10px;
  cursor: pointer;
  padding: 2px 8px;
  border-radius: 5px;
  border: 1px solid rgba(88,166,255,.3);
  transition: all .15s;
}
.filter-banner-clear:hover { background: rgba(88,166,255,.1); }

/* ── Keyboard shortcut hint on search ── */
.search-kbd {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--fm);
  font-size: 10px;
  color:var(--text-4);
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius: 4px;
  padding: 1px 5px;
  pointer-events: none;
  transition: opacity .15s;
}


/* Cmd Palette */.cmd-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:999;display:none;align-items:flex-start;justify-content:center;padding-top:min(20vh,160px)}.cmd-overlay.open{display:flex}.cmd-box{width:min(600px,92vw);background:var(--bg-1);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 64px var(--shadow-strong);overflow:hidden;animation:cmdS .15s ease-out}@keyframes cmdS{from{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:none}}.cmd-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border-soft)}.cmd-input-wrap svg{width:16px;height:16px;color:var(--text-3);flex-shrink:0}.cmd-input{flex:1;background:none;border:none;color:var(--text);font-size:15px;font-family:var(--ff);outline:none}.cmd-input::placeholder{color:var(--text-4)}.cmd-kbd{font-family:var(--fm);font-size:10px;color:var(--text-4);border:1px solid var(--border);border-radius:4px;padding:2px 6px}.cmd-results{max-height:360px;overflow-y:auto;padding:6px}.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;cursor:pointer;transition:background .1s;text-decoration:none;color:inherit}.cmd-item:hover,.cmd-item.active{background:var(--bg-2)}.cmd-item-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cmd-item-name{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--text)}.cmd-item-cat{font-family:var(--fm);font-size:9px;color:var(--text-4);padding:2px 7px;border-radius:4px;background:var(--bg);flex-shrink:0}.cmd-hint{padding:8px 14px;border-top:1px solid var(--border-soft);display:flex;gap:14px;font-family:var(--fm);font-size:10px;color:var(--text-4)}.cmd-hint kbd{border:1px solid var(--border);border-radius:3px;padding:1px 5px;color:var(--text-3)}.cmd-section{font-family:var(--fd);font-size:10px;font-weight:700;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;padding:8px 14px 4px}.cmd-empty{padding:32px 14px;text-align:center;color:var(--text-4);font-size:12px}
/* Arch */.arch-section{margin-bottom:24px}.arch-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px 0;font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text-2);transition:color .15s;border:none;background:none;width:100%}.arch-toggle:hover{color:var(--text)}.arch-toggle svg.chevron{width:14px;height:14px;transition:transform .2s}.arch-toggle.open svg.chevron{transform:rotate(90deg)}.arch-badge{font-family:var(--fm);font-size:9px;color:var(--text-3);padding:2px 7px;border-radius:8px;background:var(--bg-1);border:1px solid var(--border);margin-left:auto}.arch-body{display:none;padding:0 0 16px}.arch-body.open{display:block}.arch-diagram{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:24px 24px 32px;overflow:visible}.arch-row{display:flex;gap:12px;justify-content:center;margin-bottom:8px;flex-wrap:wrap}.arch-node{padding:10px 16px;border-radius:10px;border:2px solid;cursor:pointer;transition:all .2s;text-align:center;min-width:120px;position:relative}.arch-node:hover{box-shadow:0 4px 20px var(--shadow-strong);transform:translateY(-2px)}.arch-node:hover::after{content:"click for tools";position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-family:var(--fm);font-size:9px;color:var(--text-3);background:var(--bg-1);padding:2px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;opacity:0;animation:archHint .15s ease-out .3s forwards}@keyframes archHint{to{opacity:1}}.arch-node.open{transform:translateY(-2px)}.arch-node.open:hover::after{display:none}.arch-node-name{font-family:var(--fd);font-size:12px;font-weight:700;color:var(--text);margin-bottom:2px}.arch-node-sub{font-family:var(--fm);font-size:9px;opacity:.7}.arch-node-tools{position:absolute;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--link);border-radius:8px;padding:8px;box-shadow:0 8px 32px var(--shadow-strong);z-index:50;display:none;min-width:200px;white-space:nowrap;bottom:100%;margin-bottom:8px}.arch-node.open .arch-node-tools{display:block}.arch-tool-link{display:block;padding:6px 12px;border-radius:5px;font-size:11px;color:var(--text);text-decoration:none;transition:all .1s;font-weight:500}.arch-tool-link:hover{background:var(--bg-2);color:var(--link)}.arch-connector{display:flex;justify-content:center;padding:2px 0}.arch-connector svg{width:12px;height:12px;color:var(--border)}
/* Workflows */.wf-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px 0;font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text-2);transition:color .15s;border:none;background:none;width:100%}.wf-toggle:hover{color:var(--text)}.wf-toggle svg.chevron{width:14px;height:14px;transition:transform .2s}.wf-toggle.open svg.chevron{transform:rotate(90deg)}.wf-badge{font-family:var(--fm);font-size:9px;color:var(--text-3);padding:2px 7px;border-radius:8px;background:var(--bg-1);border:1px solid var(--border);margin-left:auto}.wf-body{display:none;padding:0 0 16px}.wf-body.open{display:block}.wf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.wf-card{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:16px 18px;cursor:pointer;transition:all .15s}.wf-card:hover{border-color:var(--link);background:var(--bg-2)}.wf-card.expanded{border-color:var(--link);background:var(--bg-2)}.wf-card-hdr{display:flex;align-items:center;gap:8px;margin-bottom:8px}.wf-card-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wf-card-title{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--text)}.wf-card-desc{font-size:11px;color:var(--text-3);line-height:1.5;margin-bottom:10px}.wf-steps{display:flex;align-items:center;gap:0;flex-wrap:wrap}.wf-step{font-family:var(--fm);font-size:10px;color:var(--link);padding:3px 8px;border-radius:5px;background:rgba(31,111,235,.1);border:1px solid rgba(31,111,235,.2)}.wf-step-arrow{color:var(--border);font-size:12px;padding:0 3px}.wf-expanded{display:none;margin-top:12px;border-top:1px solid var(--border);padding-top:10px}.wf-card.expanded .wf-expanded{display:block}.wf-tool-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;text-decoration:none;transition:all .1s;margin-bottom:2px;color:inherit}.wf-tool-row:hover{background:var(--bg-2)}.wf-tool-num{width:22px;height:22px;border-radius:50%;background:rgba(31,111,235,.2);color:var(--link);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:10px;font-weight:700;flex-shrink:0}.wf-tool-name{font-size:12px;font-weight:600;color:var(--text);flex:1}.wf-tool-arrow{color:var(--text-4)}.wf-tool-row:hover .wf-tool-arrow{color:var(--link)}
/* Wizard */.wiz-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:998;display:none;align-items:center;justify-content:center}.wiz-overlay.open{display:flex}.wiz-box{width:min(560px,92vw);background:var(--bg-1);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 64px var(--shadow-strong);overflow:hidden;animation:cmdS .15s ease-out}.wiz-hdr{padding:18px 22px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.wiz-hdr-title{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}.wiz-hdr-title svg{width:18px;height:18px;color:var(--link)}.wiz-close{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:none;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.wiz-close:hover{border-color:#f85149;color:#f85149}.wiz-body{padding:20px 22px}.wiz-step{display:none}.wiz-step.active{display:block}.wiz-q{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--text);margin-bottom:14px}.wiz-opts{display:flex;flex-direction:column;gap:8px}.wiz-opt{display:flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;background:var(--bg)}.wiz-opt:hover{border-color:var(--link);background:var(--bg-2)}.wiz-opt.selected{border-color:var(--link);background:rgba(31,111,235,.08)}.wiz-opt-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wiz-opt-name{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--text)}.wiz-opt-desc{font-size:11px;color:var(--text-3);margin-top:2px}.wiz-progress{display:flex;gap:4px;padding:0 22px 6px}.wiz-dot{height:3px;flex:1;border-radius:2px;background:var(--bg-2);transition:background .3s}.wiz-dot.done{background:var(--link)}.wiz-dot.active{background:#3b82f6}.wiz-result{padding:20px 22px}.wiz-result-title{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}.wiz-result-sub{font-size:12px;color:var(--text-3);margin-bottom:16px}.wiz-result-tools{display:flex;flex-direction:column;gap:6px}.wiz-result-tool{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;background:var(--bg);border:1px solid var(--border);text-decoration:none;transition:all .15s;color:inherit}.wiz-result-tool:hover{border-color:var(--link);background:var(--bg-2);transform:translateX(4px)}.wiz-result-num{width:24px;height:24px;border-radius:50%;background:rgba(31,111,235,.2);color:var(--link);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:11px;font-weight:700;flex-shrink:0}.wiz-result-name{font-size:12px;font-weight:600;color:var(--text);flex:1}.wiz-result-arrow{color:var(--border)}.wiz-result-tool:hover .wiz-result-arrow{color:var(--link)}.wiz-footer{padding:14px 22px;border-top:1px solid var(--border-soft);display:flex;justify-content:space-between;align-items:center}.wiz-btn{font-family:var(--fd);font-size:12px;font-weight:600;padding:8px 18px;border-radius:8px;cursor:pointer;border:none;transition:all .15s}.wiz-btn-back{background:none;border:1px solid var(--border);color:var(--text-2)}.wiz-btn-back:hover{border-color:var(--link);color:var(--link)}.wiz-btn-go{background:var(--link);color:#fff}.wiz-btn-go:hover{background:var(--link-2)}.wiz-btn:disabled{opacity:.3;cursor:default}.wiz-step-indicator{font-family:var(--fm);font-size:10px;color:var(--text-4)}
/* #20: Shareable plan link */
.wiz-result-share{margin-top:18px;padding-top:14px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.wiz-share-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--fd);font-size:12px;font-weight:600;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text-2);cursor:pointer;transition:all .15s}
.wiz-share-btn:hover{border-color:var(--link);color:var(--link);background:var(--bg-2)}
.wiz-share-btn.copied{border-color:#3fb950;color:#3fb950;background:rgba(63,185,80,.08)}
.wiz-share-btn svg{flex-shrink:0}
.wiz-share-hint{font-family:var(--fm);font-size:10px;color:var(--text-4);line-height:1.5}
/* Plan btn */.hero-plan-btn{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:9px 18px;border-radius:8px;border:1.5px solid #3b82f6;background:rgba(31,111,235,.08);color:var(--link);font-family:var(--fd);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.hero-plan-btn:hover{background:rgba(31,111,235,.15);border-color:var(--link);transform:translateY(-1px);box-shadow:0 4px 16px rgba(31,111,235,.2)}.hero-plan-btn svg{width:14px;height:14px}
/* Chain */.chain-badge{display:inline-flex;align-items:center;gap:3px;font-family:var(--fm);font-size:10px;color:#818cf8;background:rgba(129,140,248,.08);border:1px solid rgba(129,140,248,.2);border-radius:4px;padding:2px 6px;margin-left:4px;cursor:help}.chain-badge svg{width:10px;height:10px}
/* #7 Updated badge for cards with recent changelog entry */
.updated-badge{display:inline-flex;align-items:center;font-family:var(--fm);font-size:10px;color:#3fb950;background:rgba(63,185,80,.08);border:1px solid rgba(63,185,80,.25);border-radius:4px;padding:2px 6px;margin-left:4px;cursor:help;font-weight:500}
/* ============================================================
   styles.css — UX polish patch (2026-05-02)
   Append to the end of the file. Bump the version query string
   on the <link rel="stylesheet"> in index.html (?v=20260502).

   Each block is independent. Copy only what you want.
   ============================================================ */


/* ----------------------------------------------------------
   1. Sticky nav search button
   The button now contains only the magnifying-glass SVG and a
   kbd. Tighten internal padding so it doesn't look stretched
   without the "Search" text label.
   ---------------------------------------------------------- */
.sticky-nav-search{
  padding:6px 8px 6px 10px;
  gap:8px;
}
.sticky-nav-search .sticky-nav-kbd{
  margin-left:0;
}


/* ----------------------------------------------------------
   2. Hero stats — remove the "(?)" treatment
   The (?) is gone in markup; the new <svg.stat-link-arrow>
   sits next to "Data collected". If your styles.css has
   a .stat-info rule, you can delete it (no longer referenced).
   ---------------------------------------------------------- */
/* nothing required here — inline override in index.html
   handles the new arrow. Listed only so you remember to
   delete the .stat-info rule if it exists. */


/* ----------------------------------------------------------
   3. Tool card hover — calm it down
   If your styles.css does:
     .tool-card:hover{ transform: translateY(-4px) scale(1.02) }
     .tool-card:hover .tool-card-arrow{ transform: scale(1.3) translateX(4px) }
   replace those rules with the lighter touch below.
   ---------------------------------------------------------- */
.tool-card{
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease;
}
.tool-card:hover{
  transform:translateY(-2px);
  /* keep your existing box-shadow / border-color rules here */
}
.tool-card:hover .tool-card-arrow{
  transform:translateX(2px);
  opacity:1;
}


/* ----------------------------------------------------------
   4. Filter pill counts — stable widths
   Stops the row from reflowing as counts swap between 1 and 2
   digits. Tabular-nums keeps the glyphs aligned at any size.
   ---------------------------------------------------------- */
.f-pill .f-count{
  display:inline-block;
  min-width:1.4em;
  margin-left:6px;
  text-align:center;
  font-variant-numeric:tabular-nums;
  font-size:.85em;
  opacity:.7;
}
.f-pill.on .f-count{
  opacity:.9;
}


/* ----------------------------------------------------------
   5. Group headers — consistent two-row layout
   Row 1: icon · title · count · [New badge]
   Row 2: description (full width, secondary colour)
   The selector flex-basis:100% forces .group-desc onto its
   own row regardless of where it sits in source order.
   ---------------------------------------------------------- */
.group-hdr{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.group-hdr .group-icon{ flex-shrink:0; }
.group-hdr .group-label{ margin:0; }
.group-hdr .group-desc{
  flex-basis:100%;
  margin-top:2px;
  /* keep your existing .group-desc colour/size from styles.css */
}


/* ----------------------------------------------------------
   6. Workflow step arrows — chevron, not "→"
   Markup now uses <svg class="wf-step-arrow">. The flex
   alignment ensures the chevron sits on the text baseline
   regardless of pill height.
   ---------------------------------------------------------- */
.wf-steps{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
}
.wf-step-arrow{
  display:inline-block;
  vertical-align:middle;
  margin:0 2px;
  opacity:.55;
  flex-shrink:0;
  color:var(--fg-muted, #8b949e);
}
[data-theme="light"] .wf-step-arrow{
  color:var(--fg-muted-light, #6b7280);
}


/* ----------------------------------------------------------
   7. Hero CTA row
   "Plan my deployment" lives in its own row now, not inside
   .stats. Centered, breathing room above and below.
   ---------------------------------------------------------- */
.hero-cta-row{
  display:flex;
  justify-content:center;
  margin:22px 0 4px;
  padding:0 16px;
}
.hero-cta-row .hero-plan-btn{
  margin:0;       /* override any inline margin from old markup */
}
