:root{--base-font: 16px;--min-font: 14px;--radius: 8px;--radius-sm: 4px;--tap-min: 44px;--content-max: 960px;--transition: .2s ease}[data-theme=dark]{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-card: #1e2130;--bg-code: #272a38;--bg-input: #252838;--text-primary: #e8eaf0;--text-secondary: #a0a4b8;--text-muted: #6b7094;--accent: #60a5fa;--accent-hover: #93c5fd;--accent-subtle: rgba(96, 165, 250, .12);--success: #34d399;--success-bg: rgba(52, 211, 153, .12);--error: #f87171;--error-bg: rgba(248, 113, 113, .12);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .12);--border: #2d3148;--border-focus: #60a5fa;--chip-bg: #2d3148;--chip-text: #93c5fd;--bar-bike: #a78bfa;--bar-mlkem: #60a5fa;--bar-rsa: #6b7094;--bar-mceliece: #f472b6;--shadow: 0 2px 8px rgba(0, 0, 0, .3)}[data-theme=light]{--bg-primary: #f8f9fc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-code: #f0f1f5;--bg-input: #f0f1f5;--text-primary: #1a1d27;--text-secondary: #4b5068;--text-muted: #7a7f96;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: rgba(37, 99, 235, .08);--success: #059669;--success-bg: rgba(5, 150, 105, .08);--error: #dc2626;--error-bg: rgba(220, 38, 38, .08);--warning: #d97706;--warning-bg: rgba(217, 119, 6, .08);--border: #d4d6e0;--border-focus: #2563eb;--chip-bg: #e8eaf0;--chip-text: #2563eb;--bar-bike: #7c3aed;--bar-mlkem: #2563eb;--bar-rsa: #6b7280;--bar-mceliece: #db2777;--shadow: 0 2px 8px rgba(0, 0, 0, .08)}@media (prefers-color-scheme: light){html:not([data-theme=dark]){--bg-primary: #f8f9fc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-code: #f0f1f5;--bg-input: #f0f1f5;--text-primary: #1a1d27;--text-secondary: #4b5068;--text-muted: #7a7f96;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: rgba(37, 99, 235, .08);--success: #059669;--success-bg: rgba(5, 150, 105, .08);--error: #dc2626;--error-bg: rgba(220, 38, 38, .08);--warning: #d97706;--warning-bg: rgba(217, 119, 6, .08);--border: #d4d6e0;--border-focus: #2563eb;--chip-bg: #e8eaf0;--chip-text: #2563eb;--bar-bike: #7c3aed;--bar-mlkem: #2563eb;--bar-rsa: #6b7280;--bar-mceliece: #db2777;--shadow: 0 2px 8px rgba(0, 0, 0, .08)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--base-font);scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.skip-link{position:absolute;top:-100%;left:1rem;background:var(--accent);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-sm);z-index:1000;font-weight:600;text-decoration:none}.skip-link:focus{top:.5rem}:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}h1,h2,h3,h4{line-height:1.3;color:var(--text-primary)}h2{font-size:1.5rem;margin-bottom:1rem}h3{font-size:1.2rem;margin-bottom:.75rem}h4{font-size:1.05rem;margin-bottom:.5rem}p{margin-bottom:.75rem}a{color:var(--accent);text-decoration:underline}a:hover{color:var(--accent-hover)}ul,ol{margin-left:1.5rem;margin-bottom:.75rem}li{margin-bottom:.35rem}code{background:var(--bg-code);padding:.15em .4em;border-radius:var(--radius-sm);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.9em}blockquote{border-left:4px solid var(--accent);padding:.75rem 1rem;margin:1rem 0;background:var(--accent-subtle);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.mono{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.85rem}.output-scroll{overflow-x:auto;word-break:break-all;white-space:pre-wrap;max-width:100%;padding:.5rem;background:var(--bg-code);border-radius:var(--radius-sm);border:1px solid var(--border)}.site-header{padding:1.25rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;max-width:var(--content-max);margin:0 auto}.header-left{flex:1}.category-chip{display:inline-block;background:var(--accent-subtle);color:var(--accent);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .6rem;border-radius:var(--radius-sm);margin-bottom:.5rem}.site-title{font-size:1.75rem;font-weight:800;margin-bottom:.25rem}.site-subtitle{font-size:.9rem;color:var(--text-secondary);margin-bottom:0}.theme-toggle{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;min-width:var(--tap-min);min-height:var(--tap-min);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:1.25rem;transition:background var(--transition)}.theme-toggle:hover{background:var(--accent-subtle)}.primitive-chips{display:flex;flex-wrap:wrap;gap:.5rem;max-width:var(--content-max);margin:.75rem auto 0}.chip{display:inline-block;background:var(--chip-bg);color:var(--chip-text);font-size:.8rem;font-weight:600;padding:.3rem .7rem;border-radius:999px}main{max-width:var(--content-max);margin:0 auto;padding:1rem}.why-banner{background:var(--accent-subtle);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem}.why-banner p{margin:0;font-size:.95rem;line-height:1.6}.panel-nav{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border);padding-bottom:0}.panel-tab{display:flex;align-items:center;gap:.4rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:.85rem;font-weight:600;padding:.6rem .75rem;cursor:pointer;min-height:var(--tap-min);white-space:nowrap;transition:color var(--transition),border-color var(--transition)}.panel-tab:hover{color:var(--text-primary)}.panel-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-number{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;background:var(--chip-bg);border-radius:50%;font-size:.75rem;font-weight:700}.panel-tab.active .tab-number{background:var(--accent);color:#fff}.panel{display:none}.panel.active{display:block;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.panel.active{animation:none}html{scroll-behavior:auto}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.bridge-card{background:var(--accent-subtle);border-color:var(--accent);text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-min);min-width:var(--tap-min);padding:.6rem 1.25rem;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform .1s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--chip-bg);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-large{padding:.75rem 1.75rem;font-size:1rem;margin:.5rem 0}.link-btn{background:none;border:none;color:var(--accent);text-decoration:underline;cursor:pointer;font-size:inherit;padding:0;min-height:var(--tap-min)}.next-panel-btn{margin-top:.75rem}.status-chip-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.status-chip{display:inline-block;font-size:.75rem;font-weight:700;padding:.25rem .65rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.status-round4{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning)}.status-standard{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.status-sim{background:var(--error-bg);color:var(--error);border:1px solid var(--error)}.param-table-wrapper{overflow-x:auto;margin:1rem 0}.param-table{width:100%;border-collapse:collapse;font-size:.9rem}.param-table caption{font-weight:600;margin-bottom:.5rem;text-align:left;color:var(--text-secondary);font-size:.85rem}.param-table th,.param-table td{padding:.6rem .75rem;border:1px solid var(--border);text-align:left}.param-table th{background:var(--bg-secondary);font-weight:600}.param-table .highlight-row{background:var(--accent-subtle)}.comparison-table-wrapper{overflow-x:auto;margin:1rem 0}.comparison-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:600px}.comparison-table caption{font-weight:600;margin-bottom:.5rem;text-align:left;color:var(--text-secondary);font-size:.85rem}.comparison-table th,.comparison-table td{padding:.5rem .6rem;border:1px solid var(--border);text-align:center}.comparison-table thead th{background:var(--bg-secondary);font-weight:700}.comparison-table tbody th{text-align:left;background:var(--bg-secondary)}.comparison-table .vs-cell{font-style:italic;color:var(--text-muted)}.output-area{margin-top:.75rem}.output-section{padding:.5rem 0}.output-section h4{margin-top:.75rem;color:var(--accent)}.placeholder-text{color:var(--text-muted);font-style:italic}.loading-text{color:var(--accent);font-style:italic}.error-text{color:var(--error);font-weight:600}.success-text{color:var(--success);font-weight:600}.meta{font-size:.85rem;color:var(--text-secondary);margin-bottom:.35rem}.timing{font-style:italic}.shared-secret{color:var(--success);font-weight:600}.decrypted-text{font-size:1.1rem;font-weight:600;color:var(--success);padding:.5rem;background:var(--success-bg);border-radius:var(--radius-sm)}.cite{font-size:.8rem;color:var(--text-muted);font-style:italic}.note{font-size:.9rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.75rem;border-radius:var(--radius-sm);border-left:3px solid var(--accent);margin:.75rem 0}.demo-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin:.75rem 0}.output-box{margin-top:.75rem;min-height:2rem}.parity-demo{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem}.mono-input{font-family:SF Mono,Fira Code,Cascadia Code,monospace;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:1.1rem;letter-spacing:.15em;width:6rem;min-height:var(--tap-min)}.help-text{font-size:.8rem;color:var(--text-muted)}.parity-steps{display:flex;flex-direction:column;gap:.5rem}.step{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.step-label{font-size:.9rem;min-width:200px;color:var(--text-secondary)}.step-bits{display:flex;gap:.2rem}.bit{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:700}.bit-error{background:var(--error-bg);border-color:var(--error);color:var(--error)}.key-explainer{display:grid;gap:1rem;margin-top:.75rem}.key-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem}.size-comparison{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.size-bar-group{display:flex;flex-direction:column;gap:.25rem}.size-bar-label{font-size:.85rem;color:var(--text-secondary)}.size-bar{position:relative;height:2rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}.size-bar-fill{display:block;height:100%;width:var(--bar-pct);border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:width .5s ease}.bike-fill{background:var(--bar-bike)}.mlkem-fill{background:var(--bar-mlkem)}.rsa-fill{background:var(--bar-rsa)}.mceliece-fill{background:var(--bar-mceliece)}.size-value{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font-size:.8rem;font-weight:600;color:var(--text-primary)}.visual-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin:1rem 0;text-align:center}.matrix-visual{display:inline-flex;align-items:center;gap:.5rem;font-size:1.1rem;margin:.5rem 0}.matrix-label{font-weight:700;font-style:italic}.matrix-bracket{font-size:2.5rem;font-weight:300;color:var(--text-muted);line-height:1}.matrix-block{display:flex;flex-direction:column;align-items:center;padding:.75rem 1.25rem;background:var(--accent-subtle);border:2px dashed var(--accent);border-radius:var(--radius-sm)}.block-label{font-weight:700;font-size:1.1rem}.block-desc{font-size:.75rem;color:var(--text-muted)}.matrix-divider{font-size:2rem;color:var(--text-muted)}.visual-caption{font-size:.85rem;color:var(--text-secondary);margin-top:.5rem;margin-bottom:0}.kem-flow-list{margin-left:1.5rem}.kem-flow-list li{margin-bottom:.75rem}.encap-section{display:flex;flex-direction:column;gap:.75rem}.prereq-notice{background:var(--warning-bg);border:1px solid var(--warning);border-radius:var(--radius-sm);padding:.75rem}.match-indicator{margin-top:.75rem}.match-success,.match-failure{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:var(--radius);font-size:1rem}.match-success{background:var(--success-bg);border:1px solid var(--success)}.match-failure{background:var(--error-bg);border:1px solid var(--error)}.match-icon{font-size:1.5rem}.aes-demo{display:flex;flex-direction:column;gap:.5rem}.text-input{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .75rem;font-size:1rem;min-height:var(--tap-min);width:100%}.text-input:focus{border-color:var(--border-focus)}.compare-chart{margin:.5rem 0}.chart-header{display:none}.chart-level-label{font-weight:700;font-size:.85rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin-top:1rem;margin-bottom:.35rem;padding-left:.25rem}.chart-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.4rem}.chart-label{min-width:110px;font-size:.85rem;font-weight:600;flex-shrink:0}.chart-bar-container{flex:1;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;height:1.75rem}.chart-bar{height:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;border-radius:var(--radius-sm) 0 0 var(--radius-sm);min-width:60px;transition:width .5s ease}.bar-bike{background:var(--bar-bike)}.bar-mlkem{background:var(--bar-mlkem)}.chart-bar-value{font-size:.75rem;font-weight:700;color:#fff;white-space:nowrap}.chart-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem}.legend-item{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.legend-swatch{display:inline-block;width:1rem;height:1rem;border-radius:var(--radius-sm)}.diversity-grid{display:grid;gap:1rem;margin:1rem 0}.diversity-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.cross-links{display:grid;gap:.75rem;margin-top:1rem}.cross-link-badge{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text-primary);transition:border-color var(--transition),background var(--transition);min-height:var(--tap-min)}.cross-link-badge:hover{border-color:var(--accent);background:var(--accent-subtle)}.badge-icon{font-size:1.5rem;flex-shrink:0}.badge-text{font-size:.9rem;font-weight:600;line-height:1.4}.badge-text small{font-weight:400;color:var(--text-secondary);font-size:.8rem}.site-footer{margin-top:3rem;padding:1.5rem 1rem;background:var(--bg-secondary);border-top:1px solid var(--border)}.footer-content{max-width:var(--content-max);margin:0 auto;text-align:center}.github-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text-primary);font-weight:600;font-size:.9rem;transition:border-color var(--transition);min-height:var(--tap-min)}.github-badge:hover{border-color:var(--accent)}.footer-verse{margin-top:1rem;font-style:italic;color:var(--text-muted);font-size:.85rem}@media (min-width: 600px){.key-explainer,.diversity-grid,.cross-links{grid-template-columns:1fr 1fr}.panel-tab{font-size:.9rem;padding:.6rem 1rem}.step-label{min-width:280px}}@media (min-width: 900px){.site-title{font-size:2rem}h2{font-size:1.75rem}.card{padding:1.5rem}}@media (max-width: 400px){.panel-tab{font-size:.75rem;padding:.5rem .45rem}.tab-number{width:1.2rem;height:1.2rem;font-size:.65rem}.matrix-visual{font-size:.85rem}.matrix-block{padding:.5rem .6rem}.matrix-bracket{font-size:2rem}.chart-label{min-width:80px;font-size:.75rem}.step-label{min-width:auto;font-size:.8rem}.bit{width:1.6rem;height:1.6rem;font-size:.85rem}}.output-scroll,.param-table-wrapper,.comparison-table-wrapper,.chart-bar-container{max-width:100%;overflow-x:auto}
