*,::after,::before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080b12;--bg2:#0d1120;--bg3:#111827;--glass:rgba(255,255,255,0.035);--glass-b:rgba(255,255,255,0.08);--glass-hov:rgba(255,255,255,0.06);--border:rgba(255,255,255,0.07);--border-b:rgba(255,255,255,0.14);--blue:#3b82f6;--blue-b:#60a5fa;--cyan:#22d3ee;--violet:#8b5cf6;--pink:#ec4899;--yellow:#fbbf24;--green:#10b981;--red:#ef4444;--orange:#f97316;--txt:#e2e8f0;--txt2:#94a3b8;--txt3:#475569;--mono:'JetBrains Mono',monospace;--sans:'DM Sans',sans-serif;--display:'Syne',sans-serif;--radius:16px;--radius-sm:10px}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--txt);min-height:100vh;overflow-x:hidden;line-height:1.6}#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4}.orb{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0}.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,.15) 0,transparent 70%);top:-200px;left:-200px}.orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,.12) 0,transparent 70%);bottom:-150px;right:-150px}.orb-3{width:400px;height:400px;background:radial-gradient(circle,rgba(34,211,238,.08) 0,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%)}.wrapper{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:40px 20px 80px}header{text-align:center;margin-bottom:52px;animation:.7s both fadeDown}.logo-badge{display:inline-flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--border-b);border-radius:999px;padding:6px 16px 6px 10px;margin-bottom:24px;font-size:12px;color:var(--txt2);letter-spacing:.05em}.logo-dot{width:8px;height:8px;background:var(--cyan);border-radius:50%;box-shadow:0 0 8px var(--cyan);animation:2s ease-in-out infinite pulse}h1{font-family:var(--display);font-size:clamp(2.4rem, 6vw, 4rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;background:linear-gradient(135deg,#fff 30%,var(--blue-b) 60%,var(--cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{margin-top:12px;color:var(--txt2);font-size:1rem;font-weight:300;letter-spacing:.02em}.card{background:var(--glass);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:28px;margin-bottom:20px;transition:border-color .3s}.card:hover{border-color:var(--border-b)}.card-title{font-family:var(--display);font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--txt3);margin-bottom:20px}.pwd-display-card{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(139,92,246,.06));border-color:rgba(59,130,246,.2);animation:.7s .1s both fadeDown}.char-upper{color:var(--blue-b)}.char-lower{color:#e2e8f0}.char-number{color:var(--yellow)}.char-symbol{color:var(--pink)}.strength-row{display:flex;align-items:center;gap:14px;margin-top:16px}.strength-bar-track{flex:1;height:5px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}.strength-bar-fill{height:100%;border-radius:99px;transition:width .5s cubic-bezier(.34,1.56,.64,1),background .5s;width:0%}.strength-label{font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.08em;min-width:90px;text-align:right}.entropy-label{font-family:var(--mono);font-size:.7rem;color:var(--txt3);text-align:right;margin-top:6px}.controls-card{animation:.7s .15s both fadeDown}.slider-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}.slider-label{font-size:.85rem;color:var(--txt2);white-space:nowrap}.slider-value{font-family:var(--mono);font-size:1.5rem;font-weight:700;color:var(--blue-b);min-width:40px;text-align:center}input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:5px;background:rgba(255,255,255,.1);border-radius:99px;outline:0;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:linear-gradient(135deg,var(--blue),var(--violet));border-radius:50%;cursor:pointer;box-shadow:0 0 12px rgba(59,130,246,.5);transition:transform .15s,box-shadow .15s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 20px rgba(59,130,246,.7)}input[type=range]::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,var(--blue),var(--violet));border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 12px rgba(59,130,246,.5)}.toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:20px}.toggle-item{display:flex;align-items:center;gap:12px;background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;cursor:pointer;transition:.2s;user-select:none}.toggle-item:hover{border-color:var(--border-b);background:var(--glass-hov)}.toggle-item.active{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.08)}.toggle-item input{display:none}.toggle-switch{width:36px;height:20px;background:rgba(255,255,255,.1);border-radius:99px;position:relative;flex-shrink:0;transition:background .25s}.toggle-switch::after{content:'';position:absolute;width:14px;height:14px;background:var(--txt3);border-radius:50%;top:3px;left:3px;transition:.25s cubic-bezier(.34,1.56,.64,1)}.toggle-item.active .toggle-switch{background:linear-gradient(90deg,var(--blue),var(--violet))}.toggle-item.active .toggle-switch::after{left:19px;background:#fff}.toggle-info{flex:1}.toggle-name{font-size:.85rem;font-weight:500;color:var(--txt)}.toggle-chars{font-family:var(--mono);font-size:.65rem;color:var(--txt3);margin-top:1px}.lang-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.exclusion-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.excl-input{flex:1;min-width:200px;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-family:var(--mono);font-size:.85rem;color:var(--txt);outline:0;transition:border-color .2s}.excl-input::placeholder{color:var(--txt3)}.excl-input:focus{border-color:var(--blue)}.count-row{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.count-btn{flex:1;min-width:70px;background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font-family:var(--mono);font-size:.9rem;color:var(--txt2);cursor:pointer;transition:.2s;text-align:center}.count-btn:hover{border-color:var(--border-b);color:var(--txt)}.count-btn.active{background:rgba(59,130,246,.15);border-color:var(--blue);color:var(--blue-b);font-weight:700}.multi-list{display:flex;flex-direction:column;gap:8px}.multi-item{display:flex;align-items:center;gap:12px;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;animation:.3s both fadeIn}.multi-num{font-family:var(--mono);font-size:.7rem;color:var(--txt3);min-width:20px}.multi-pwd{flex:1;font-family:var(--mono);font-size:.82rem;word-break:break-all;letter-spacing:.04em;line-height:1.6}.multi-copy{width:30px;height:30px;background:var(--glass);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;color:var(--txt3);flex-shrink:0}.multi-copy:hover{border-color:var(--blue);color:var(--blue-b)}.multi-copy.copied{border-color:var(--green);color:var(--green)}.multi-copy svg{width:13px;height:13px}.save-card{animation:.7s .25s both fadeDown}.save-form{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}.save-input{flex:1;min-width:160px;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-family:var(--sans);font-size:.85rem;color:var(--txt);outline:0;transition:border-color .2s}.save-input::placeholder{color:var(--txt3)}.save-input:focus{border-color:var(--blue)}.save-btn{padding:10px 20px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-sm);font-family:var(--sans);font-size:.85rem;font-weight:500;color:var(--blue-b);cursor:pointer;transition:.2s;white-space:nowrap}.save-btn:hover{background:rgba(59,130,246,.25);border-color:var(--blue)}.clear-all-btn{padding:10px 16px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);font-family:var(--sans);font-size:.82rem;color:rgba(239,68,68,.7);cursor:pointer;transition:.2s;white-space:nowrap}.clear-all-btn:hover{background:rgba(239,68,68,.2);color:var(--red);border-color:var(--red)}.saved-list{display:flex;flex-direction:column;gap:8px}.saved-item{display:flex;align-items:center;gap:12px;background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;animation:.3s both fadeIn;transition:border-color .2s}.saved-item:hover{border-color:var(--border-b)}.saved-site{font-size:.85rem;font-weight:500;color:var(--txt);min-width:80px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-pwd{flex:1;font-family:var(--mono);font-size:.78rem;color:var(--txt2);word-break:break-all;cursor:pointer;transition:color .2s;position:relative}.saved-pwd .masked{letter-spacing:.15em}.saved-actions{display:flex;gap:6px;flex-shrink:0}.saved-copy,.saved-del,.saved-reveal{width:28px;height:28px;background:var(--glass);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;color:var(--txt3)}.saved-copy:hover{border-color:var(--blue);color:var(--blue-b)}.saved-reveal:hover{border-color:var(--violet);color:#a78bfa}.saved-del:hover{border-color:var(--red);color:var(--red);background:rgba(239,68,68,.1)}.saved-copy svg,.saved-del svg,.saved-reveal svg{width:12px;height:12px}.saved-copy.copied{border-color:var(--green);color:var(--green)}.empty-state{text-align:center;padding:32px;color:var(--txt3);font-size:.85rem}.empty-icon{font-size:2rem;margin-bottom:8px;opacity:.4}.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(80px);background:rgba(16,185,129,.15);border:1px solid var(--green);border-radius:99px;padding:10px 24px;font-family:var(--mono);font-size:.8rem;color:var(--green);backdrop-filter:blur(20px);transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .35s;opacity:0;z-index:1000;pointer-events:none}.toast.show{transform:translateX(-50%) translateY(0);opacity:1}.section-divider{display:flex;align-items:center;gap:14px;margin:8px 0 20px}.section-divider span{font-size:.7rem;color:var(--txt3);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}.section-divider::after,.section-divider::before{content:'';flex:1;height:1px;background:var(--border)}@keyframes fadeDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 8px var(--cyan)}50%{opacity:.5;box-shadow:0 0 4px var(--cyan)}}@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}footer{text-align:center;margin-top:40px;font-size:.72rem;color:var(--txt3);letter-spacing:.04em}footer span{color:var(--txt2)}@media (max-width:600px){.wrapper{padding:28px 14px 60px}.card{padding:20px}.slider-row{flex-wrap:wrap}.save-form{flex-direction:column}.saved-site{min-width:60px;max-width:100px}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-b);border-radius:99px}