:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:#ffffffde;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);min-height:100vh;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh;width:100%}.header{background:#0003;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(100,108,255,.2);position:sticky;top:0;z-index:1000;padding:1rem 0;width:100%}.header-container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;position:relative}.logo-section{display:flex;align-items:center;gap:.75rem;z-index:1001}.header-logo{width:36px;height:36px;object-fit:contain;border-radius:8px;transition:transform .3s ease}.header-logo:hover{transform:scale(1.05)}.brand-name{font-size:1.25rem;font-weight:700;color:#646cff;text-decoration:none}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;z-index:1002;padding:.5rem}.hamburger{display:flex;flex-direction:column;width:24px;height:18px;position:relative}.hamburger span{display:block;height:2px;background-color:#fffc;border-radius:1px;transition:all .3s ease;transform-origin:center}.hamburger span:nth-child(1){margin-bottom:6px}.hamburger span:nth-child(2){margin-bottom:6px}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.navigation{display:flex;gap:2rem;align-items:center}.nav-link{color:#fffc;text-decoration:none;font-weight:500;padding:.75rem 1rem;border-radius:8px;transition:all .3s ease;white-space:nowrap;min-height:44px;display:flex;align-items:center}.nav-link:hover,.nav-link:focus{color:#646cff;background:#646cff1a;outline:none}.mobile-overlay{display:none}.main-content{flex:1;padding:2rem 0;display:flex;align-items:center;justify-content:center;width:100%}.container{width:100%;margin:0 auto;padding:0 1rem;text-align:center}h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:1rem;background:linear-gradient(135deg,#646cff,#535bf2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.subtitle{font-size:clamp(1rem,2.5vw,1.2rem);color:#ffffffb3;margin-bottom:2rem;margin-left:auto;margin-right:auto}.password-section{background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px #0000004d;width:100%}.password-box{margin-bottom:2rem}.password-input{width:100%;padding:1rem;font-size:clamp(.9rem,2vw,1.1rem);font-family:Courier New,monospace;background:#0003;border:2px solid rgba(100,108,255,.3);border-radius:8px;color:#fff;margin-bottom:1rem;transition:all .3s ease;min-height:50px}.password-input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff33}.password-input::placeholder{color:#ffffff80}.button-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.generate-btn,.copy-btn{padding:.875rem 1.5rem;font-size:clamp(.9rem,2vw,1rem);font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;min-height:50px;min-width:120px;white-space:nowrap}.generate-btn{background:linear-gradient(135deg,#646cff,#535bf2);color:#fff;box-shadow:0 4px 15px #646cff66}.generate-btn:hover,.generate-btn:focus{background:linear-gradient(135deg,#535bf2,#4338ca);transform:translateY(-2px);box-shadow:0 6px 20px #646cff99;outline:none}.copy-btn{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3)}.copy-btn:hover:not(:disabled),.copy-btn:focus:not(:disabled){background:#fff3;border-color:#ffffff80;transform:translateY(-2px);outline:none}.copy-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.controls{text-align:left;margin-top:1.5rem}.length-control{margin-bottom:2rem}.length-control label{display:block;margin-bottom:1rem;font-weight:600;font-size:clamp(1rem,2.5vw,1.1rem);color:#ffffffe6}.range-slider{width:100%;height:8px;background:#fff3;border-radius:4px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:linear-gradient(135deg,#646cff,#535bf2);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #646cff66;transition:all .3s ease}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #646cff99}.range-slider::-moz-range-thumb{width:24px;height:24px;background:linear-gradient(135deg,#646cff,#535bf2);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 8px #646cff66}.checkbox-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.checkbox-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;cursor:pointer;min-height:50px}.checkbox-item:hover{background:#ffffff1a;border-color:#646cff4d}.checkbox-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#646cff}.checkbox-item label{cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:#ffffffe6;font-size:clamp(.9rem,2vw,1rem)}.footer{background:#0000004d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(100,108,255,.2);padding:2rem 0 1rem;margin-top:auto;width:100%}.footer-container{width:100%;padding:0 1rem;display:grid;grid-template-columns:1fr;gap:2rem;margin:0 auto}.footer-section h3{color:#646cff;margin-bottom:1rem;font-size:clamp(1.1rem,2.5vw,1.2rem)}.footer-brand{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;justify-content:center}.footer-logo{width:32px;height:32px;object-fit:contain}.footer-brand-name{font-size:clamp(1.2rem,3vw,1.3rem);font-weight:700;color:#646cff}.footer-description{color:#ffffffb3;line-height:1.6;text-align:center;margin:0 auto}.footer-section{text-align:center}.footer-section ul{list-style:none}.footer-section li{margin-bottom:.5rem;color:#ffffffb3;transition:color .3s ease}.footer-section li:hover{color:#ffffffe6;cursor:default}.social-links{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.social-link{color:#ffffffb3;text-decoration:none;padding:.75rem;border-radius:8px;transition:all .3s ease;min-height:44px;display:flex;align-items:center}.social-link:hover,.social-link:focus{color:#646cff;background:#646cff1a;outline:none}.footer-bottom{margin-top:2rem;padding:1rem;border-top:1px solid rgba(255,255,255,.1);text-align:center;color:#fff9;width:100%;font-size:clamp(.8rem,2vw,.9rem)}@media (min-width: 768px){.header-container,.container{padding:0 2rem}.main-content{padding:3rem 0}.password-section{padding:2rem}.subtitle{margin-bottom:3rem}.button-group{flex-direction:row}.checkbox-controls{gap:2rem}.footer-container{grid-template-columns:repeat(2,1fr);gap:3rem;padding:0 2rem}.footer-section{text-align:left}.footer-brand{justify-content:flex-start}.footer-description{text-align:left;margin:0}.social-links{justify-content:flex-start}}@media (min-width: 1024px){.main-content{padding:4rem 0}.password-section{padding:2.5rem}.controls{text-align:left}.footer-container{grid-template-columns:repeat(4,1fr);gap:2rem}}@media (min-width: 1400px){.header-container,.container,.footer-container{padding-left:2rem;padding-right:2rem}}@media (max-width: 767px){.mobile-menu-btn{display:block}.navigation{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#000000f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;justify-content:center;align-items:center;gap:2rem;transition:right .3s ease;z-index:1000;border-left:1px solid rgba(100,108,255,.2)}.navigation.mobile-open{right:0}.mobile-overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999}.nav-link{font-size:1.2rem;width:100%;text-align:center;padding:1rem}.brand-name{font-size:1.1rem}.header-logo{width:32px;height:32px}.button-group{flex-direction:column;align-items:center}.generate-btn,.copy-btn{width:100%}.checkbox-controls{flex-direction:column;gap:1rem}}@media (max-width: 480px){.header-container,.container{padding:0 1rem}.password-section{padding:1rem}.navigation{width:100vw}.footer-bottom{font-size:.8rem}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.header-logo,.footer-logo{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus-visible,input:focus-visible,a:focus-visible{outline:2px solid #646cff;outline-offset:2px}@media print{.header,.footer,.mobile-menu-btn,.button-group{display:none!important}body{background:#fff!important;color:#000!important}.password-section{background:#fff!important;border:1px solid black!important}}
