*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#0B0E11;--card:rgba(20,24,32,.7);--border:rgba(108,92,231,.12);--text:#E8E6F0;--muted:#8B8A9E;--dim:#5A5872;--primary:#6C5CE7;--primary-light:#A29BFE;--accent:#00CEC9;--success:#00B894;--warn:#FDCB6E;--danger:#FF6B6B;--radius:12px;--font:'Inter',system-ui,sans-serif}
html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex;justify-content:center;padding:24px 16px 60px}
.app-container{max-width:600px;width:100%}
.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:8px}
.logo-group{display:flex;align-items:center;gap:10px}
h1{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--primary-light),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
h2{font-size:.82rem;font-weight:600;margin-bottom:8px}
.offline-badge{font-size:.68rem;padding:3px 8px;border-radius:999px;background:rgba(0,184,148,.1);color:var(--success);border:1px solid rgba(0,184,148,.2)}
.input-card,.detail-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;backdrop-filter:blur(12px)}
.input-card label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:6px;font-weight:500}
.input-wrap{display:flex;gap:6px;margin-bottom:10px}
.password-input{flex:1;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font);font-size:1rem;padding:10px 12px;outline:none;letter-spacing:.05em}
.password-input:focus{border-color:var(--primary)}
.btn{border:none;cursor:pointer;font-family:var(--font);font-weight:600;border-radius:8px;transition:all .2s}
.btn-sm{font-size:.75rem;padding:6px 10px}
.btn-ghost{background:transparent;color:var(--muted)}
.meter-bar{height:6px;background:rgba(255,255,255,.05);border-radius:999px;overflow:hidden;margin-bottom:6px}
.meter-fill{height:100%;border-radius:999px;transition:width .4s ease,background .3s}
.meter-label{font-size:.75rem;color:var(--muted);text-align:center}
.hidden{display:none}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.stat{text-align:center;padding:10px;background:rgba(0,0,0,.2);border-radius:10px}
.stat-val{font-size:1.3rem;font-weight:800;font-variant-numeric:tabular-nums}
.stat-lbl{font-size:.62rem;color:var(--muted);margin-top:2px}
.char-classes{display:flex;flex-wrap:wrap;gap:6px}
.cc-tag{font-size:.72rem;padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-weight:500}
.cc-tag.active{border-color:var(--accent);color:var(--accent);background:rgba(0,206,201,.08)}
.cc-tag.inactive{color:var(--dim);opacity:.5}
.attack-table{display:flex;flex-direction:column;gap:4px}
.attack-row{display:flex;justify-content:space-between;padding:6px 8px;font-size:.73rem;background:rgba(0,0,0,.12);border-radius:6px}
.attack-row .speed{color:var(--muted)}.attack-row .time{font-weight:600}
.patterns{display:flex;flex-direction:column;gap:4px}
.pattern-item{font-size:.73rem;padding:6px 8px;border-radius:6px}
.pattern-item.warn{background:rgba(253,203,110,.08);color:var(--warn)}
.pattern-item.ok{background:rgba(0,184,148,.08);color:var(--success)}
.nist{font-size:.75rem;line-height:1.6;color:var(--muted)}
.nist .check{color:var(--success)}.nist .cross{color:var(--danger)}
@media(max-width:500px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
