*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}}:root{--bg:#0e1117;--bg-panel:#161b22;--bg-input:#0d1117;--border:#30363d;--text:#e6edf3;--text-muted:#8b949e;--accent:#58a6ff;--accent-dim:#1f6feb;--success:#3fb950;--warning:#d29922;--error:#f85149;--chip-rec:#238636;--chip-rec-text:#fff;--chip-acc:#9e6a03;--chip-acc-text:#fff;--chip-def:#1f6feb;--chip-def-text:#fff;--chip-info:#30363d;--chip-info-text:#e6edf3;--focus-ring:#58a6ff;--font-mono:"SF Mono", "Cascadia Code", "Fira Code", "Consolas", monospace;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--radius:8px;--shadow:0 1px 3px #00000080}[data-theme=light]{--bg:#fff;--bg-panel:#f6f8fa;--bg-input:#fff;--border:#d0d7de;--text:#1f2328;--text-muted:#656d76;--accent:#0969da;--accent-dim:#0550ae;--success:#1a7f37;--warning:#9a6700;--error:#cf222e;--chip-rec:#2da44e;--chip-rec-text:#fff;--chip-acc:#bf8700;--chip-acc-text:#fff;--chip-def:#0969da;--chip-def-text:#fff;--chip-info:#eaeef2;--chip-info-text:#1f2328;--focus-ring:#0969da;--shadow:0 1px 3px #0000001f}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%;min-height:100vh;line-height:1.6}:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px;border-radius:2px}.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}.site-header{text-align:center;padding:2rem 1rem 1.5rem;position:relative}.category-chip{background:var(--accent-dim);color:#fff;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle;border-radius:999px;padding:.2em .7em;font-size:.75rem;font-weight:700;display:inline-block}.site-title{margin-top:.25rem;font-size:clamp(1.5rem,5vw,2.5rem);font-weight:800}.site-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:1rem}.primitive-chips{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;display:flex}.primitive-chip{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);border-radius:999px;padding:.25em .6em;font-size:.8rem;display:inline-block}.theme-toggle{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:2.6rem;height:2.6rem;font-size:1.25rem;transition:background .15s;display:flex}.theme-toggle:hover{background:var(--border)}.panels{flex-direction:column;gap:2rem;max-width:900px;margin:0 auto;padding:0 1rem 2rem;display:flex}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.panel-heading{margin-bottom:1rem}.panel-title{flex-wrap:wrap;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.rfc-ref{color:var(--text-muted);margin-top:.15rem;font-size:.8rem;font-style:normal;display:block}.status-chip{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:999px;padding:.2em .6em;font-size:.7rem;font-weight:700;display:inline-block}.chip-recommended{background:var(--chip-rec);color:var(--chip-rec-text)}.chip-recommended-default{background:var(--chip-def);color:var(--chip-def-text)}.chip-acceptable{background:var(--chip-acc);color:var(--chip-acc-text)}.chip-info{background:var(--chip-info);color:var(--chip-info-text)}.info-box{background:color-mix(in srgb, var(--accent) 8%, transparent);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;color:var(--text);margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem;line-height:1.5}.panel-form{gap:.75rem;margin-bottom:1rem;display:grid}@media (min-width:600px){.panel-form{grid-template-columns:1fr 1fr}}.input-group{flex-direction:column;gap:.25rem;display:flex}.input-group label{color:var(--text);font-size:.85rem;font-weight:600}.input-field{font-family:var(--font-mono);background:var(--bg-input);min-height:44px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);width:100%;padding:.5rem .75rem;font-size:.9rem}.input-field:focus-visible{outline:3px solid var(--focus-ring);outline-offset:1px}input[type=range]{-webkit-appearance:none;background:var(--border);border-radius:3px;width:100%;height:6px;min-height:44px;padding:19px 0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:24px;height:24px}input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:0;border-radius:50%;width:24px;height:24px}.range-value{font-family:var(--font-mono);color:var(--text-muted);font-size:.85rem}.btn{min-width:44px;min-height:44px;font-size:.9rem;font-weight:600;font-family:var(--font-sans);color:#fff;background:var(--accent-dim);border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;margin-bottom:.5rem;margin-right:.5rem;padding:.6rem 1.25rem;transition:background .15s,box-shadow .15s;display:inline-flex}.btn:hover{background:var(--accent)}.btn:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}.btn:active{transform:translateY(1px)}.output-group{margin-top:.75rem}.output-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem;font-weight:600;display:block}.output-hex{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);word-break:break-all;white-space:pre-wrap;color:var(--text);min-height:2.5rem;max-height:12rem;padding:.75rem;font-size:.85rem;overflow:auto}.timing{font-family:var(--font-mono);color:var(--accent);margin:.5rem 0;font-size:.85rem}.decision-question{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:1rem}.decision-question legend{padding:0 .25rem;font-size:.95rem;font-weight:600}.radio-option{align-items:center;gap:.5rem;min-height:44px;margin-top:.5rem;display:flex}.radio-option input[type=radio]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer}.radio-option label{cursor:pointer;font-size:.9rem}.decision-result{background:color-mix(in srgb, var(--success) 8%, transparent);border:1px solid var(--success);border-radius:var(--radius);margin:1rem 0;padding:1rem;display:none}.decision-result:not(:empty){display:block}.decision-kdf{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.1rem;font-weight:700;display:flex}.decision-reasoning{font-size:.9rem;line-height:1.5}.table-scroll{-webkit-overflow-scrolling:touch;margin-top:1rem;overflow-x:auto}.comparison-table{border-collapse:collapse;width:100%;min-width:600px;font-size:.8rem}.comparison-table th,.comparison-table td{border:1px solid var(--border);text-align:left;vertical-align:top;padding:.5rem .6rem}.comparison-table th{background:var(--bg);white-space:nowrap;font-weight:700}.comparison-table tr:nth-child(2n){background:color-mix(in srgb, var(--bg) 50%, var(--bg-panel))}.td-kdf{font-family:var(--font-mono);white-space:nowrap;font-weight:700}.salt-demos{gap:1.5rem;display:grid}@media (min-width:700px){.salt-demos{grid-template-columns:1fr 1fr}}.salt-demo-group h3{margin-bottom:.5rem;font-size:1rem}.why-section{max-width:900px;margin:0 auto;padding:1rem 1rem 0}.why-section h2{margin-bottom:.5rem;font-size:1.2rem}.why-section p{color:var(--text-muted);margin-bottom:1rem;font-size:.95rem;line-height:1.6}.cross-links{flex-wrap:wrap;align-items:center;gap:.5rem;max-width:900px;margin:0 auto;padding:1rem;display:flex}.cross-label{color:var(--text-muted);font-size:.9rem;font-weight:600}.cross-link{background:var(--bg-panel);border:1px solid var(--border);color:var(--accent);border-radius:999px;min-height:44px;padding:.3em .7em;font-size:.85rem;line-height:44px;text-decoration:none;transition:background .15s;display:inline-block}.cross-link:hover{background:var(--border);text-decoration:underline}.cross-link:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}.site-footer{text-align:center;border-top:1px solid var(--border);max-width:900px;margin:1rem auto 0;padding:2rem 1rem}.github-badge{background:var(--bg-panel);border:1px solid var(--border);color:var(--text);border-radius:999px;align-items:center;gap:.4rem;min-height:44px;padding:.4em 1em;font-size:.9rem;text-decoration:none;transition:background .15s;display:inline-flex}.github-badge:hover{background:var(--border)}.footer-verse{color:var(--text-muted);margin-top:1rem;font-size:.85rem;font-style:italic;line-height:1.5}@media (max-width:320px){body{font-size:16px}.panel{padding:1rem}.comparison-table{font-size:.75rem}}@media (min-width:768px){.panels{padding:0 2rem 2rem}.panel{padding:2rem}}h3{margin-top:1rem;margin-bottom:.5rem;font-size:1rem}
