:root{--color-bg:#0f1117;--color-bg-2:#161b27;--color-bg-3:#1e2535;--color-surface:#1a2030;--color-surface-2:#232c40;--color-border:#2a3550;--color-border-2:#3a4a6b;--color-text:#e6eaf4;--color-text-2:#a0aec0;--color-text-3:#6b7a99;--color-primary:#4a9eff;--color-primary-dim:#1a4a80;--color-accent:#7c5cbf;--color-valid:#22c55e;--color-valid-bg:#052e16;--color-valid-text:#4ade80;--color-invalid:#ef4444;--color-invalid-bg:#2d0a0a;--color-invalid-text:#f87171;--color-warning:#f59e0b;--color-warning-bg:#1c1200;--color-warning-text:#fcd34d;--color-code-bg:#0d1117;--color-version:#4a9eff;--color-cost:#f59e0b;--color-salt:#22c55e;--color-hash:#a855f7;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--font-mono:"Cascadia Code", "Fira Code", "JetBrains Mono", Consolas, "Courier New", monospace;--font-sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--tap-min:44px}[data-theme=light]{--color-bg:#f0f4ff;--color-bg-2:#e8edf8;--color-bg-3:#dde5f5;--color-surface:#fff;--color-surface-2:#f5f8ff;--color-border:#c8d4ec;--color-border-2:#a0b4d8;--color-text:#1a202c;--color-text-2:#4a5568;--color-text-3:#718096;--color-primary:#1a56db;--color-primary-dim:#dbeafe;--color-valid:#16a34a;--color-valid-bg:#f0fdf4;--color-valid-text:#166534;--color-invalid:#dc2626;--color-invalid-bg:#fef2f2;--color-invalid-text:#991b1b;--color-warning:#d97706;--color-warning-bg:#fffbeb;--color-warning-text:#92400e;--color-code-bg:#f1f5f9;--color-version:#1a56db;--color-cost:#d97706;--color-salt:#16a34a;--color-hash:#7c3aed}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);min-width:320px;margin:0;font-size:1rem;line-height:1.6;overflow-x:hidden}.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}.skip-link{top:-100%;left:var(--space-4);background:var(--color-primary);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);z-index:9999;font-weight:600;text-decoration:none;transition:top .1s;position:absolute}.skip-link:focus{top:var(--space-4)}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}h1,h2,h3,h4{margin:0;line-height:1.2}p{margin:0 0 var(--space-4)}p:last-child{margin-bottom:0}code{font-family:var(--font-mono);background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.1em .35em;font-size:.875em}ul,ol{padding-left:var(--space-5);margin:0 0 var(--space-4)}li{margin-bottom:var(--space-1)}a{color:var(--color-primary);text-decoration:underline}a:hover{text-decoration:none}.site-header{background:var(--color-bg-2);border-bottom:1px solid var(--color-border)}.site-header__inner{max-width:1200px;padding:var(--space-3) var(--space-4);margin:0 auto;position:relative}.site-header__top{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.category-chip{text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);border:1px solid var(--color-accent);white-space:nowrap;border-radius:99px;padding:2px 10px;font-size:.75rem;font-weight:700;display:inline-block}.site-title{letter-spacing:-.02em;font-size:clamp(1.25rem,4vw,1.875rem);font-weight:800}.site-title__main{color:var(--color-text)}.site-title__sub{color:var(--color-text-2);margin-top:var(--space-1);font-size:clamp(.75rem,2vw,.9375rem);font-weight:400;display:block}.site-header__title-block{margin-bottom:var(--space-3)}.primitive-chips{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.primitive-chips__label{color:var(--color-text-3);margin-right:var(--space-1);font-size:.75rem;font-weight:600}.chip{font-size:.75rem;font-weight:600;font-family:var(--font-mono);background:var(--color-primary-dim);color:var(--color-primary);border-radius:var(--radius-sm);padding:2px 8px}.why-matters{color:var(--color-text-2);border-left:3px solid var(--color-primary);padding-left:var(--space-3);margin-bottom:var(--space-1);font-size:.875rem}.why-matters strong{color:var(--color-text)}.theme-toggle{background:var(--color-surface);width:2.6rem;height:2.6rem;color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.25rem;line-height:1;transition:background .15s,border-color .15s;display:inline-flex}.theme-toggle:hover{background:var(--color-surface-2);border-color:var(--color-primary)}.tabs-sticky-bar{z-index:100;background:var(--color-bg-2);border-bottom:1px solid var(--color-border);position:sticky;top:0}.panel-tabs-wrapper{max-width:1200px;padding:var(--space-4) var(--space-4) 0;gap:var(--space-1);-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin:0 auto;display:flex;overflow-x:auto}.panel-tab{align-items:center;gap:var(--space-2);background:var(--color-surface);color:var(--color-text-2);border:1px solid var(--color-border);border-radius:var(--radius-md) var(--radius-md) 0 0;padding:var(--space-2) var(--space-4);cursor:pointer;min-height:var(--tap-min);white-space:nowrap;border-bottom:none;flex-shrink:0;font-size:.875rem;font-weight:600;transition:background .15s,color .15s;display:flex}.panel-tab:hover{background:var(--color-surface-2);color:var(--color-text)}.panel-tab[aria-selected=true]{background:var(--color-bg-3);color:var(--color-primary);border-color:var(--color-primary);border-bottom:1px solid var(--color-bg-3);z-index:1;position:relative}.panel-tab__num{background:var(--color-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:inline-flex}.panel-tab[aria-selected=true] .panel-tab__num{background:var(--color-primary);color:#fff}.site-main{max-width:1200px;padding:var(--space-4) var(--space-4) var(--space-12);margin:0 auto}.panel{background:var(--color-bg-3);border:1px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-6)}.panel__inner{max-width:900px}.panel__title{color:var(--color-text);margin-bottom:var(--space-4);font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700}.panel__intro{color:var(--color-text-2);border-left:3px solid var(--color-border-2);padding-left:var(--space-4);margin-bottom:var(--space-6);font-size:1rem}.panel-section{margin-bottom:var(--space-8)}.section-title{color:var(--color-text);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);font-size:1.0625rem;font-weight:700}.btn{min-width:var(--tap-min);min-height:var(--tap-min);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-2);border:2px solid #0000;font-size:.9375rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover:not(:disabled){filter:brightness(1.15)}.btn--attack{color:var(--color-invalid);border-color:var(--color-invalid);background:0 0}.btn--attack:hover:not(:disabled){background:var(--color-invalid-bg)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn--small{min-width:32px;min-height:32px;padding:var(--space-1) var(--space-3);font-size:.8125rem}.button-row{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.control-row{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.control-label{color:var(--color-text-2);font-size:.875rem;font-weight:600}.text-input,.select-input{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);min-height:var(--tap-min);font-family:inherit;font-size:1rem}.text-input:focus,.select-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim);outline:none}.password-wrapper{align-items:center;display:flex;position:relative}.password-wrapper .text-input{flex:1;padding-right:3rem}.password-toggle{right:var(--space-2);color:var(--color-text-3);cursor:pointer;padding:var(--space-1);min-width:var(--tap-min);min-height:var(--tap-min);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.1rem;display:flex;position:absolute}.password-toggle:hover{color:var(--color-text)}.range-row{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.range-row input[type=range]{min-width:120px;accent-color:var(--color-primary);flex:1;height:6px}.range-value{font-family:var(--font-mono);color:var(--color-primary);text-align:center;min-width:2.5ch;font-size:1.125rem;font-weight:700}.result-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin:var(--space-4) 0;font-family:var(--font-mono);word-break:break-all;font-size:.875rem;position:relative;overflow-x:auto}.copy-btn{top:var(--space-2);right:var(--space-2);background:var(--color-surface-2);color:var(--color-text-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);cursor:pointer;min-width:var(--tap-min);min-height:32px;font-size:.75rem;transition:color .15s,border-color .15s;position:absolute}.copy-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.callout{background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--space-4);margin:var(--space-4) 0;font-size:.9375rem}.callout__title{color:var(--color-primary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:700}.callout--warning{border-left-color:var(--color-warning)}.callout--warning .callout__title{color:var(--color-warning)}.callout--valid{border-left-color:var(--color-valid)}.callout--valid .callout__title{color:var(--color-valid)}.anatomy-display{font-family:var(--font-mono);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);white-space:nowrap;font-size:clamp(.75rem,2.5vw,1.125rem);line-height:1.8;overflow-x:auto}.anatomy-version{color:var(--color-version);font-weight:700}.anatomy-cost{color:var(--color-cost);font-weight:700}.anatomy-salt{color:var(--color-salt);font-weight:700}.anatomy-hash{color:var(--color-hash);font-weight:700}.anatomy-legend{gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.anatomy-legend__item{align-items:center;gap:var(--space-2);font-size:.8125rem;display:flex}.anatomy-legend__dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.bar-chart{gap:var(--space-2);flex-direction:column;display:flex}.bar-row{align-items:center;gap:var(--space-3);min-height:32px;display:flex}.bar-label{font-family:var(--font-mono);color:var(--color-text-2);text-align:right;flex-shrink:0;min-width:5ch;font-size:.8125rem;font-weight:600}.bar-track{background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);flex:1;height:24px;position:relative;overflow:hidden}.bar-fill{border-radius:var(--radius-sm);background:var(--color-primary);min-width:2px;height:100%;transition:width .5s ease-out}.bar-fill--danger{background:var(--color-invalid)}.bar-fill--safe{background:var(--color-valid)}.bar-time{font-family:var(--font-mono);color:var(--color-text-2);text-align:left;flex-shrink:0;min-width:12ch;font-size:.75rem}.bar-multiplier{font-family:var(--font-mono);color:var(--color-text-3);flex-shrink:0;min-width:5ch;font-size:.75rem}.zone-label{text-transform:uppercase;letter-spacing:.05em;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);margin:var(--space-2) 0;font-size:.75rem;font-weight:700;display:inline-block}.zone-label--danger{color:var(--color-invalid-text);background:var(--color-invalid-bg)}.zone-label--safe{color:var(--color-valid-text);background:var(--color-valid-bg)}.comparison-table{border-collapse:collapse;width:100%;margin:var(--space-4) 0;font-size:.875rem}.comparison-table th,.comparison-table td{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);text-align:center;vertical-align:middle}.comparison-table th{background:var(--color-surface);color:var(--color-text-2);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.comparison-table td{background:var(--color-bg-3)}.comparison-table tr[data-expandable]{cursor:pointer;transition:background .15s}.comparison-table tr[data-expandable]:hover td{background:var(--color-surface)}.comparison-table .expand-row td{text-align:left;color:var(--color-text-2);background:var(--color-surface);padding:var(--space-3) var(--space-4);font-size:.8125rem}.scenario-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-6)}.scenario-card__title{color:var(--color-text);margin-bottom:var(--space-3);align-items:center;gap:var(--space-2);font-size:1rem;font-weight:700;display:flex}.scenario-card__badge{border-radius:var(--radius-sm);text-transform:uppercase;padding:2px 8px;font-size:.75rem;font-weight:700}.scenario-card__badge--danger{background:var(--color-invalid-bg);color:var(--color-invalid-text)}.scenario-card__badge--warning{background:var(--color-warning-bg);color:var(--color-warning-text)}.scenario-card__badge--safe{background:var(--color-valid-bg);color:var(--color-valid-text)}.user-table{border-collapse:collapse;width:100%;margin:var(--space-3) 0;font-size:.8125rem}.user-table th,.user-table td{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);text-align:left}.user-table th{background:var(--color-bg-3);color:var(--color-text-2);text-transform:uppercase;font-size:.75rem;font-weight:700}.user-table td{font-family:var(--font-mono);word-break:break-all;font-size:.75rem}.user-table .revealed{color:var(--color-invalid-text);background:var(--color-invalid-bg)}.user-table .safe{color:var(--color-valid-text)}.progress-bar{background:var(--color-surface-2);border-radius:var(--radius-sm);width:100%;height:8px;margin:var(--space-3) 0;overflow:hidden}.progress-bar__fill{background:var(--color-primary);border-radius:var(--radius-sm);height:100%;transition:width .3s}.status-display{color:var(--color-text-2);padding:var(--space-3);border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);margin-bottom:var(--space-4);font-size:.875rem}.timing-chart{gap:var(--space-1);flex-direction:column;display:flex}.timing-row{align-items:center;gap:var(--space-2);height:20px;display:flex}.timing-bar{border-radius:var(--radius-sm);min-width:2px;height:100%;transition:width .3s}.timing-bar--naive{background:var(--color-invalid)}.timing-bar--bcrypt{background:var(--color-valid)}.timing-label{font-family:var(--font-mono);color:var(--color-text-3);flex-shrink:0;min-width:6ch;font-size:.6875rem}@media (max-width:768px){.panel{padding:var(--space-4);border-radius:var(--radius-md)}.site-header__inner{padding:var(--space-2) var(--space-3)}.comparison-table,.user-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.bar-row{flex-wrap:wrap}.bar-track{width:100%;min-width:0}.anatomy-display{font-size:.75rem}.two-col{flex-direction:column}}@media (max-width:480px){.panel-tab__label{display:none}.panel-tab{padding:var(--space-2) var(--space-3)}.site-main{padding:var(--space-3) var(--space-3) var(--space-8)}}.two-col{gap:var(--space-6);display:flex}.two-col>*{flex:1;min-width:0}.scripture-footer{text-align:center;opacity:.7;color:var(--color-text-2);margin-top:2rem;padding:1.5rem;font-size:.85rem}.verify-result{padding:var(--space-3);border-radius:var(--radius-md);text-align:center;margin:var(--space-3) 0;font-size:1.125rem;font-weight:700}.verify-result--match{background:var(--color-valid-bg);color:var(--color-valid-text);border:1px solid var(--color-valid)}.verify-result--no-match{background:var(--color-invalid-bg);color:var(--color-invalid-text);border:1px solid var(--color-invalid)}.expand-icon{font-size:.75rem;transition:transform .2s;display:inline-block}.expand-icon--open{transform:rotate(90deg)}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);vertical-align:middle;border-radius:50%;width:1em;height:1em;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}
