*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}:root[data-theme=dark]{--bg-primary: #1e1e1e;--bg-surface: #252526;--bg-surface-alt: #2d2d30;--bg-hover: #37373d;--text-primary: #d4d4d4;--text-secondary: #cccccc;--text-muted: #9d9d9d;--text-dimmed: #858585;--text-disabled: #6e6e6e;--accent-teal: #4ec9b0;--accent-teal-hover: #6ed9c3;--accent-blue: #0e639c;--accent-blue-hover: #1177bb;--accent-orange: #ce9178;--border-color: #3e3e42;--shadow: rgba(0, 0, 0, .5)}:root[data-theme=light]{--bg-primary: #ffffff;--bg-surface: #f8f9fa;--bg-surface-alt: #f4f5f6;--bg-hover: #e9ecef;--text-primary: #212529;--text-secondary: #495057;--text-muted: #6c757d;--text-dimmed: #868e96;--text-disabled: #adb5bd;--accent-teal: #0d9488;--accent-teal-hover: #0f766e;--accent-blue: #0ea5e9;--accent-blue-hover: #0284c7;--accent-orange: #f97316;--border-color: #dee2e6;--shadow: rgba(0, 0, 0, .075)}body{margin:0;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh;background:var(--bg-primary)}a{color:var(--accent-teal);text-decoration:none}a:hover{text-decoration:underline;color:var(--accent-teal-hover)}*{box-sizing:border-box}.app{width:45vw;margin-inline:auto;min-height:100vh;background:var(--bg-primary);font-family:Roboto,sans-serif;transition:background-color .3s ease}.header{background:var(--bg-surface);color:var(--text-primary);padding:1.5rem 2rem;box-shadow:0 2px 4px var(--shadow);display:flex;justify-content:space-between;align-items:center;gap:2rem;border-bottom:1px solid var(--border-color);transition:background-color .3s ease,color .3s ease}.header-controls{display:flex;align-items:center;gap:1rem}.header-content{max-width:1400px;flex:1}.logo-section{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.logo{font-size:2.5rem;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.3))}.header h1{margin:0;font-size:2rem;font-weight:600}.tagline{margin:0;font-size:.95rem;opacity:.95;font-weight:300}.nav{background:var(--bg-surface);padding:0;display:flex;gap:0;box-shadow:0 2px 4px var(--shadow);overflow-x:auto;border-bottom:1px solid var(--border-color);transition:background-color .3s ease}.nav-btn{background:var(--bg-surface-alt);color:var(--text-secondary);border:none;padding:1rem 1.5rem;cursor:pointer;font-size:.9rem;transition:all .2s;white-space:nowrap;border-right:1px solid var(--border-color)}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-btn.active{background:var(--bg-primary);color:var(--accent-teal);border-bottom:2px solid var(--accent-teal)}.main-content{max-width:1600px;margin:0 auto;display:flex;gap:1rem;justify-content:center;align-items:flex-start}.ad-slot{flex-shrink:0;width:300px}.ad-slot.ad-right{display:flex;flex-direction:column;gap:1rem;position:sticky;top:2rem;height:fit-content}.ad-right-top,.ad-right-bottom{background:var(--bg-surface);border-radius:4px;padding:1rem;box-shadow:0 2px 4px var(--shadow);min-height:250px;border:1px solid var(--border-color)}.ad-slot:empty{display:none}@media(max-width:1280px){.app{width:75vw}.main-content{flex-direction:column;align-items:center}.ad-slot{display:none}.generator-section{width:100%}}.generator-section{background:var(--bg-surface);border-radius:4px;box-shadow:0 2px 8px var(--shadow);overflow:hidden;margin:0 auto;border:1px solid var(--border-color);transition:background-color .3s ease}.banner{background:var(--bg-surface-alt);color:var(--accent-orange);padding:.75rem 1.5rem;text-align:center;font-weight:500;font-size:.9rem;border-bottom:1px solid var(--border-color);transition:background-color .3s ease,color .3s ease}.generator-card{padding:2rem;background:var(--bg-surface);transition:background-color .3s ease}.generator-card h2{color:var(--text-primary);margin:0 0 1rem;font-size:1.75rem;font-weight:500;transition:color .3s ease}.description{color:var(--text-muted);line-height:1.6;margin-bottom:2rem;font-size:.95rem;transition:color .3s ease}.password-display{background:var(--bg-primary);padding:1.5rem;border-radius:4px;margin-bottom:2rem;border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.password-display label{display:block;font-weight:500;margin-bottom:.75rem;color:var(--text-primary);transition:color .3s ease}.password-input-group{display:flex;gap:.5rem;margin-bottom:.75rem}.password-input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:3px;font-size:1rem;font-family:Roboto,monospace;background:var(--bg-primary);color:var(--text-primary);letter-spacing:1px;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.password-input:focus{outline:none;border-color:var(--accent-teal)}.copy-btn{background:var(--accent-blue);color:var(--bg-primary);border:none;padding:.75rem 2rem;border-radius:4px;cursor:pointer;font-weight:600;transition:background-color .3s ease;white-space:nowrap}.copy-btn:hover{background:var(--accent-blue-hover)}.strength-indicator{color:var(--accent-teal);font-weight:500;margin:.5rem 0 0;font-size:1rem;transition:color .3s ease}.generator-options{background:var(--bg-primary);padding:1.5rem;border-radius:4px;margin-bottom:2rem;border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.options-title{background:var(--bg-surface-alt);color:var(--text-primary);margin:-1.5rem -1.5rem 1.5rem;padding:.75rem 1.5rem;border-radius:4px 4px 0 0;font-size:1.1rem;font-weight:500;border-bottom:1px solid var(--border-color);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.option-row{display:grid;grid-template-columns:250px 30px 1fr;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem 0}.option-row label{font-weight:400;color:var(--text-primary);transition:color .3s ease}.option-row input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent-teal)}.option-row input[type=number]{grid-column:2 / 4}.length-input{padding:.5rem;border:1px solid var(--border-color);border-radius:3px;font-size:1rem;width:100px;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.length-input:focus{outline:none;border-color:var(--accent-teal)}.option-example{color:var(--text-dimmed);font-size:.85rem;font-style:normal;font-family:Roboto,monospace;transition:color .3s ease}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.generate-btn{background:var(--accent-blue);color:var(--bg-primary);border:none;padding:.875rem 2rem;border-radius:3px;cursor:pointer;font-weight:500;font-size:1rem;transition:background-color .2s ease}.generate-btn:hover{background:var(--accent-blue-hover)}.generate-btn:disabled{background:var(--bg-surface-alt);color:var(--text-disabled);cursor:not-allowed}.advanced-btn{background:var(--bg-surface-alt);color:var(--text-secondary);border:1px solid var(--border-color);padding:.875rem 2rem;border-radius:3px;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s}.advanced-btn:hover{background:var(--bg-hover);border-color:var(--accent-teal)}.hash-algorithm-section,.hash-input-section,.hash-file-section,.hash-output-section{background:var(--bg-primary);padding:1.5rem;border-radius:4px;margin-bottom:1.5rem;border:1px solid var(--border-color)}.algorithm-buttons{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.algorithm-btn{padding:.75rem 1.5rem;background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:3px;cursor:pointer;font-weight:500;transition:all .2s;font-size:.9rem;color:var(--text-secondary)}.algorithm-btn:hover{border-color:var(--accent-teal);background:var(--bg-hover)}.algorithm-btn.active{background:var(--accent-blue);color:var(--bg-primary);border-color:var(--accent-blue)}.hash-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:3px;font-size:1rem;font-family:Roboto,monospace;resize:vertical;margin-bottom:1rem;background:var(--bg-primary);color:var(--text-primary)}.hash-textarea:focus{outline:none;border-color:var(--accent-teal)}.file-upload-container{margin-top:1rem}.file-upload-label{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:var(--bg-surface-alt);border:1px dashed var(--accent-teal);border-radius:3px;cursor:pointer;transition:all .2s;font-weight:500;color:var(--accent-teal)}.file-upload-label:hover{background:var(--bg-hover);border-color:var(--accent-teal-hover)}.file-upload-icon{font-size:1.5rem}.file-upload-input{display:none}.file-name-display{margin-top:1rem;padding:.75rem;background:var(--bg-surface-alt);border-radius:3px;border:1px solid var(--border-color);color:var(--text-secondary);font-family:Roboto,monospace}.hash-display{background:var(--bg-surface-alt);padding:1rem;border-radius:3px;border:1px solid var(--border-color)}.hash-algorithm-label{display:inline-block;background:var(--accent-blue);color:var(--bg-primary);padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:600;margin-bottom:.5rem}.hash-output{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:3px;font-size:.9rem;font-family:Roboto,monospace;background:var(--bg-primary);color:var(--accent-orange);resize:vertical;word-break:break-all}.hash-actions{display:flex;gap:.5rem;margin-top:1rem}.clear-btn{background:var(--bg-surface-alt);color:var(--text-secondary);border:1px solid var(--border-color);padding:.75rem 2rem;border-radius:3px;cursor:pointer;font-weight:500;transition:all .2s}.clear-btn:hover{background:var(--bg-hover);border-color:var(--text-dimmed)}.hash-info{margin-top:1rem;padding:.75rem;background:var(--bg-surface-alt);border-radius:3px;border-left:3px solid var(--accent-teal)}.hash-info p{margin:.25rem 0;color:var(--text-muted)}.info-section ul{list-style:none;padding-left:0}.info-section li{padding:.5rem 0;border-bottom:1px solid var(--border-color);color:var(--text-muted)}.info-section li:last-child{border-bottom:none}.info-section h4{color:var(--text-primary);margin-top:1.5rem;margin-bottom:.75rem;font-weight:500}.advanced-options{background:var(--bg-primary);padding:1.5rem;border-radius:4px;margin-top:2rem;border:1px solid var(--border-color);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.advanced-title{color:var(--text-primary);margin:0 0 .5rem;font-size:1.3rem;font-weight:500}.advanced-description{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.advanced-section{background:var(--bg-surface);padding:1.25rem;border-radius:4px;margin-bottom:1rem;border:1px solid var(--border-color)}.advanced-section:last-child{margin-bottom:0}.advanced-section h4{color:var(--text-secondary);font-size:1rem;margin:0 0 1rem;font-weight:500;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.custom-charset-input{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:3px;font-size:.95rem;font-family:Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary)}.custom-charset-input:focus{outline:none;border-color:var(--accent-teal)}.info-section{margin-top:2rem;color:var(--text-muted);line-height:1.7}.info-section h3{color:var(--text-primary);margin-top:1.5rem;margin-bottom:.75rem;font-size:1.3rem;font-weight:500}.info-section p{margin-bottom:1rem;font-size:.95rem}.info-section strong{color:var(--text-secondary)}@media(max-width:768px){.app{width:100vw}.header{padding:1rem;flex-direction:column;align-items:flex-start;gap:1rem}.header-content{width:100%}.header-controls{width:100%;justify-content:flex-end;align-items:flex-end;gap:.5rem}.header h1{font-size:1.5rem}.logo{font-size:2rem}.nav{flex-wrap:wrap}.nav-btn{padding:.75rem 1rem;font-size:.85rem}.generator-card{padding:1rem}.option-row{grid-template-columns:1fr 30px;gap:.5rem}.option-example{grid-column:1 / 3;margin-top:-.5rem}.button-group,.password-input-group{flex-direction:column}.advanced-options,.advanced-section{padding:1rem}.custom-charset-input{font-size:.85rem}.algorithm-buttons{gap:.25rem}.algorithm-btn{padding:.5rem 1rem;font-size:.85rem}.file-upload-label{padding:.75rem 1.5rem;font-size:.9rem}.hash-actions{flex-direction:column}.hash-actions button{width:100%}}.ad-bottom-collapsible{position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:2px solid var(--border-color);box-shadow:0 -4px 12px var(--shadow);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;max-height:150px}.ad-bottom-collapsible.collapsed{transform:translateY(calc(100% - 40px))}.ad-collapse-btn{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);background:var(--bg-surface);border:2px solid var(--border-color);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:var(--text-primary);box-shadow:0 2px 8px var(--shadow);transition:all .2s ease;z-index:1001}.ad-collapse-btn:hover{background:var(--bg-hover);transform:translate(-50%,-50%) scale(1.1);border-color:var(--accent-teal)}.ad-collapse-btn:active{transform:translate(-50%,-50%) scale(.95)}.collapse-icon{display:block;line-height:1;transition:transform .3s ease}.ad-bottom-content{padding:1.5rem 1rem 1rem;max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center}.app:has(.ad-bottom-collapsible:not(.collapsed)){padding-bottom:140px}@media(max-width:1024px){.ad-bottom-collapsible{max-height:110px}.ad-bottom-content{padding:1rem .5rem .5rem}.app:has(.ad-bottom-collapsible:not(.collapsed)){padding-bottom:100px}.ad-collapse-btn{width:36px;height:36px;font-size:1rem}}@media(max-width:768px){.ad-bottom-collapsible{max-height:90px}.ad-bottom-content{padding:.75rem .25rem .25rem}.app:has(.ad-bottom-collapsible:not(.collapsed)){padding-bottom:80px}.ad-collapse-btn{width:32px;height:32px;font-size:.9rem}}@media(max-width:480px){.ad-bottom-collapsible{max-height:80px}.ad-bottom-content{padding:.5rem .25rem .25rem}.app:has(.ad-bottom-collapsible:not(.collapsed)){padding-bottom:70px}}.simple-footer{background:var(--bg-surface);border-top:1px solid var(--border-color);margin-top:3rem;padding:1.5rem 2rem;text-align:center}.footer-links{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.footer-link{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s ease}.footer-link:hover{color:var(--accent-teal);text-decoration:underline}.footer-separator{color:var(--text-muted);font-size:.8rem}.footer-gdpr{color:var(--accent-teal);font-size:.9rem;font-weight:500}.footer-copyright{color:var(--text-muted);font-size:.8rem;margin-top:.5rem}.privacy-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-primary);border-radius:8px;border-left:4px solid var(--accent-teal)}.privacy-section h3{color:var(--text-primary);font-size:1.2rem;margin-bottom:1rem;font-weight:600}.privacy-section p{color:var(--text-secondary);line-height:1.7;font-size:.95rem}.privacy-list{list-style:none;padding:0;margin:0}.privacy-list li{color:var(--text-secondary);line-height:1.8;padding:.5rem 0 .5rem 1.5rem;position:relative;font-size:.95rem}.privacy-list li:before{content:"✓";color:var(--accent-teal);font-weight:700;position:absolute;left:0}.privacy-disclaimer{background:var(--bg-surface-alt);padding:1.5rem;border-radius:8px;margin:2rem 0;border:1px solid var(--border-color)}.privacy-disclaimer p{color:var(--text-muted);font-size:.9rem;line-height:1.6;margin:0;text-align:center}@media(max-width:768px){.simple-footer{padding:1.25rem 1rem}.footer-links{gap:.5rem}.footer-link,.footer-gdpr{font-size:.85rem}.footer-copyright{font-size:.75rem}.privacy-section{padding:1rem}.privacy-section h3{font-size:1.1rem}.privacy-section p,.privacy-list li{font-size:.9rem}}.language-switcher{display:flex;align-items:center;gap:.5rem;height:35px}.language-select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:3px;background-color:var(--bg-surface-alt);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s ease;outline:none;font-family:Roboto,sans-serif;-webkit-appearance:none;-moz-appearance:none;appearance:none}.language-select:hover{border-color:var(--accent-teal);background-color:var(--bg-hover)}.language-select:focus{border-color:var(--accent-teal);background-color:var(--bg-hover)}.language-select option{padding:.5rem;background-color:var(--bg-surface);color:var(--text-primary);font-family:Roboto,sans-serif}@media(max-width:768px){.language-select{padding:.4rem .8rem;font-size:.85rem}}.theme-switcher{background:var(--bg-surface-alt);border:1px solid var(--border-color);border-radius:3px;padding:.5rem .75rem;cursor:pointer;font-size:1.2rem;transition:all .2s;display:flex;align-items:center;justify-content:center;width:40px;height:35px}.theme-switcher:hover{background:var(--bg-hover);border-color:var(--accent-teal);transform:scale(1.05)}.theme-switcher:active{transform:scale(.95)}@media(max-width:768px){.theme-switcher{padding:.4rem .6rem;font-size:1rem;min-width:36px;height:36px}}.language-tabs{display:flex;gap:.5rem;margin:2rem 0 1rem;flex-wrap:wrap;border-bottom:2px solid var(--border-color)}.language-tab{padding:.75rem 1.5rem;background:var(--bg-surface-alt);border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease;border-radius:4px 4px 0 0}.language-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.language-tab.active{background:var(--bg-primary);color:var(--accent-teal);border-bottom-color:var(--accent-teal)}.tab-content{background:var(--bg-primary);padding:2rem;border-radius:0 4px 4px;border:1px solid var(--border-color);margin-bottom:2rem}.language-section{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.code-snippet{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:1rem;overflow-x:auto;margin:1rem 0;font-family:Roboto,monospace;font-size:.9rem;line-height:1.5}.code-snippet code{color:var(--text-primary);white-space:pre;display:block}.java-code{background:linear-gradient(135deg,#1a1410,#1e1e1e);border-left:4px solid #f89820}.java-code code{color:#e8d4b0}.csharp-code{background:linear-gradient(135deg,#130f1e,#1e1e1e);border-left:4px solid #9b4f96}.csharp-code code{color:#d4bfdc}.cpp-code{background:linear-gradient(135deg,#0f1419,#1e1e1e);border-left:4px solid #00599c}.cpp-code code{color:#b8cfe0}.python-code{background:linear-gradient(135deg,#0e1a1f,#1e1e1e);border-left:4px solid #4b8bbe}.python-code code{color:#d4e8f0}.javascript-code{background:linear-gradient(135deg,#1a1810,#1e1e1e);border-left:4px solid #f7df1e}.javascript-code code{color:#f0e8d0}.php-code{background:linear-gradient(135deg,#12101a,#1e1e1e);border-left:4px solid #777bb3}.php-code code{color:#d4d0e8}@media(max-width:768px){.language-tabs{gap:.25rem}.language-tab{padding:.5rem 1rem;font-size:.85rem;flex:1 1 auto;min-width:100px}.tab-content{padding:1rem}}@media(max-width:480px){.language-tab{padding:.5rem .75rem;font-size:.8rem;min-width:80px}}
