/* (same design tokens & styles you already approved) */
:root{--brand:#C83242;--ink:#151515;--muted:#f4f5f7;--paper:#ffffff;--link:#C83242;--focus:#0a7cff;--radius:16px}
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.wrap{max-width:1120px;margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;padding:10px 12px;background:#000;color:#fff;border-radius:8px;z-index:1000}
.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}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid #eee}
.site-header .wrap{display:flex;align-items:center;gap:16px;min-height:64px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-weight:700;letter-spacing:.2px}
.brand-mark{display:inline-block;transform:rotate(45deg);border:2px solid var(--brand);border-radius:4px;padding:2px 6px;line-height:1}
.brand-text{font-size:18px}.brand-dot{color:var(--brand)}
.nav{display:flex;align-items:center;gap:20px;margin-left:auto}
.nav ul{display:flex;gap:18px;list-style:none;padding:0;margin:0}
.nav a{color:var(--ink);text-decoration:none}
.nav a:hover{text-decoration:underline}
.nav .btn{margin-left:6px}
.nav-toggle{display:none;margin-left:auto;border:1px solid #ddd;background:#fff;border-radius:8px;padding:6px 10px}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid transparent;padding:10px 16px;font-weight:600;text-decoration:none;cursor:pointer;transition:transform .08s ease, box-shadow .2s ease}
.btn:focus-visible{outline:3px solid var(--focus);outline-offset:2px}
.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--brand);color:#fff}.btn-ghost{background:#fff;border-color:#ddd;color:var(--ink)}.btn-inverse{background:#fff;color:var(--brand)}.btn-ghost-inverse{background:transparent;border-color:#fff;color:#fff}
.hero{padding:72px 0}.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:center}
.lead{font-size:1.125rem;opacity:.9}.cta-row{display:flex;gap:12px;margin:20px 0 8px}
.report-card{background:var(--ink);color:#fff;border-radius:var(--radius);padding:22px;box-shadow:0 12px 30px rgba(0,0,0,.25)}
.report-card .score{font-size:56px;font-weight:800;line-height:1}
.pill-row{display:flex;gap:8px;margin:8px 0 14px}
.pill{display:inline-block;border-radius:999px;padding:6px 10px;font-size:12px;border:1px solid rgba(255,255,255,.2)}
.pill.critical{background:#2a0004;border-color:#ff9aa6;color:#ff9aa6}.pill.warn{background:#1a1400;border-color:#ffd66e;color:#ffd66e}.pill.pass{background:#001a09;border-color:#7dffb3;color:#7dffb3}
.issue-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.issue-list li{display:flex;justify-content:space-between;gap:12px;background:rgba(255,255,255,.06);padding:10px 12px;border-radius:10px}
.section{padding:72px 0}.section-muted{background:var(--muted)}.section-cta{background:linear-gradient(180deg,var(--brand),#8f2030);color:#fff;text-align:center;border-top:1px solid rgba(255,255,255,.12)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;list-style:none;margin:22px 0 0;padding:0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--paper);border:1px solid #eee;border-radius:14px;padding:18px}
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price-card{background:#fff;border:1px solid #eee;border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:10px}
.price-card .price{font-size:34px;font-weight:800;margin:.25rem 0}.price-card .price span{font-size:14px;font-weight:600;opacity:.7}
.price-card.featured{border-color:var(--brand);box-shadow:0 10px 26px rgba(200,50,66,.18);position:relative}
.price-card .flag{position:absolute;top:-12px;right:16px;background:var(--brand);color:#fff;font-size:12px;font-weight:700;border-radius:999px;padding:6px 10px}
.scan-form{display:grid;gap:8px;max-width:640px}.scan-output{background:#0e1116;color:#d6e2ff;border-radius:10px;padding:10px;font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;font-size:12px;max-height:260px;overflow:auto}
.site-footer{border-top:1px solid #eee;background:#fafafa}.footer-grid{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:18px 0}
.site-footer nav a{color:var(--ink);text-decoration:none;margin-left:14px}.site-footer nav a:hover{text-decoration:underline}
@media (max-width:1000px){.hero-grid{grid-template-columns:1fr}.steps,.grid-3,.pricing{grid-template-columns:1fr}}
@media (max-width:760px){.nav{display:none}.nav.open{display:flex;flex-direction:column;align-items:flex-start;padding:12px 0}.nav-toggle{display:inline-block}.input-row{flex-direction:column}}

/* Results card */
.results{background:#fff;border:1px solid #eee;border-radius:14px;padding:16px;margin-top:18px}
.results > summary{cursor:pointer;list-style:none}
.results[open] > summary{margin-bottom:10px}

.results-grid{display:grid;grid-template-columns:repeat(5, minmax(120px,1fr));gap:12px;margin-bottom:10px}
.metric{background:var(--paper);border:1px solid #eee;border-radius:12px;padding:12px;display:flex;flex-direction:column;align-items:flex-start}
.metric .num{font-size:22px;font-weight:800;line-height:1;margin-bottom:2px}
.metric .label{font-size:12px;opacity:.8}

.actions{display:flex;gap:8px;align-items:center;margin-bottom:10px}

/* Stack metrics on narrow screens */
@media (max-width: 760px){
  .results-grid{grid-template-columns:1fr 1fr}
}

/* Deep Contrast toggle */
.opts{margin:8px 0 0; font-size:.95rem; opacity:.95}
.opts-toggle{display:inline-flex; align-items:center; gap:.5rem; cursor:pointer}
.opts .help{display:block; font-size:.85rem; opacity:.75; margin-top:4px}
.opts input[type="checkbox"]{width:1.1rem; height:1.1rem; accent-color: var(--brand)}

/* Fix pack styles (from v0.4) */
.fixpack{background:#fff;border:1px solid #eee;border-radius:14px;padding:16px;margin-top:12px}
.fixpack > summary{cursor:pointer;list-style:none;margin-bottom:8px}
.fix-list{display:grid;gap:8px;padding:0;margin:0;list-style:none}
.fix{border:1px solid #eee;border-radius:10px;padding:10px;background:#fafafa}
.fix h4{margin:0 0 6px 0;font-size:14px}
.fix code{display:block;background:#0e1116;color:#d6e2ff;border-radius:8px;padding:8px;font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;font-size:12px;overflow:auto}

/* Contrast suggestions */
.contrastfix{background:#fff;border:1px solid #eee;border-radius:14px;padding:16px;margin-top:12px}
.contrastfix > summary{cursor:pointer;list-style:none;margin-bottom:8px}
.contrast-list{display:grid;gap:8px;padding:0;margin:0;list-style:none}
.pair{border:1px solid #eee;border-radius:10px;padding:10px;background:#fafafa}
.pair h4{margin:0 0 6px 0;font-size:14px}
.pair .swatch{display:inline-block;width:16px;height:16px;border-radius:4px;border:1px solid #ddd;margin-right:6px;vertical-align:middle}
.pair .note{font-size:12px;opacity:.85}