:root{--ink-strong:#15121a;--ink:#2a2138;--ink-soft:#524763;--line:#211a2b24;--panel:#fffcf8e0;--panel-strong:#fffffff0;--accent:#0b6f96;--accent-2:#b03333;--accent-3:#c79a30;--accent-4:#0f6357;--shadow:0 20px 60px #22152824;--mono:"IBM Plex Mono", "SFMono-Regular", Consolas, monospace;--sans:"Space Grotesk", "Segoe UI", system-ui, -apple-system, sans-serif;--surface-bg:linear-gradient(180deg, #fff7eb 0%, #f7efe9 100%);--surface-radial-1:#0b7fab24;--surface-radial-2:#c43b3b1f;--input-bg:#fff9f2eb;--mono-block-bg:#1d1824;--mono-block-fg:#f7f1eb;--metric-bg:linear-gradient(180deg, #12151af0, #211a2bf0);--metric-fg:#f7f1eb;--metric-muted:#f7f1ebc7;--warning-bg:#c43b3b1a;--warning-fg:#5b1414;--warning-border:#c43b3b38;--focus-ring:#ed9b1a;font-family:var(--sans);color:var(--ink);background:radial-gradient(circle at top left, var(--surface-radial-1), transparent 32%), radial-gradient(circle at top right, var(--surface-radial-2), transparent 28%), var(--surface-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}[data-theme=dark]{--ink-strong:#f3f0f7;--ink:#dcd6e6;--ink-soft:#b1a8c2;--line:#c8bedc2e;--panel:#1e1a26e6;--panel-strong:#262130f5;--accent:#6fd0ff;--accent-2:#ff8585;--accent-3:#f6d574;--accent-4:#56e6d2;--shadow:0 20px 60px #0006;--surface-bg:linear-gradient(180deg, #12101a 0%, #1a1624 100%);--surface-radial-1:#4dc3f71a;--surface-radial-2:#f0686814;--input-bg:#16131eeb;--mono-block-bg:#0e0b14;--mono-block-fg:#ece7f4;--metric-bg:linear-gradient(180deg, #08060ef0, #120e1cf0);--metric-fg:#ece7f4;--metric-muted:#dcd6e6d1;--warning-bg:#f0686824;--warning-fg:#fbb7b7;--warning-border:#f0686847;--focus-ring:#f6d574}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);margin:0}a{color:var(--accent)}a:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:4px}.skip-link{z-index:100;background:var(--accent);color:#fff;border-radius:0 0 12px;width:1px;height:1px;padding:12px 18px;font-weight:700;text-decoration:none;position:absolute;top:auto;left:-10000px;overflow:hidden}.skip-link:focus{outline:3px solid var(--focus-ring);outline-offset:0;width:auto;height:auto;position:fixed;top:0;left:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none;transform:none}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}#app{min-height:100vh}.page-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:28px 0 72px}.hero-panel,.lab-section,.panel-card,.scenario-card,.info-panel,.warning-banner{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.hero-panel{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:28px;grid-template-columns:minmax(0,1.8fr) minmax(260px,1fr);gap:22px;padding:30px;display:grid;position:relative}.hero-copy{gap:12px;display:grid}.portfolio-badge{width:fit-content;color:var(--accent);font-family:var(--mono);background:#0b7fab1f;border-radius:999px;padding:10px 14px;font-size:.84rem;text-decoration:none}.portfolio-badge:hover{text-decoration:underline}.eyebrow{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.9rem;font-weight:700}.hero-panel h1{color:var(--ink-strong);margin:0;font-size:clamp(2.4rem,7vw,5rem);line-height:.95}.hero-text{max-width:64ch;color:var(--ink-soft);margin:0;line-height:1.65}.why-details,.explanation-details{border:1px solid var(--line);background:var(--panel);border-radius:20px;padding:16px 18px}.why-details summary,.explanation-details summary{cursor:pointer;color:var(--ink-strong);font-weight:700}.why-details summary:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:6px}.why-details p,.explanation-details p{margin:12px 0 0;line-height:1.6}.hero-metric-card{background:var(--metric-bg);color:var(--metric-fg);border-radius:24px;align-content:start;gap:10px;padding:22px;display:grid}.hero-metric-label{letter-spacing:.08em;text-transform:uppercase;color:var(--metric-muted);margin:0;font-size:.82rem}.hero-metric-value{font-family:var(--mono);gap:6px;margin:0;font-size:1.02rem;line-height:1.5;display:grid}.hero-metric-strong{color:var(--metric-fg);font-weight:700}.hero-metric-or{width:fit-content;color:var(--metric-fg);letter-spacing:.1em;background:#ffffff1a;border-radius:999px;align-self:start;padding:2px 8px;font-size:.78rem;display:inline-block}.hero-metric-note{color:var(--metric-muted);margin:0;line-height:1.6}.lab-section{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:28px;margin-top:26px;padding:28px}.lab-section--footer{box-shadow:none;background:0 0;border-style:dashed}.section-heading-row,.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.section-kicker{color:var(--accent-2);letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:.85rem;font-weight:700}.lab-section h2,.panel-card h3,.scenario-card h3{color:var(--ink-strong);margin:0}.lab-section h2{font-size:clamp(1.6rem,4vw,2.6rem);line-height:1.15}.lab-section h2:focus-visible{outline:2px solid var(--focus-ring);outline-offset:4px;border-radius:6px}.lab-section h2[id]{scroll-margin-top:96px}@media (width<=720px){.lab-section h2[id]{scroll-margin-top:80px}}.panel-card h3,.scenario-card h3{font-size:1.15rem}.panel-copy,.scenario-copy,.section-footnote,.math-decimal,.info-panel p{color:var(--ink-soft);line-height:1.6}.panel-copy,.scenario-copy,.section-footnote,.math-decimal{margin:8px 0 0}.action-button,.ghost-button,.tab-button,.preset-button{border:0;border-radius:999px;transition:transform .18s,box-shadow .18s,background .18s,color .18s}.action-button,.ghost-button{min-height:44px;padding:14px 18px;font-weight:700}.action-button{background:linear-gradient(135deg, var(--accent), color-mix(in oklab, var(--accent) 60%, black));color:#fff9f2;box-shadow:0 12px 24px #0b7fab2e}.action-button--danger{background:linear-gradient(135deg, var(--accent-2), color-mix(in oklab, var(--accent-2) 60%, black));box-shadow:0 12px 24px #c43b3b38}.ghost-button{background:var(--panel-strong);color:var(--ink-strong);border:1px solid var(--line)}.ghost-button--compact{min-height:36px;padding:8px 14px;font-size:.85rem}.ghost-button.is-copied{background:color-mix(in oklab, var(--accent-4) 22%, var(--panel-strong));color:var(--accent-4);border-color:var(--accent-4)}.action-button:hover,.ghost-button:hover,.tab-button:hover,.preset-button:hover{transform:translateY(-1px)}.action-button:focus-visible,.ghost-button:focus-visible,.tab-button:focus-visible,.preset-button:focus-visible,.message-input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}.playground-grid,.reuse-grid,.math-summary-grid{gap:18px;margin-top:24px;display:grid}.playground-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.reuse-grid,.math-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-card,.scenario-card,.info-panel{border:1px solid var(--line);background:var(--panel-strong);border-radius:24px;padding:22px}.panel-card--wide{grid-column:span 2}.message-input,.mono-block,.mono-inline,.mono-cell,.math-empty,.tag-cell{font-family:var(--mono)}.mono-hex,.mono-cell--hex,.tag-cell{text-transform:uppercase}.message-input{border:1px solid var(--line);resize:vertical;background:var(--input-bg);width:100%;min-height:118px;color:var(--ink-strong);border-radius:18px;margin-top:14px;padding:16px 18px}.preview-block,.mono-block,.mono-inline{overflow-wrap:anywhere;word-break:break-all;border-radius:18px;margin-top:14px;padding:14px 16px}.mono-block,.mono-inline{background:var(--mono-block-bg);color:var(--mono-block-fg);letter-spacing:.06em}.mono-inline--meter{margin-top:8px;padding:6px 10px;font-size:.85rem;display:inline-block}.preview-block{background:var(--input-bg);color:var(--ink-strong);border:1px solid var(--line);white-space:pre-wrap}.key-display{min-height:84px}.tag-grid{grid-template-columns:repeat(8,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.tag-grid--compact{margin-top:14px}.tag-cell{background:linear-gradient(180deg, color-mix(in oklab, var(--tag-color) 72%, white), color-mix(in oklab, var(--tag-color) 82%, black 12%));color:#08141d;letter-spacing:.08em;border-radius:16px;place-items:center;min-height:54px;font-weight:700;display:grid}[data-theme=dark] .tag-cell{color:#f0edf5;background:linear-gradient(180deg, color-mix(in oklab, var(--tag-color) 50%, black 20%), color-mix(in oklab, var(--tag-color) 40%, black 40%))}.tag-cell--tampered{border:3px solid var(--accent-2)}.scenario-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:20px;display:grid}.scenario-status{margin:14px 0 0;font-weight:700}.scenario-status--pending{color:var(--accent)}.scenario-status--valid{color:var(--accent-4)}.scenario-status--invalid{color:var(--accent-2)}.table-shell{border:1px solid var(--line);border-radius:24px;margin-top:18px;overflow-x:auto}.math-table{border-collapse:collapse;background:var(--panel-strong);width:100%;min-width:920px}.math-table th,.math-table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:14px 16px}.math-table th{color:var(--ink-strong);background:#0b7fab14}.math-empty{color:var(--ink-soft)}.math-row{opacity:0;animation:.42s forwards row-enter;transform:translateY(12px)}@keyframes row-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.warning-banner{border:1px solid var(--warning-border);background:var(--warning-bg);color:var(--warning-fg);border-radius:20px;align-items:center;gap:10px;margin-top:22px;padding:16px 18px;display:flex}.warning-banner[hidden]{display:none}.info-tabs{flex-wrap:wrap;gap:12px;margin-top:22px;display:flex}.tab-button{background:var(--panel-strong);color:var(--ink-soft);border:1px solid var(--line);padding:12px 18px;font-weight:700}.tab-button.is-active{background:var(--mono-block-bg);color:var(--mono-block-fg)}.info-panels{margin-top:18px}.info-panel{line-height:1.7}.info-panel p{margin:0}.info-panel p+p{margin-top:14px}.theme-toggle{border:1px solid var(--line);background:var(--panel-strong);width:44px;height:44px;color:var(--ink-strong);cursor:pointer;border-radius:50%;place-items:center;font-size:1.2rem;transition:transform .18s,box-shadow .18s;display:grid;position:absolute;top:14px;right:14px}.theme-toggle:hover{transform:translateY(-1px)}.theme-toggle:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}.theme-toggle__icon{line-height:1}.footer-meta{margin:14px 0 0}.footer-meta a{color:var(--accent);font-weight:700;text-decoration:none}.footer-meta a:hover{text-decoration:underline}@media (width<=1024px){.hero-panel,.playground-grid,.scenario-grid,.reuse-grid,.math-summary-grid{grid-template-columns:1fr}.panel-card--wide{grid-column:auto}}@media (width<=720px){.page-shell{width:min(1180px,100% - 20px);padding:20px 0 48px}.hero-panel,.lab-section,.panel-card,.scenario-card,.info-panel{padding:22px}.section-heading-row,.panel-header,.warning-banner{flex-direction:column;align-items:stretch}.tag-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.theme-toggle{top:12px;right:12px}.hero-panel{padding-top:64px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}@media (forced-colors:active){.theme-toggle,.ghost-button,.panel-card,.lab-section,.hero-panel{border:1px solid canvastext}.entropy-fill,.entropy-fill--ok,.entropy-fill--bad{background:highlight!important}}.vs-chip{font-family:var(--mono);letter-spacing:.04em;border:1px solid var(--line);background:var(--panel-strong);color:var(--ink-soft);border-radius:999px;padding:4px 12px;font-size:.74rem;font-weight:700;display:inline-block}.vs-chip--ok{background:color-mix(in oklab, var(--accent-4) 18%, transparent);color:var(--accent-4);border-color:var(--accent-4)}.vs-chip--bad{background:var(--warning-bg);color:var(--accent-2);border-color:var(--warning-border)}.section-nav{z-index:20;border:1px solid var(--line);background:color-mix(in oklab, var(--panel-strong) 90%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);-webkit-overflow-scrolling:touch;border-radius:999px;margin:18px 0 0;padding:8px 10px;position:sticky;top:8px;overflow-x:auto}.section-nav__list{white-space:nowrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.section-nav__link{color:var(--ink-soft);border-radius:999px;padding:8px 14px;font-size:.86rem;font-weight:600;text-decoration:none;transition:background .18s,color .18s;display:inline-block}.section-nav__link:hover{background:color-mix(in oklab, var(--accent) 14%, transparent);color:var(--ink-strong)}.section-nav__link.is-active{background:var(--mono-block-bg);color:var(--mono-block-fg)}.hero-cta-row{flex-wrap:wrap;gap:10px;margin-top:6px;display:flex}.hero-cta-row .action-button,.hero-cta-row .ghost-button{place-items:center;text-decoration:none;display:inline-grid}.hero-stat-grid{border-top:1px solid #ffffff1f;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:6px 0 0;padding-top:12px;display:grid}.hero-stat-grid>div{gap:2px;display:grid}.hero-stat-grid dt{letter-spacing:.08em;text-transform:uppercase;color:var(--metric-muted);font-size:.68rem}.hero-stat-grid dd{font-family:var(--mono);color:var(--metric-fg);margin:0;font-size:.86rem}.kbd-hint{border:1px solid var(--line);background:var(--panel-strong);color:var(--ink-soft);font-family:var(--mono);letter-spacing:.04em;white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:.72rem;display:inline-flex}.kbd-hint span{background:var(--mono-block-bg);color:var(--mono-block-fg);border-radius:5px;padding:2px 6px;font-weight:700}.combiner-diagram{border:1px solid var(--line);background:var(--panel-strong);border-radius:20px;margin:22px 0 0;padding:14px 18px}.combiner-diagram svg{width:100%;max-width:560px;height:auto;margin:0 auto;display:block}.combiner-diagram svg path{stroke-dasharray:6 4;transition:stroke .26s;animation:1.8s linear infinite combiner-flow}.combiner-diagram svg path.is-broken{stroke-dasharray:4 4;animation:none;stroke:var(--accent-2)!important}.combiner-diagram svg rect{transition:stroke .26s}.combiner-diagram svg rect#diag-classical-rect.is-broken,.combiner-diagram svg rect#diag-pq-rect.is-broken{stroke:var(--accent-2)}@keyframes combiner-flow{to{stroke-dashoffset:-20px}}@media (prefers-reduced-motion:reduce){.combiner-diagram svg path{stroke-dasharray:0;animation:none}}.combiner-flow{grid-template-columns:1fr 1fr;gap:18px;margin-top:18px;display:grid}.comp-card{border:1px solid var(--line);background:var(--panel-strong);border-radius:20px;padding:20px;transition:opacity .22s,border-color .22s}.comp-card--classical{border-left:4px solid var(--accent)}.comp-card--pq{border-left:4px solid var(--accent-3)}.comp-card.is-broken{opacity:.6;border-color:var(--accent-2)}.comp-card.is-broken .comp-secret{color:var(--accent-2);text-decoration:line-through}.comp-label{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 10px;font-size:.82rem;font-weight:700}.comp-secret{word-break:break-all;margin:0 0 14px}.break-toggle{color:var(--ink-soft);cursor:pointer;align-items:center;gap:10px;min-height:44px;padding:8px 4px;font-size:.94rem;display:inline-flex}.break-toggle input{width:20px;height:20px;accent-color:var(--accent-2);cursor:pointer;flex-shrink:0}.break-toggle:focus-within{outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:8px}.scenario-presets{border:1px solid var(--line);background:var(--panel);border-radius:18px;margin-top:18px;padding:14px 16px}.scenario-presets__legend{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding:0 8px;font-size:.8rem;font-weight:700}.scenario-presets__row{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.preset-button{border:1px solid var(--line);background:var(--panel-strong);min-height:40px;color:var(--ink-strong);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;font-size:.9rem;font-weight:600;display:inline-flex}.preset-button__key{background:var(--mono-block-bg);width:22px;height:22px;color:var(--mono-block-fg);font-family:var(--mono);border-radius:6px;place-items:center;font-size:.74rem;font-weight:700;display:inline-grid}.preset-button:hover{background:color-mix(in oklab, var(--accent) 8%, var(--panel-strong))}.preset-button--danger{border-color:var(--warning-border);color:var(--accent-2);background:var(--warning-bg)}.preset-button--danger:hover{background:color-mix(in oklab, var(--accent-2) 14%, var(--warning-bg))}.combiner-bar{border:1px solid var(--line);background:var(--panel);border-radius:16px;flex-wrap:wrap;align-items:center;gap:16px;margin-top:18px;padding:14px 18px;display:flex}.combiner-bar label{color:var(--ink-soft);align-items:center;gap:10px;font-size:.95rem;display:inline-flex}.combiner-bar select{border:1px solid var(--line);background:var(--input-bg);min-height:40px;color:var(--ink-strong);font-family:var(--mono);cursor:pointer;border-radius:12px;padding:10px 12px}.combiner-bar select:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}.combiner-bar .ghost-button{margin-left:auto}.formula-card{border:1px solid var(--line);background:var(--mono-block-bg);color:var(--mono-block-fg);border-radius:18px;margin-top:18px;padding:16px 18px}.formula-label{letter-spacing:.1em;text-transform:uppercase;color:var(--metric-muted);margin:0;font-size:.74rem}.formula-body{font-family:var(--mono);white-space:pre-wrap;word-break:break-word;color:var(--mono-block-fg);margin:8px 0 0;padding:0;font-size:clamp(.86rem,2.6vw,1.05rem);line-height:1.5}.formula-note{color:var(--metric-muted)}.session-out{margin-top:18px}.session-key-row{flex-wrap:wrap;align-items:stretch;gap:12px;display:flex}.session-key-row .mono-block{flex:320px;min-width:0;margin-top:14px}.session-key-row .ghost-button{align-self:center;margin-top:14px}.bitgrid-wrap{border:1px solid var(--line);background:var(--panel);border-radius:18px;margin-top:22px;padding:16px 18px}.bitgrid-count{font-family:var(--mono);color:var(--ink-soft);letter-spacing:.04em;text-transform:none;font-size:.78rem}.bitgrid-pair{grid-template-columns:1fr 1fr;gap:18px;margin:12px 0;display:grid}.bitgrid-col{gap:8px;display:grid}.bitgrid-label{font-family:var(--mono);color:var(--ink-soft);align-items:center;gap:8px;margin:0;font-size:.78rem;display:inline-flex}.bitgrid-dot{border-radius:3px;width:10px;height:10px;display:inline-block}.bitgrid-dot--classical{background:var(--accent)}.bitgrid-dot--pq{background:var(--accent-3)}.bitgrid{background:var(--mono-block-bg);border:1px solid var(--line);border-radius:12px;grid-template-columns:repeat(16,1fr);gap:3px;padding:10px;display:grid}.bitgrid-cell{aspect-ratio:1;background:var(--accent);opacity:.85;border-radius:2px;transition:background .28s,opacity .28s,transform .24s;display:block}.bitgrid-cell--pq{background:var(--accent-3)}.bitgrid.is-broken .bitgrid-cell{background:var(--mono-block-fg);opacity:.16;transform:scale(.85)}@media (prefers-reduced-motion:no-preference){.bitgrid-cell{animation:4.6s ease-in-out infinite bit-pulse}.bitgrid-cell:nth-child(7n){animation-delay:.4s}.bitgrid-cell:nth-child(11n){animation-delay:.9s}.bitgrid-cell:nth-child(13n){animation-delay:1.4s}.bitgrid.is-broken .bitgrid-cell{animation:none}@keyframes bit-pulse{0%,to{opacity:.85}50%{opacity:.55}}}.entropy{margin-top:18px}.entropy-track{background:var(--input-bg);border:1px solid var(--line);border-radius:999px;height:14px;margin:14px 0 6px;overflow:hidden}.entropy-fill{border-radius:999px;height:100%;transition:width .5s cubic-bezier(.22,1,.36,1)}.entropy-fill--ok{background:linear-gradient(90deg, var(--accent-4), var(--accent))}.entropy-fill--bad{background:linear-gradient(90deg, var(--accent-2), color-mix(in oklab, var(--accent-2) 55%, black))}.timeline-card{border:1px solid var(--line);background:var(--panel-strong);border-radius:22px;margin-top:22px;padding:22px}.timeline-track{height:56px;margin:12px 8px 8px;position:relative}.timeline-track__line{background:linear-gradient(90deg, var(--accent-4), var(--accent), var(--accent-3), var(--accent-2));opacity:.5;border-radius:999px;height:4px;position:absolute;top:24px;left:0;right:0}.timeline-track__pip{border:1px solid var(--line);background:var(--panel);min-width:56px;color:var(--ink-soft);font-family:var(--mono);cursor:pointer;border-radius:999px;padding:4px 8px;font-size:.72rem;transition:background .18s,color .18s,border-color .18s;position:absolute;top:4px;transform:translate(-50%)}.timeline-track__pip:hover{background:var(--mono-block-bg);color:var(--mono-block-fg);border-color:var(--mono-block-bg)}#timeline-slider{appearance:none;background:var(--input-bg);border:1px solid var(--line);cursor:pointer;border-radius:999px;outline:none;width:100%;height:8px;margin:12px 0 0}#timeline-slider:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}#timeline-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);border:3px solid var(--panel-strong);cursor:grab;border-radius:50%;width:22px;height:22px;box-shadow:0 4px 12px #0003}#timeline-slider::-moz-range-thumb{background:var(--accent);border:3px solid var(--panel-strong);cursor:grab;border-radius:50%;width:22px;height:22px;box-shadow:0 4px 12px #0003}.timeline-readout{flex-wrap:wrap;align-items:center;gap:14px;margin-top:14px;display:flex}.timeline-year{font-family:var(--mono);color:var(--ink-strong);letter-spacing:.02em;font-size:clamp(2rem,5vw,2.6rem);font-weight:700}.timeline-states{flex-wrap:wrap;gap:10px;display:flex}.state-chip{font-family:var(--mono);background:var(--panel);border:1px solid var(--line);color:var(--ink-soft);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:.84rem;display:inline-flex}.state-chip strong{color:var(--ink-strong)}.state-chip[data-state=safe]{background:color-mix(in oklab, var(--accent-4) 18%, transparent);border-color:var(--accent-4);color:var(--accent-4)}.state-chip[data-state=safe] strong{color:var(--accent-4)}.state-chip[data-state=fragile]{background:color-mix(in oklab, var(--accent-3) 22%, transparent);border-color:var(--accent-3);color:color-mix(in oklab, var(--accent-3) 70%, var(--ink-strong))}.state-chip[data-state=fragile] strong{color:var(--ink-strong)}.state-chip[data-state=broken]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--accent-2)}.state-chip[data-state=broken] strong{color:var(--accent-2)}.timeline-body{margin-top:14px}.timeline-body h3{color:var(--ink-strong);margin:0 0 6px}.timeline-implication{border:1px solid var(--line);border-radius:14px;margin-top:12px;padding:10px 14px;line-height:1.5}.timeline-implication[data-tone=ok]{background:color-mix(in oklab, var(--accent-4) 14%, transparent);border-color:var(--accent-4);color:var(--accent-4)}.timeline-implication[data-tone=warn]{background:color-mix(in oklab, var(--accent-3) 18%, transparent);border-color:var(--accent-3);color:color-mix(in oklab, var(--accent-3) 70%, var(--ink-strong))}.timeline-implication[data-tone=bad]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-fg)}.harvest-block{border-top:1px dashed var(--line);margin-top:18px;padding-top:16px}.harvest-block__label{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 12px;font-size:.78rem;font-weight:700}.harvest-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.harvest-card{border:1px solid var(--line);background:var(--panel);border-radius:18px;padding:16px 18px;transition:background .4s,border-color .4s;position:relative;overflow:hidden}.harvest-card--classical{border-left:4px solid var(--accent)}.harvest-card--hybrid{border-left:4px solid var(--accent-4);background:color-mix(in oklab, var(--accent-4) 10%, var(--panel))}.harvest-card__head{align-items:center;gap:12px;display:flex}.harvest-card__lock{background:var(--mono-block-bg);width:40px;height:40px;color:var(--mono-block-fg);border-radius:50%;place-items:center;font-size:1.2rem;transition:background .4s,transform .4s;display:inline-grid}.harvest-card__year{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-size:.7rem;font-family:var(--mono);margin:0}.harvest-card__title{color:var(--ink-strong);margin:2px 0 0;font-weight:700}.harvest-card__hash{margin:10px 0 0;padding:8px 10px;font-size:.78rem;display:block}.harvest-card__status{color:var(--ink-soft);font-size:.86rem;font-family:var(--mono);margin:8px 0 0}.harvest-card--hybrid .harvest-card__status{color:var(--accent-4)}.harvest-card__crack{pointer-events:none;opacity:0;background-image:linear-gradient(115deg, transparent 48%, color-mix(in oklab, var(--accent-2) 60%, transparent) 49%, color-mix(in oklab, var(--accent-2) 60%, transparent) 50%, transparent 51%), linear-gradient(65deg, transparent 38%, color-mix(in oklab, var(--accent-2) 60%, transparent) 39%, color-mix(in oklab, var(--accent-2) 60%, transparent) 40%, transparent 41%);transition:opacity .4s;position:absolute;inset:0}.harvest-card.is-cracked{background:var(--warning-bg);border-color:var(--warning-border)}.harvest-card.is-cracked .harvest-card__lock{background:var(--accent-2);color:#fff;transform:rotate(-12deg)}.harvest-card.is-cracked .harvest-card__hash{color:var(--accent-2);text-decoration:line-through}.harvest-card.is-cracked .harvest-card__status{color:var(--accent-2);font-weight:700}.harvest-card.is-cracked .harvest-card__crack{opacity:.9}@media (width<=720px){.harvest-grid{grid-template-columns:1fr}}.code-panel{border:1px solid var(--line);background:var(--panel);border-radius:18px;margin-top:14px;overflow:hidden}.code-panel>summary{cursor:pointer;color:var(--ink-strong);-webkit-user-select:none;user-select:none;padding:12px 18px;font-weight:700;list-style:none}.code-panel>summary::-webkit-details-marker{display:none}.code-panel>summary:before{content:"▸ ";color:var(--accent);transition:transform .18s;display:inline-block}.code-panel[open]>summary:before{content:"▾ "}.code-panel>summary:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-2px}.code-block{background:var(--mono-block-bg);color:var(--mono-block-fg);font-family:var(--mono);white-space:pre;border-top:1px solid var(--line);margin:0;padding:14px 18px;font-size:.82rem;line-height:1.55;overflow-x:auto}.code-panel__actions{border-top:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:12px;padding:12px 18px;display:flex}.code-panel__hint{color:var(--ink-soft);font-size:.8rem}.attack-row{gap:14px;margin-top:18px;display:grid}.attack-row .action-button--danger{text-align:left;justify-self:start}.attack-result{border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:.94rem;line-height:1.55}.attack-result code{background:var(--mono-block-bg);color:var(--mono-block-fg);font-family:var(--mono);border-radius:4px;padding:1px 6px;font-size:.86em}.attack-result[data-tone=bad]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-fg)}.attack-result[data-tone=ok]{background:color-mix(in oklab, var(--accent-4) 14%, transparent);border-color:var(--accent-4);color:var(--accent-4)}.attack-result strong{color:inherit}#session-key.is-attacked{border:1px solid var(--accent-2);animation:.48s key-shake}#session-key.is-shielded{border:1px solid var(--accent-4);animation:.6s key-shield}@keyframes key-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}@keyframes key-shield{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 0 6px color-mix(in oklab, var(--accent-4) 40%, transparent)}}@media (prefers-reduced-motion:reduce){#session-key.is-attacked,#session-key.is-shielded{animation:none}}@media (width<=720px){.attack-row .action-button--danger{justify-self:stretch}}.handshake-list{gap:16px;margin:18px 0 0;padding:0;list-style:none;display:grid}.handshake-row{border:1px solid var(--line);background:var(--panel-strong);border-radius:18px;padding:14px 16px}.handshake-row__head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:10px;display:flex}.handshake-row__name{color:var(--ink-strong);font-weight:700}.handshake-row__bytes{margin:0;display:inline-block}.handshake-bar{background:var(--input-bg);border:1px solid var(--line);border-radius:999px;height:14px;margin:10px 0 8px;overflow:hidden}.handshake-bar span{border-radius:999px;height:100%;transition:width .7s cubic-bezier(.22,1,.36,1);display:block}.handshake-bar--classical span{background:linear-gradient(90deg, var(--accent), color-mix(in oklab, var(--accent) 60%, white))}.handshake-bar--pq span{background:linear-gradient(90deg, var(--accent-3), color-mix(in oklab, var(--accent-3) 60%, black))}.handshake-bar--hybrid span{background:linear-gradient(90deg, var(--accent-4), var(--accent))}.handshake-row__note{margin:4px 0 0}.middlebox-figure{margin:22px 0 0;padding:0}.middlebox-figure__caption{color:var(--ink-soft);margin:0 0 12px;font-size:.92rem;line-height:1.55}.middlebox-figure__caption strong{color:var(--ink-strong)}.middlebox-stage{border:1px solid var(--line);background:var(--panel);border-radius:20px;gap:14px;padding:18px 16px;display:grid}.mb-lane{grid-template-columns:130px 1fr 140px;align-items:center;gap:14px;display:grid}.mb-lane__tag{font-family:var(--mono);color:var(--ink-soft);font-size:.78rem}.mb-lane--pq .mb-lane__tag{color:var(--accent-3)}.mb-lane__track{background:var(--input-bg);border:1px solid var(--line);border-radius:14px;height:56px;position:relative;overflow:hidden}.mb-lane__verdict{font-family:var(--mono);font-size:.78rem}.mb-lane__verdict--ok{color:var(--accent-4)}.mb-lane__verdict--bad{color:var(--accent-2)}.mb-icon{background:var(--mono-block-bg);width:44px;height:30px;color:var(--mono-block-fg);font-family:var(--mono);letter-spacing:.04em;border-radius:8px;place-items:center;font-size:.62rem;display:inline-grid;position:absolute;top:50%;transform:translateY(-50%)}.mb-icon--client{left:8px}.mb-icon--firewall{background:var(--accent);width:60px;left:50%;transform:translate(-50%,-50%)}.mb-icon--firewall--strict{background:var(--accent-2)}.mb-icon--server{background:var(--accent-4);right:8px}.mb-packet{font-family:var(--mono);color:#08141d;white-space:nowrap;opacity:0;will-change:left, opacity, background;border-radius:999px;padding:4px 10px;font-size:.7rem;position:absolute;top:50%;transform:translateY(-50%)}.mb-packet--small{background:linear-gradient(135deg, var(--accent), color-mix(in oklab, var(--accent) 60%, white))}.mb-packet--big{background:linear-gradient(135deg, var(--accent-3), color-mix(in oklab, var(--accent-3) 70%, white))}[data-theme=dark] .mb-packet{color:#08141d}@media (prefers-reduced-motion:no-preference){.mb-packet--pass{animation:4.8s ease-in-out infinite mb-glide;animation-delay:var(--mb-delay,0s)}.mb-packet--drop{animation:4.8s ease-in-out infinite mb-bounce;animation-delay:var(--mb-delay,0s)}@keyframes mb-glide{0%{opacity:0;left:8%}8%{opacity:1}50%{opacity:1;left:50%}92%{opacity:1;left:88%}to{opacity:0;left:92%}}@keyframes mb-bounce{0%{opacity:0;left:8%}10%{opacity:1}45%{background:linear-gradient(135deg, var(--accent-3), color-mix(in oklab, var(--accent-3) 70%, white));left:48%}55%{background:linear-gradient(135deg, var(--accent-2), color-mix(in oklab, var(--accent-2) 70%, white));left:48%}85%{opacity:.6;left:12%}to{opacity:0;left:8%}}}@media (prefers-reduced-motion:reduce){.mb-packet--small{opacity:1;left:80%}.mb-packet--frag1{opacity:1;left:78%}.mb-packet--frag2{opacity:1;background:linear-gradient(135deg, var(--accent-2), color-mix(in oklab, var(--accent-2) 70%, white));left:48%}.mb-packet--frag3{opacity:1;left:18%}}@media (width<=720px){.mb-lane{grid-template-columns:1fr;gap:6px}.mb-lane__verdict{justify-self:start}}.bench-state{color:var(--ink-soft);margin:14px 0 0;font-size:.92rem}.bench-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:18px 0 0;padding:0;list-style:none;display:grid}.bench-tile{border:1px solid var(--line);background:var(--panel-strong);border-radius:18px;padding:16px 18px}.bench-tile--headline{background:var(--metric-bg);color:var(--metric-fg);border-color:#0000}.bench-tile__label{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin:0;font-size:.74rem;font-weight:700}.bench-tile--headline .bench-tile__label{color:var(--metric-muted)}.bench-tile__value{margin:8px 0 6px;padding:6px 12px;font-size:clamp(1rem,2.6vw,1.3rem);font-weight:700;display:inline-block}.bench-tile__note{color:var(--ink-soft);font-size:.82rem;font-family:var(--mono);margin:4px 0 0}.bench-tile--headline .bench-tile__note{color:var(--metric-muted)}@media (width<=720px){.bench-grid{grid-template-columns:1fr}}.decision-flow{gap:16px;margin-top:22px;display:grid}.decision-step{border:1px solid var(--line);background:var(--panel-strong);border-radius:20px;grid-template-columns:44px 1fr;align-items:start;gap:18px;padding:18px 20px;display:grid}.decision-step h3{color:var(--ink-strong);margin:0 0 8px;font-size:1.08rem}.decision-num{width:40px;height:40px;font-family:var(--mono);color:var(--metric-fg);background:var(--metric-bg);border-radius:50%;place-items:center;font-weight:700;display:grid}.dec-tag{font-size:.72rem;font-weight:700;font-family:var(--mono);border-radius:6px;margin-right:6px;padding:1px 8px;display:inline-block}.dec-tag--yes{background:color-mix(in oklab, var(--accent-4) 22%, transparent);color:var(--accent-4)}.dec-tag--no{background:var(--panel);color:var(--ink-soft);border:1px solid var(--line)}.decision-verdict{background:var(--metric-bg);color:var(--metric-fg);border-radius:22px;gap:4px;margin-top:18px;padding:18px 22px;display:grid}.decision-verdict__label{letter-spacing:.1em;text-transform:uppercase;color:var(--metric-muted);margin:0;font-size:.78rem}.decision-verdict__value{font-family:var(--mono);margin:0;font-size:clamp(1rem,2.6vw,1.2rem);font-weight:700}.trait-list{gap:12px;margin:14px 0 0;padding-left:0;list-style:none;display:grid}.trait-list li{color:var(--ink-soft);padding-left:26px;line-height:1.55;position:relative}.trait-list li strong{color:var(--ink-strong)}.trait-list li:before{font-weight:700;position:absolute;top:0;left:0}.trait-list--good li:before{content:"✓";color:var(--accent-4)}.trait-list--bad li:before{content:"⚠";color:var(--accent-3)}.scripture{color:var(--ink-soft);margin:18px 0 0;font-style:italic;line-height:1.6}.footer-meta__sep{color:var(--ink-soft);margin:0 8px}.toast-root{z-index:200;pointer-events:none;gap:8px;max-width:100%;padding:0 14px;display:grid;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}.toast{pointer-events:auto;background:var(--mono-block-bg);color:var(--mono-block-fg);border:1px solid var(--line);opacity:0;border-radius:999px;padding:12px 18px;font-size:.9rem;transition:opacity .18s,transform .22s;transform:translateY(8px);box-shadow:0 12px 28px #00000040}.toast.is-shown{opacity:1;transform:translateY(0)}.toast--ok{border-color:var(--accent-4)}.toast--warn{border-color:var(--accent-2)}.reveal{opacity:0;will-change:opacity, transform;transition:opacity .48s,transform .48s cubic-bezier(.22,1,.36,1);transform:translateY(14px)}.reveal.is-visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transition:none;transform:none}}@media (width<=900px){.bitgrid-pair{grid-template-columns:1fr}}@media (width<=720px){.section-nav{border-radius:18px}.section-nav__link{padding:8px 12px;font-size:.82rem}.kbd-hint{display:none}.combiner-flow{grid-template-columns:1fr}.combiner-bar{flex-direction:column;align-items:stretch}.combiner-bar label,.combiner-bar select{width:100%}.combiner-bar .ghost-button{width:100%;margin-left:0}.session-key-row .ghost-button{width:100%}.decision-step{grid-template-columns:34px 1fr;gap:12px;padding:16px}.decision-num{width:30px;height:30px;font-size:.9rem}.scenario-presets__row{gap:8px}.preset-button{flex:calc(50% - 4px);justify-content:flex-start;min-width:0}.timeline-track{height:70px;margin:12px 0 4px}.timeline-track__pip{min-width:48px;padding:3px 6px;font-size:.66rem}.timeline-readout{gap:10px}.timeline-year{font-size:2rem}.hero-stat-grid{grid-template-columns:repeat(3,1fr);gap:6px}.hero-stat-grid dt{font-size:.62rem}.hero-stat-grid dd{font-size:.78rem}}
