.passgen-page{--bg-deep:#080014;--bg-plum:#22002c;--accent-gold:#ffcc33;--accent-gold-soft:#ffe58a;--accent-red:#c2185b;--accent-magenta:#ff3366;--accent-cyan:#00f6ff;--accent-purple:#7b1fa2;--text-main:#f8f5ff;--text-muted:#c8bfe0;--machine-face:#2b1539;--machine-face-inner:#3b214b;--border-radius-large:24px;--reel-width:24px;--cell:44px;--spin-ms:1200}.passgen-page *{box-sizing:border-box}.passgen-page{}.passgen-page{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.passgen-page{width:100%;max-width:var(--tool-page-max-width,1600px);margin:0 auto;padding:24px 16px 32px;background:0 0}.passgen-page .app-header{text-align:center;margin-bottom:24px}.passgen-page .title-container{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:8px;flex-wrap:wrap}.passgen-page .title-icon{font-size:3rem;filter:drop-shadow(0 0 8px rgba(255,204,51,.6));animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,100%{filter:drop-shadow(0 0 8px rgba(255,204,51,.6));transform:scale(1)}50%{filter:drop-shadow(0 0 16px rgba(255,204,51,.9));transform:scale(1.05)}}.passgen-page .app-header h1{font-size:clamp(2.2rem,3vw,2.8rem);margin:0;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient( to right,var(--accent-gold),var(--accent-magenta),var(--accent-cyan) );-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 12px rgba(0,0,0,.8)}.passgen-page .app-header p{margin:0;font-size:.98rem;color:var(--text-muted)}.passgen-page .ad-container{max-width:var(--tool-page-max-width,1600px);margin:16px auto;padding:0 16px;text-align:center;min-height:90px}.passgen-page .ad-container.top-ad{margin-top:0;margin-bottom:24px}.passgen-page .ad-container.bottom-ad{margin-top:32px;margin-bottom:16px}.passgen-page .ad-label{font-size:.7rem;color:var(--text-muted);opacity:.6;margin-bottom:4px;text-transform:uppercase;letter-spacing:.1em}.passgen-page .machine-section{display:flex;justify-content:center;align-items:center;width:100%;background:0 0}.passgen-page .machine-outer{position:relative;perspective:1200px;width:100%;max-width:900px;margin:0 auto;background:0 0}.passgen-page .no-3d .machine-outer{perspective:none}.passgen-page .machine-frame{position:relative;border-radius:var(--border-radius-large);padding:24px 20px 20px;background:linear-gradient(145deg,#4a274a,#120516),radial-gradient(circle at top left,#7b2cbf,transparent 60%),radial-gradient(circle at bottom right,#ff8a00,transparent 60%);box-shadow:0 0 0 2px rgba(255,255,255,5%),0 16px 40px rgba(5,10,20,.45),0 0 60px rgba(65,35,96,.35);transform-style:preserve-3d;transform:none;transition:transform 280ms ease-out,box-shadow 280ms ease-out}.passgen-page .no-3d .machine-frame{transform:none}.passgen-page .bulb-strip{position:absolute;display:flex;pointer-events:none;z-index:2}.bulb-strip.top,.passgen-page .bulb-strip.bottom{left:11%;right:11%;justify-content:space-between}.passgen-page .bulb-strip.top{top:6px}.passgen-page .bulb-strip.bottom{bottom:6px}.bulb-strip.left,.passgen-page .bulb-strip.right{top:18%;bottom:18%;flex-direction:column;justify-content:space-between}.passgen-page .bulb-strip.left{left:6px}.passgen-page .bulb-strip.right{right:6px}.passgen-page .bulb{width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff 0,#fff 20%,#ffd76a 45%,#b57b11 70%,#704813 100%);box-shadow:0 0 6px rgba(255,204,51,.85),0 0 16px rgba(255,204,51,.7);filter:brightness(1)}.passgen-page .machine-frame.spinning .bulb{animation:bulb-marquee .9s linear infinite;animation-delay:calc(var(--i) * .06s)}@keyframes bulb-marquee{0%,30%{filter:brightness(.7);box-shadow:0 0 3px rgba(255,204,51,.4),0 0 8px rgba(255,204,51,.3)}45%{filter:brightness(1.9);box-shadow:0 0 8px #fff,0 0 20px #fc3}100%{filter:brightness(.7);box-shadow:0 0 3px rgba(255,204,51,.4),0 0 8px rgba(255,204,51,.3)}}.passgen-page .machine-frame.jackpot .bulb{animation:bulb-flash .35s ease-in-out 2}@keyframes bulb-flash{0%,100%{filter:brightness(1);box-shadow:0 0 6px rgba(255,204,51,.6),0 0 10px rgba(255,204,51,.4)}50%{filter:brightness(1.9);box-shadow:0 0 12px #fff,0 0 24px #fc3}}.passgen-page .machine-body{position:relative;border-radius:calc(var(--border-radius-large) - 6px);padding:18px 18px 16px;background:linear-gradient(160deg,#1b0f27,#321b42);box-shadow:inset 0 0 0 1px rgba(255,255,255,5%),inset 0 12px 24px rgba(255,255,255,5%),0 16px 40px rgba(0,0,0,.9);z-index:1}.passgen-page .machine-display-block{background:radial-gradient(circle at top,rgba(255,255,255,.14),transparent 65%),linear-gradient(135deg,var(--machine-face),var(--machine-face-inner));border-radius:18px;padding:14px 14px 12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,4%),0 12px 28px rgba(0,0,0,.85);margin-bottom:16px}.passgen-page .display-header{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-gold-soft);opacity:.85;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.passgen-page .display-header span.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-left:6px;background:radial-gradient(circle,#0f0 0,#0f0 40%,#093 70%,transparent 100%);box-shadow:0 0 6px rgba(0,255,128,.8),0 0 12px rgba(0,255,128,.6)}.passgen-page .reel-window{position:relative;border-radius:14px;padding:10px;background:radial-gradient(circle at 50% 0,rgba(255,255,255,.18),transparent 55%),linear-gradient(180deg,#140b24,#1f1033);box-shadow:inset 0 0 0 1px rgba(255,255,255,8%),0 10px 20px rgba(0,0,0,.9);overflow:hidden;display:flex;justify-content:center}.passgen-page .reels{position:relative;display:grid;justify-content:center;justify-items:center;gap:4px;grid-template-columns:repeat(var(--cols,12),var(--reel-width));width:calc( (var(--cols,12) * var(--reel-width)) + ((var(--cols,12) - 1) * 4px) + 12px );max-width:100%;margin:0 auto;padding:4px 6px;border-radius:12px;border:1px solid rgba(255,255,255,8%);box-shadow:inset 0 4px 12px rgba(0,0,0,.6),inset 0 -4px 12px rgba(0,0,0,.6);overflow:hidden}.passgen-page .reels.light-rim{border-color:rgba(212,175,55,.9);box-shadow:0 0 0 2px rgba(212,175,55,.95),0 0 24px rgba(212,175,55,.85),inset 0 0 24px rgba(212,175,55,.75);animation:rimBlink 140ms steps(2)infinite}@keyframes rimBlink{0%,50%{filter:brightness(1)}100%{filter:brightness(1.25)}}.passgen-page .reel{width:var(--reel-width);height:var(--cell);overflow:hidden;border-radius:10px;background:radial-gradient( circle at 50% 0,rgba(255,255,255,.16),transparent 70% );box-shadow:0 0 0 1px rgba(0,0,0,.85),0 4px 10px rgba(0,0,0,.6);position:relative}.passgen-page .strip{will-change:transform;transform:translateY(0)}.passgen-page .symbol{height:var(--cell);display:grid;place-items:center;font-weight:600;font-size:1.08rem;color:var(--accent-cyan);text-shadow:0 0 10px rgba(0,246,255,.9),0 0 16px rgba(0,0,0,.7)}.passgen-page .password-output{margin-top:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.passgen-page .password-output input{flex:auto;min-width:0;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:radial-gradient(circle at top,#280c3d,#13021c);color:var(--accent-gold-soft);font-size:.95rem;letter-spacing:.12em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;outline:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.75),0 0 12px rgba(255,255,255,4%)}.passgen-page .password-output input::placeholder{color:rgba(255,255,255,.35)}.passgen-page .btn,.passgen-page .pill-button{position:relative;border-radius:999px;border:none;padding:8px 14px;font-size:.88rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;color:#1a061e;background:radial-gradient(circle at 30% 10%,#fffbe5 0,#ffe58a 45%,#ffb300 80%);box-shadow:0 4px 10px rgba(0,0,0,.8),0 0 18px rgba(255,204,51,.8);transition:transform 120ms ease-out,box-shadow 120ms ease-out,filter 120ms ease-out}.passgen-page .btn:hover,.passgen-page .pill-button:hover{transform:translateY(-1px)scale(1.03);box-shadow:0 6px 14px rgba(0,0,0,.9),0 0 20px rgba(255,225,120,.85);filter:brightness(1.05)}.passgen-page .btn:active,.passgen-page .pill-button:active{transform:translateY(1px)scale(.98);box-shadow:0 2px 8px rgba(0,0,0,.9),0 0 12px rgba(255,204,51,.7)}.passgen-page .btn:focus-visible,.passgen-page .pill-button:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.passgen-page .copy-toast{font-size:.8rem;color:var(--accent-cyan);opacity:0;transform:translateY(2px);transition:opacity 160ms ease-out,transform 160ms ease-out}.passgen-page .copy-toast.visible{opacity:1;transform:translateY(0)}.passgen-page .toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%)translateY(20px);background:#0d0a13;color:#fff;border:1px solid rgba(255,255,255,.15);padding:10px 14px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.45);opacity:0;transition:.25s ease;z-index:1000}.passgen-page .toast.on{opacity:1;transform:translateX(-50%)translateY(0)}.passgen-page .machine-controls{margin-top:14px;padding:12px 12px 14px;border-radius:14px;background:linear-gradient( 180deg,rgba(9,3,24,.92),rgba(10,4,20,.98) );box-shadow:inset 0 0 0 1px rgba(255,255,255,4%),0 6px 20px rgba(0,0,0,.9)}.passgen-page .control-grid{display:grid;grid-template-columns:minmax(0,2fr)minmax(0,3fr)minmax(0,1.6fr);gap:10px;align-items:flex-start}@media(max-width:900px){.passgen-page .control-grid{grid-template-columns:1fr}}.passgen-page .control-group{text-align:left}.passgen-page .control-label{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:6px}.passgen-page .control-label span.value{color:var(--accent-gold-soft);font-weight:600}.passgen-page .length-slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;background:linear-gradient( 90deg,var(--accent-magenta),var(--accent-gold),var(--accent-cyan) );outline:none;box-shadow:0 0 0 1px rgba(0,0,0,.7),0 0 10px rgba(255,255,255,6%)}.passgen-page .length-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 20%,#fff 0,#ffe58a 45%,#ffb300 80%);border:1px solid rgba(0,0,0,.7);box-shadow:0 2px 6px rgba(0,0,0,.9),0 0 10px rgba(255,204,51,.9);cursor:pointer;margin-top:-6px}.passgen-page .length-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 20%,#fff 0,#ffe58a 45%,#ffb300 80%);border:1px solid rgba(0,0,0,.7);box-shadow:0 2px 6px rgba(0,0,0,.9),0 0 10px rgba(255,204,51,.9);cursor:pointer}.passgen-page .length-slider::-moz-range-track{height:6px;border-radius:999px;background:linear-gradient( 90deg,var(--accent-magenta),var(--accent-gold),var(--accent-cyan) )}.passgen-page .switch-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}@media(max-width:480px){.passgen-page .switch-grid{grid-template-columns:1fr}}.passgen-page .pill-toggle{position:relative;display:inline-flex;align-items:center;justify-content:space-between;gap:6px;padding:6px 10px;border-radius:999px;background:radial-gradient(circle at 30% 0,#2d1639,#120415);color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,6%),0 3px 6px rgba(0,0,0,.9);user-select:none}.passgen-page .pill-toggle input{display:none}.passgen-page .toggle-knob{width:26px;height:16px;border-radius:999px;background:linear-gradient(180deg,#120016,#2a0636);box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 0 6px rgba(0,0,0,.9);position:relative}.passgen-page .toggle-knob::before{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 30% 20%,#fff,#ffd76a,#ffb300);box-shadow:0 1px 3px rgba(0,0,0,.8),0 0 6px rgba(255,204,51,.8);transition:transform 140ms ease-out}.passgen-page .pill-toggle input:checked+.toggle-knob::before{transform:translateX(8px)}.passgen-page .pill-toggle input:checked~.toggle-label{color:var(--accent-gold-soft)}.passgen-page .pill-toggle:hover{box-shadow:inset 0 0 0 1px rgba(255,255,255,9%),0 4px 8px rgba(0,0,0,.95)}.passgen-page .toggle-label{flex:1}.passgen-page .constraints{display:grid;grid-template-columns:1fr;gap:4px;margin-top:4px}.passgen-page .constraints .pill-toggle{font-size:.75rem;letter-spacing:.08em}.passgen-page .hint{font-size:.75rem;color:var(--accent-cyan);margin-top:4px;opacity:.75}.passgen-page .sound-control{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:right}.passgen-page .pill-button{width:100%;justify-content:center}.passgen-page .pill-button.muted{background:radial-gradient(circle at 30% 10%,#f5f5f5 0,#d5d5d5 45%,#999 80%);box-shadow:0 4px 10px rgba(0,0,0,.8),0 0 10px rgba(180,180,180,.5);color:#333}.passgen-page .sound-caption{font-size:.78rem;color:var(--text-muted)}.passgen-page .error-message{margin-top:8px;font-size:.78rem;color:#ff8080;min-height:.9em}.passgen-page .spin-row{margin-top:10px;display:flex;justify-content:center}.passgen-page .spin-btn{padding:10px 22px;font-size:.95rem;max-width:280px;width:100%;text-align:center}.passgen-page .history-section{margin-top:22px;padding:12px 14px 10px;border-radius:18px;background:radial-gradient(circle at top,rgba(255,255,255,6%),transparent 55%),linear-gradient(160deg,rgba(7,2,18,.96),rgba(10,4,24,.98));box-shadow:0 10px 26px rgba(0,0,0,.9),inset 0 0 0 1px rgba(255,255,255,5%);max-width:900px;margin-left:auto;margin-right:auto}.passgen-page .history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.passgen-page .history-header h2{font-size:.9rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin:0}.passgen-page .history-header span{font-size:.76rem;color:rgba(200,191,224,.8)}.passgen-page .history-list{list-style:none;margin:4px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:6px}.passgen-page .history-list li{padding:6px 8px;border-radius:999px;background:radial-gradient(circle at top,#241338,#11051d);border:1px solid rgba(255,255,255,6%);font-size:.78rem;color:var(--accent-gold-soft);letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.85),0 0 10px rgba(255,255,255,5%);transition:transform 120ms ease-out,box-shadow 120ms ease-out,border-color 120ms ease-out}.passgen-page .history-list li:hover{transform:translateY(-1px);border-color:rgba(0,246,255,.6);box-shadow:0 3px 8px rgba(0,0,0,.95),0 0 16px rgba(0,246,255,.5)}.passgen-page .history-list li:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.passgen-page .confetti-piece{position:fixed;top:-10px;width:6px;height:14px;border-radius:2px;opacity:.9;z-index:999;animation-name:confettiFall;animation-timing-function:linear;animation-fill-mode:forwards;pointer-events:none}@keyframes confettiFall{0%{transform:translate3d(0,0,0)rotateZ(0);opacity:1}100%{transform:translate3d(15px,100vh,0)rotateZ(540deg);opacity:0}}@media(prefers-reduced-motion:reduce){.passgen-page .confetti-piece{animation:none!important;display:none!important}.passgen-page .machine-frame{transition:none!important}}@media(max-width:640px){.passgen-page .machine-frame{padding:18px 14px 16px}.passgen-page .machine-body{padding:12px 10px 10px}.passgen-page .password-output{flex-direction:column;align-items:stretch}.passgen-page .password-output .btn{width:100%;justify-content:center}.passgen-page .sound-control{align-items:flex-start;text-align:left}.passgen-page .reels{grid-template-columns:repeat(auto-fit,minmax(var(--reel-width),1fr));width:100%;justify-content:center}}}