:root,[data-theme=dark]{--bg: #0d1024;--bg-soft: #161a36;--panel: #1b1f3a;--panel-strong: #232850;--line: rgba(255, 255, 255, .08);--line-strong: rgba(255, 255, 255, .16);--ink-strong: #f5f5ff;--ink: #d8dbf0;--ink-soft: #9ea3c6;--ink-faint: #6f7499;--accent: #b58cff;--accent-2: #7ad1ff;--accent-3: #ffd479;--accent-4: #6ff0b6;--warning-bg: rgba(255, 174, 95, .12);--warning-ink: #ffb56b;--metric-bg: rgba(122, 209, 255, .1);--pass-bg: rgba(111, 240, 182, .13);--pass-ink: #6ff0b6;--fail-bg: rgba(255, 110, 134, .15);--fail-ink: #ff8d9f;--pending-bg: rgba(255, 212, 121, .13);--pending-ink: #ffd479;--mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Consolas, monospace;--sans: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--shadow-1: 0 12px 30px rgba(0, 0, 0, .45);--shadow-2: 0 4px 14px rgba(0, 0, 0, .3);--radius-sm: 6px;--radius: 12px;--radius-lg: 18px}[data-theme=light]{--bg: #f6f6fb;--bg-soft: #ecedf6;--panel: #ffffff;--panel-strong: #f1f1fa;--line: rgba(20, 23, 60, .08);--line-strong: rgba(20, 23, 60, .16);--ink-strong: #14143c;--ink: #2a2c5b;--ink-soft: #4a4f78;--ink-faint: #7c80a6;--accent: #5b39c0;--accent-2: #0a5c87;--accent-3: #8a4f08;--accent-4: #146b40;--warning-bg: rgba(138, 79, 8, .14);--warning-ink: #6e3e06;--metric-bg: rgba(10, 92, 135, .12);--pass-bg: rgba(20, 107, 64, .15);--pass-ink: #0b5b34;--fail-bg: rgba(140, 26, 53, .13);--fail-ink: #8c1a35;--pending-bg: rgba(138, 79, 8, .15);--pending-ink: #6e3e06;--shadow-1: 0 10px 24px rgba(20, 23, 60, .12);--shadow-2: 0 4px 12px rgba(20, 23, 60, .08)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#app{max-width:1080px;margin:0 auto;padding:32px 24px 64px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100px;left:12px;z-index:100;padding:10px 16px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;transition:top .15s ease}.skip-link:focus{top:12px;outline:2px solid var(--accent-2);outline-offset:2px}.hero-panel{position:relative;padding:32px 32px 28px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--panel) 0%,var(--panel-strong) 100%);border:1px solid var(--line);box-shadow:var(--shadow-1);margin-bottom:32px}.hero-panel .hero-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);margin:0 0 10px}.hero-panel h1{font-size:clamp(28px,4vw,40px);margin:0 0 14px;color:var(--ink-strong);letter-spacing:-.01em}.hero-panel p.hero-lede{font-size:17px;color:var(--ink);max-width:70ch;margin:0 0 18px}.hero-panel details{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}.hero-panel summary{cursor:pointer;color:var(--accent);font-weight:600;font-size:14px}.hero-panel details[open] summary{margin-bottom:8px}.hero-metric{display:inline-flex;margin-top:10px;padding:8px 14px;background:var(--metric-bg);border:1px solid var(--line);color:var(--accent-2);font-family:var(--mono);font-size:12.5px;border-radius:999px}.theme-toggle{position:absolute;top:20px;right:20px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line-strong);background:var(--panel-strong);color:var(--ink-strong);display:inline-flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:transform .15s ease,background .2s ease}.theme-toggle:hover{transform:rotate(15deg);background:var(--panel)}.theme-toggle:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}@media (prefers-reduced-motion: reduce){.theme-toggle,.theme-toggle:hover{transition:none;transform:none}*{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important}}.lab-section{margin-bottom:32px;padding:24px 24px 22px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-2)}.section-heading-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:8px}.section-heading-row h2{font-size:22px;margin:0;color:var(--ink-strong);letter-spacing:-.01em}.section-kicker{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}.lab-section>p{margin:6px 0 14px;color:var(--ink);max-width:75ch}.panel-card{padding:16px 18px;background:var(--panel-strong);border:1px solid var(--line);border-radius:var(--radius)}button{font-family:var(--sans);font-size:14px;font-weight:700;min-height:44px;padding:10px 18px;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--accent);color:var(--bg);cursor:pointer;transition:filter .15s ease,transform .05s ease}[data-theme=light] button{color:#fff}button:hover{filter:brightness(1.08)}button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}button:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}button.secondary{background:var(--panel-strong);color:var(--ink-strong);border-color:var(--line-strong)}[data-theme=light] button.secondary{color:var(--ink-strong)}.playground-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.reuse-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}.table-wrap:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.math-table{width:100%;min-width:320px;border-collapse:collapse;font-size:14px}.math-table th,.math-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}.math-table th{color:var(--accent);font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em}.scenario-status{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--line)}.scenario-status--valid{background:var(--pass-bg);color:var(--pass-ink)}.scenario-status--invalid{background:var(--fail-bg);color:var(--fail-ink)}.scenario-status--pending{background:var(--pending-bg);color:var(--pending-ink)}code,.mono{font-family:var(--mono);font-size:13px}pre{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;overflow-x:auto;color:var(--ink-strong)}.scripture-footer{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);text-align:center;color:var(--ink-soft);font-style:italic;font-size:14px}.scripture-footer cite{font-style:normal;color:var(--ink)}@media (max-width: 600px){#app{padding:22px 16px 48px}.hero-panel{padding:26px 22px 22px}.theme-toggle{top:14px;right:14px}}.verify-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.verify-summary{font-size:14px;color:var(--ink-strong)}.verify-note{margin-top:10px;padding:10px 12px;background:var(--metric-bg);color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:13px}.check-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:6px}.check-row{display:grid;grid-template-columns:70px 160px 1fr;align-items:center;gap:12px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-soft)}.check-row--pass{border-color:color-mix(in srgb,var(--pass-ink) 30%,var(--line))}.check-row--fail{border-color:color-mix(in srgb,var(--fail-ink) 30%,var(--line))}.check-label{font-family:var(--mono);font-size:13px;color:var(--ink-strong)}.check-detail{font-size:13px;color:var(--ink)}@media (max-width: 640px){.check-row{grid-template-columns:70px 1fr}.check-row .check-detail{grid-column:1 / -1}}.attack-controls .attack-button-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.card-title{margin:0 0 6px;font-size:15px;color:var(--accent);letter-spacing:0}.hero-metric-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.sign-count-chip{display:inline-flex;align-items:center;gap:8px;margin-top:10px;margin-left:8px;padding:6px 12px;background:var(--bg-soft);border:1px solid var(--line);color:var(--ink);font-family:var(--mono);font-size:12.5px;border-radius:999px}.sign-count-chip strong{color:var(--accent-2);font-weight:700}.sign-count-chip.bumped{animation:chip-bump .4s ease}@keyframes chip-bump{0%{transform:scale(1)}40%{transform:scale(1.08);background:var(--metric-bg)}to{transform:scale(1)}}.check-row--fail-spotlight{box-shadow:0 0 0 2px var(--fail-ink),0 0 0 6px var(--fail-bg);position:relative}.check-row--fail-spotlight:before{content:"▶";position:absolute;left:-16px;top:50%;transform:translateY(-50%);color:var(--fail-ink);font-size:12px}@media (max-width: 640px){.check-row--fail-spotlight:before{display:none}}[aria-busy=true]{position:relative}[aria-busy=true]:after{content:"";position:absolute;top:12px;right:12px;width:14px;height:14px;border:2px solid var(--line-strong);border-top-color:var(--accent-2);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.attack-button-row button .emoji{margin-right:6px;font-size:15px}.ceremony-diagram{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:stretch;margin-top:16px}.ceremony-actor{padding:18px 18px 16px;background:var(--panel-strong);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px}.ceremony-actor--auth{border-left:3px solid var(--accent)}.ceremony-actor--server{border-left:3px solid var(--accent-2)}.ceremony-actor-title{display:flex;align-items:center;gap:10px}.ceremony-actor-title h3{margin:0;font-size:16px;color:var(--ink-strong)}.ceremony-actor-icon{font-size:20px;line-height:1}.ceremony-secret{margin:0;font-size:13px;color:var(--ink-soft);font-style:italic}.ceremony-action{margin:6px 0 0;padding:10px 12px;background:var(--bg-soft);border:1px dashed var(--line-strong);border-radius:var(--radius-sm);font-size:12.5px;color:var(--ink);word-break:break-word}.ceremony-checks{margin:4px 0 0;padding-left:18px;font-size:13px;color:var(--ink)}.ceremony-checks li{margin:4px 0}.ceremony-caption{margin:6px 0 0;font-size:12.5px;color:var(--ink-soft)}.ceremony-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0 6px;color:var(--accent-3);min-width:56px}.ceremony-arrow .arrow-shape{font-size:28px;line-height:1}.ceremony-arrow .arrow-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-align:center;max-width:110px}.signed-field{display:inline-block;padding:1px 6px;margin:0 1px;background:var(--bg-soft);border:1px solid var(--line);border-radius:3px;color:var(--ink-strong);font-size:12px}.signed-field.highlight-origin{background:var(--metric-bg);border-color:color-mix(in srgb,var(--accent-2) 40%,var(--line));color:var(--accent-2);font-weight:700}@media (max-width: 760px){.ceremony-diagram{grid-template-columns:1fr}.ceremony-arrow{flex-direction:row;padding:8px 0}.ceremony-arrow .arrow-shape{transform:rotate(90deg)}.ceremony-arrow .arrow-label{max-width:none}}.signed-bytes{margin-top:14px;padding:12px 14px;background:var(--bg-soft);border:1px solid var(--line);border-left:3px solid var(--accent-3);border-radius:var(--radius-sm)}.signed-bytes-title{margin:0 0 8px}.signed-bytes-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-3)}.signed-bytes-dl{margin:0}.signed-bytes dt{margin-top:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}.signed-bytes dd{margin:3px 0 0;font-family:var(--mono);font-size:12.5px;color:var(--ink);word-break:break-all}.signed-bytes-note{margin:10px 0 0;font-size:12.5px;color:var(--ink-soft)}.highlight-origin--match{background:var(--pass-bg);color:var(--pass-ink);padding:1px 4px;border-radius:3px;font-weight:700}.highlight-origin--mismatch{background:var(--fail-bg);color:var(--fail-ink);padding:1px 4px;border-radius:3px;font-weight:700}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.compare-col{padding:14px 14px 12px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:8px}.compare-col--baseline{border-left:3px solid var(--pass-ink)}.compare-col--attack{border-left:3px solid var(--fail-ink)}.compare-col-title{display:flex;align-items:center;gap:8px;margin:0 0 6px;font-size:14px;color:var(--ink-strong)}.compare-col-icon{font-size:12px;padding:2px 8px}.compare-col .check-row{grid-template-columns:60px 130px 1fr;font-size:13px}.compare-col .signed-bytes{border-left-width:2px}@media (max-width: 760px){.compare-grid{grid-template-columns:1fr}}.result-block{display:flex;flex-direction:column;gap:10px}.reuse-grid--two-col{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.gap-card{display:flex;flex-direction:column;gap:8px}.gap-card .card-title{color:var(--accent-3)}.gap-what{margin:0;font-size:13.5px;color:var(--ink)}.gap-why,.gap-real{margin:0;padding:8px 10px;font-size:13px;border-radius:var(--radius-sm);background:var(--bg-soft)}.gap-why{border-left:2px solid var(--accent-2)}.gap-real{border-left:2px solid var(--accent-4)}#live-demo .panel-card{display:flex;flex-direction:column;gap:14px}.live-status{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-family:var(--mono);font-size:12px;border:1px solid var(--line);background:var(--bg-soft)}.live-status--available{color:var(--pass-ink);background:var(--pass-bg)}.live-status--unavailable{color:var(--fail-ink);background:var(--fail-bg)}.live-controls{display:flex;flex-wrap:wrap;gap:8px}.live-out{padding:12px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm)}.live-flags{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 0}.live-flag{font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--line)}.live-flag--on{background:var(--pass-bg);color:var(--pass-ink);border-color:color-mix(in srgb,var(--pass-ink) 30%,var(--line))}.live-flag--off{background:var(--bg-soft);color:var(--ink-soft)}
