:root,[data-theme=dark]{--bg-primary:#0f1117;--bg-secondary:#1a1d2e;--bg-card:#1e2235;--bg-input:#252a3a;--text-primary:#e2e8f0;--text-secondary:#a0aec0;--text-muted:#718096;--accent:#63b3ed;--accent-hover:#90cdf4;--accent-dim:#63b3ed26;--border:#2d3748;--border-hover:#4a5568;--button-text:#fff;--success:#68d391;--warning:#f6ad55;--warning-bg:#f6ad5514;--danger:#fc8181;--danger-bg:#fc81811a;--callout-bg:#63b3ed14;--callout-border:var(--accent);--shadow:0 4px 24px #0000004d;--code-bg:#1a202c;--table-stripe:#ffffff08;--scrollbar-thumb:#4a5568}[data-theme=light]{--bg-primary:#f7fafc;--bg-secondary:#edf2f7;--bg-card:#fff;--bg-input:#f0f4f8;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#718096;--accent:#3182ce;--accent-hover:#2b6cb0;--accent-dim:#3182ce1a;--border:#e2e8f0;--border-hover:#cbd5e0;--button-text:#fff;--success:#38a169;--warning:#dd6b20;--warning-bg:#dd6b2014;--danger:#e53e3e;--danger-bg:#e53e3e14;--callout-bg:#3182ce0f;--callout-border:var(--accent);--shadow:0 4px 24px #00000014;--code-bg:#edf2f7;--table-stripe:#00000005;--scrollbar-thumb:#cbd5e0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}.skip-link{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);z-index:1000;border-radius:6px;padding:.5rem .75rem;position:absolute;top:.5rem;left:-9999px}.skip-link:focus{left:.75rem}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.7;transition:background .3s,color .3s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}header{text-align:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:2.5rem 1rem 2rem;position:relative}header h1{color:var(--text-primary);margin-bottom:.4rem;font-size:2rem;font-weight:700}header .subtitle{color:var(--text-secondary);max-width:700px;margin:0 auto;font-size:1.05rem}#theme-toggle{border:1px solid var(--border);background:var(--bg-card);width:2.6rem;height:2.6rem;color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;transition:border-color .2s,background .2s;display:flex;position:absolute;top:1rem;right:1rem}#theme-toggle:hover{border-color:var(--border-hover);background:var(--bg-input)}main{max-width:960px;margin:0 auto;padding:2rem 1rem 3rem}.exhibit-nav{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem;padding:1rem;display:flex}.exhibit-nav a{color:var(--accent);border-radius:6px;padding:.4rem .9rem;font-size:.9rem;text-decoration:none;transition:background .2s}.exhibit-nav a:hover{background:var(--accent-dim)}.exhibit{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;margin-bottom:3rem;padding:2rem}.exhibit h2{color:var(--accent);align-items:center;gap:.6rem;margin-bottom:.3rem;font-size:1.5rem;display:flex}.exhibit h2 .flag{font-size:1.6rem}.exhibit .origin{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.92rem;line-height:1.6}.exhibit h3{color:var(--text-primary);border-bottom:1px solid var(--border);margin:1.5rem 0 .7rem;padding-bottom:.3rem;font-size:1.1rem}.note-secondary{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.note-muted{color:var(--text-muted);margin-top:.5rem;font-size:.82rem}.byte-input{width:60px;min-width:60px}.fixed-note{color:var(--text-muted);font-size:.88rem}.rounds-wrap{margin-top:.6rem}.rounds-label{color:var(--text-muted);font-size:.82rem}.context-list{color:var(--text-secondary);margin:.5rem 0 .5rem 1.5rem}.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}.playground{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;margin:1rem 0;padding:1.2rem}.control-row{flex-wrap:wrap;align-items:center;gap:.8rem;margin-bottom:.8rem;display:flex}.control-row:last-child{margin-bottom:0}label{color:var(--text-secondary);min-width:60px;font-size:.85rem;font-weight:600}select,input[type=text],textarea{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}select:focus,input:focus,textarea:focus{border-color:var(--accent);outline:none}textarea{resize:vertical;width:100%;min-height:60px;font-family:Consolas,Monaco,monospace}input[type=text]{flex:1;min-width:200px}button{background:var(--accent);color:var(--button-text);cursor:pointer;border:none;border-radius:6px;padding:.5rem 1.1rem;font-size:.88rem;font-weight:600;transition:background .2s}button:hover{background:var(--accent-hover)}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.copy-btn{background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border);padding:.35rem .7rem;font-size:.8rem}button.copy-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.output-area{background:var(--code-bg);border:1px solid var(--border);color:var(--text-primary);word-break:break-all;border-radius:6px;min-height:2.5rem;margin-top:.5rem;padding:.75rem 1rem;font-family:Consolas,Monaco,monospace;font-size:.85rem;position:relative}.output-area .label{color:var(--text-muted);margin-bottom:.3rem;font-family:Segoe UI,system-ui,sans-serif;font-size:.75rem;display:block}.output-area .hex{color:var(--success)}.output-area .plaintext-result{color:var(--accent)}.callout{background:var(--callout-bg);border-left:3px solid var(--callout-border);border-radius:0 6px 6px 0;margin:1rem 0;padding:1rem 1.2rem;font-size:.92rem;line-height:1.65}.callout.warning{background:var(--warning-bg);border-left-color:var(--warning)}.callout.danger{background:var(--danger-bg);border-left-color:var(--danger)}.callout strong{color:var(--text-primary);margin-bottom:.3rem;display:block}.callout p{color:var(--text-secondary);margin:.4rem 0}.sbox-demo{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;align-items:center;gap:.6rem;margin:.8rem 0;padding:.8rem;font-family:Consolas,Monaco,monospace;font-size:.9rem;display:flex}.sbox-demo .step{background:var(--bg-input);border:1px solid var(--border);border-radius:4px;padding:.4rem .7rem}.sbox-demo .arrow{color:var(--accent);font-weight:700}.sbox-demo .highlight{color:var(--success);font-weight:700}.comparison-table-wrapper{border:1px solid var(--border);border-radius:8px;margin:1rem 0;overflow-x:auto}.comparison-table{border-collapse:collapse;width:100%;min-width:700px;font-size:.85rem}.comparison-table th{background:var(--bg-secondary);color:var(--text-primary);text-align:left;border-bottom:2px solid var(--border);white-space:nowrap;padding:.7rem .9rem;font-weight:700}.comparison-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:.55rem .9rem}.comparison-table tr:nth-child(2n){background:var(--table-stripe)}.comparison-table .check{color:var(--success)}.comparison-table .cross{color:var(--danger)}.comparison-table .partial{color:var(--warning)}.decision-tree{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;margin:1rem 0;padding:1.2rem}.decision-tree .decision{align-items:baseline;gap:.6rem;margin-bottom:.7rem;font-size:.92rem;display:flex}.decision-tree .decision:last-child{margin-bottom:0}.decision-tree .need{color:var(--text-secondary);flex:1}.decision-tree .arrow-right{color:var(--accent);font-weight:700}.decision-tree .pick{color:var(--text-primary);min-width:120px;font-weight:700}.decision-tree .pick-success{color:var(--success)}.decision-tree .pick-warning{color:var(--warning)}.decision-tree .pick-danger{color:var(--danger)}.decision-tree .pick-accent{color:var(--accent)}.decision-tree .pick-subnote{font-size:.82rem;font-weight:400}.cross-link{color:var(--accent)}.side-by-side{grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0;display:grid}@media (width<=640px){.side-by-side{grid-template-columns:1fr}}.side-by-side .cipher-col{background:var(--code-bg);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem}.side-by-side .cipher-col h4{color:var(--accent);margin-bottom:.4rem;font-size:.85rem}.round-counter{flex-wrap:wrap;gap:3px;margin:.5rem 0;display:flex}.round-counter .round-dot{background:var(--accent-dim);border:1px solid var(--border);border-radius:3px;width:14px;height:14px;transition:background .15s}.round-counter .round-dot.active{background:var(--accent)}footer{text-align:center;opacity:.7;margin-top:2rem;padding:1.5rem;font-size:.85rem}@media (width<=768px){header h1{font-size:1.5rem}header .subtitle{font-size:.95rem}.exhibit{padding:1.2rem}.control-row{flex-direction:column;align-items:stretch}label{min-width:unset}input[type=text]{min-width:100%}.decision-tree .decision{flex-direction:column;align-items:flex-start;gap:.3rem}.decision-tree .pick{min-width:0}}.error-msg{color:var(--danger);margin-top:.3rem;font-size:.85rem}
