*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f5f5;color:#333}#root{min-height:100vh;display:flex;flex-direction:column}a{font-weight:500;color:#007bff;text-decoration:inherit}a:hover{color:#0056b3;text-decoration:underline}h1{font-size:2.5rem;line-height:1.1;color:#333}h2{font-size:2rem;line-height:1.2;color:#333}h3{font-size:1.5rem;line-height:1.3;color:#333}button{border-radius:4px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#007bff;color:#fff;cursor:pointer;transition:background-color .25s,border-color .25s}button:hover{background-color:#0056b3}button:focus,button:focus-visible{outline:2px solid #0056b3;outline-offset:2px}button:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:1em;padding:.5em;border:1px solid #ddd;border-radius:4px;background-color:#fff;color:#333}input:focus,textarea:focus,select:focus{outline:2px solid #007bff;outline-offset:0;border-color:#007bff}.notifications-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;max-width:400px;pointer-events:none}.notification{display:flex;align-items:flex-start;justify-content:space-between;padding:.875rem 1rem;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;pointer-events:auto;min-width:280px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.notification-icon{font-size:1.1rem;font-weight:700;flex-shrink:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%}.notification-message{font-size:.9rem;line-height:1.4;word-break:break-word;white-space:pre-line}.notification-close{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:0;margin-left:.5rem;opacity:.7;transition:opacity .2s;line-height:1}.notification-close:hover{opacity:1}.notification-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.notification-success .notification-icon{background-color:#28a745;color:#fff}.notification-success .notification-close{color:#155724}.notification-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.notification-error .notification-icon{background-color:#dc3545;color:#fff}.notification-error .notification-close{color:#721c24}.notification-warning{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.notification-warning .notification-icon{background-color:#ffc107;color:#333}.notification-warning .notification-close{color:#856404}.notification-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.notification-info .notification-icon{background-color:#17a2b8;color:#fff}.notification-info .notification-close{color:#0c5460}.confirm-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:10001;padding:1rem}.confirm-dialog{background:#fff;border-radius:8px;max-width:450px;width:100%;box-shadow:0 4px 20px #0000004d;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-header{padding:1.25rem 1.5rem;border-bottom:1px solid #e0e0e0}.confirm-header h3{margin:0;font-size:1.25rem;color:#333}.confirm-body{padding:1.5rem}.confirm-body p{margin:0;color:#555;line-height:1.5;white-space:pre-line}.confirm-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background-color:#f9f9f9;border-radius:0 0 8px 8px}.btn-confirm-cancel{padding:.6rem 1.25rem;border:1px solid #ddd;background-color:#fff;color:#333;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-confirm-cancel:hover{background-color:#f0f0f0;border-color:#ccc}.btn-confirm-ok{padding:.6rem 1.25rem;border:none;background-color:#333;color:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-confirm-ok:hover{background-color:#555}@media(max-width:480px){.notifications-container{left:1rem;right:1rem;max-width:none}.notification{min-width:auto}.confirm-dialog{margin:0 1rem}.confirm-actions{flex-direction:column-reverse}.confirm-actions button{width:100%}}.auth-container{display:flex;justify-content:center;align-items:flex-start;min-height:100vh;background-color:#fff;padding:0;box-sizing:border-box}.auth-card{background:#fff;padding:1.5rem;border-radius:0;box-shadow:none;width:100%;max-width:100%;min-height:100vh;margin-top:0}.auth-card h2{margin:0 0 .5rem;color:#333;text-align:center;font-size:1.75rem;font-weight:300}.auth-card h3{margin:0 0 1.5rem;color:#666;text-align:center;font-size:1.1rem;font-weight:400}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group input,.form-group select,.form-group textarea{padding:.875rem;border:1px solid #ddd;border-radius:4px;font-size:16px;transition:border-color .2s ease;background:#fff;-webkit-appearance:none;appearance:none}.form-group textarea{min-height:100px;resize:vertical}.form-group small{color:#666;font-size:.8rem;line-height:1.3}.alert{padding:.75rem 1rem;border-radius:5px;font-size:.9rem;word-break:break-word}.btn{padding:.875rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent}.btn:hover:not(:disabled){opacity:.9}.btn:active:not(:disabled){opacity:.8}.btn-block{width:100%}.auth-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #eee;text-align:center;color:#666;font-size:.9rem}.auth-footer a{color:#007bff;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-links{text-align:center;margin-top:.5rem}.auth-links a{color:#007bff;text-decoration:none;font-size:.9rem}.auth-links a:hover{text-decoration:underline}.form-row{display:flex;flex-direction:column;gap:1.25rem}.checkbox-group{display:flex;align-items:center;gap:.5rem}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}@media(min-width:768px){.auth-container{align-items:center;padding:40px 20px;background-color:#f5f5f5}.auth-card{margin-top:0;padding:3rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:450px;min-height:0}.auth-card h2{font-size:2rem}.form-row{flex-direction:row;gap:1rem}.form-row .form-group{flex:1}}.verify-email-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:20px}.verify-email-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:3rem;max-width:500px;width:100%;text-align:center}.verify-email-card h1{margin:0 0 .5rem;color:#333;font-size:2rem;font-weight:300}.verify-status{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:2rem}.spinner{border:4px solid #eee;border-top:4px solid #333;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-icon{width:80px;height:80px;border-radius:50%;background-color:#28a745;color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;animation:scaleIn .4s ease-out}.error-icon{width:80px;height:80px;border-radius:50%;background-color:#dc3545;color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;animation:scaleIn .4s ease-out}.verify-status.success h2{color:#28a745;margin:0;font-size:1.5rem;font-weight:500}.verify-status.error h2{color:#dc3545;margin:0;font-size:1.5rem;font-weight:500}.verify-status p{color:#666;font-size:1rem;margin:0;line-height:1.5}.user-details{background-color:#f8f9fa;border-radius:6px;padding:1.5rem;margin:1.5rem 0;text-align:left;border-left:4px solid #28a745}.user-details p{margin:.5rem 0;color:#333;font-size:.95rem}.user-details strong{color:#333;font-weight:600}.redirect-message{font-size:.9rem;color:#999;margin:1rem 0}.error-message{color:#dc3545;font-weight:500;margin:0;padding:1rem;background-color:#fee;border-radius:6px;border:1px solid #fcc}.error-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}@media(max-width:480px){.verify-email-card{padding:1.5rem}.verify-email-card h1{font-size:1.5rem}.error-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.success-icon,.error-icon{width:60px;height:60px;font-size:30px}}.email-icon{color:#333;margin-bottom:1.5rem}.verify-message{color:#666;font-size:1rem;margin:.5rem 0}.verify-email-address{color:#333;font-size:1.1rem;margin:.5rem 0 1.5rem}.verify-instructions{background-color:#f8f9fa;border-radius:6px;padding:1.5rem;margin:1.5rem 0;text-align:left}.verify-instructions p{color:#555;margin:0 0 .5rem;line-height:1.5}.verify-note{font-size:.9rem;color:#888!important;font-style:italic}.verify-tips{text-align:left;margin:1.5rem 0}.verify-tips h3{color:#333;font-size:1rem;margin:0 0 .75rem}.verify-tips ul{margin:0;padding-left:1.25rem}.verify-tips li{color:#666;font-size:.9rem;margin:.5rem 0;line-height:1.4}.verify-actions{margin-top:2rem}.verify-actions .btn{display:inline-block;padding:.75rem 1.5rem;border-radius:4px;text-decoration:none;font-weight:500;transition:all .2s ease}.registration-success-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:#f5f5f5;padding:20px}.registration-success-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:3rem;max-width:600px;width:100%;text-align:center}.success-animation{margin-bottom:1.5rem}.checkmark-circle{width:100px;height:100px;border-radius:50%;background-color:#28a745;margin:0 auto;display:flex;align-items:center;justify-content:center;animation:scaleIn .4s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.checkmark{width:50px;height:50px;border:5px solid white;border-top:none;border-right:none;transform:rotate(-45deg);margin-top:-8px;animation:drawCheck .4s ease-out .2s forwards;opacity:0}@keyframes drawCheck{to{opacity:1}}.registration-success-card h1{font-size:2rem;color:#333;margin:0 0 .5rem;font-weight:300}.success-message{font-size:1rem;color:#666;margin-bottom:1.5rem}.user-info-card{background:#f8f9fa;border-radius:6px;padding:1.5rem;margin:1.5rem 0;text-align:left;border-left:4px solid #28a745}.user-info-card h2{font-size:1.1rem;color:#333;margin:0 0 1rem;font-weight:500}.info-grid{display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:4px}.info-label{font-weight:500;color:#666;font-size:.9rem}.info-value{color:#333;font-size:.95rem;font-weight:500}.welcome-section{margin:2rem 0;text-align:left}.welcome-section h3{font-size:1.2rem;color:#333;margin-bottom:1.5rem;text-align:center;font-weight:500}.next-steps{display:flex;flex-direction:column;gap:1rem}.step{display:flex;gap:1rem;align-items:flex-start;padding:1rem;background:#f8f9fa;border-radius:6px;transition:background-color .2s ease}.step:hover{background:#f0f0f0}.step-number{width:32px;height:32px;background:#333;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.step-content h4{margin:0 0 .25rem;color:#333;font-size:.95rem;font-weight:500}.step-content p{margin:0;color:#666;font-size:.85rem;line-height:1.4}.redirect-info{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #eee}.redirect-info p{font-size:.9rem;color:#666;margin-bottom:1rem}.redirect-info strong{color:#333;font-size:1rem}.btn-login{background-color:#333;color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:500;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.btn-login:hover{background-color:#555}.btn-login:active{background-color:#222}@media(max-width:480px){.registration-success-container{padding:1rem}.registration-success-card{padding:1.5rem}.registration-success-card h1{font-size:1.5rem}.checkmark-circle{width:80px;height:80px}.checkmark{width:40px;height:40px;border-width:4px}.info-item{flex-direction:column;gap:.25rem;align-items:flex-start}.step{flex-direction:column;gap:.75rem}.step-number{width:28px;height:28px;font-size:.8rem}}.dashboard{width:100%;max-width:100%;margin:0 auto;padding:2rem;background-color:#f5f5f5;min-height:calc(100vh - 120px);box-sizing:border-box}@media(min-width:1600px){.dashboard{max-width:1400px}}@media(max-width:768px){.dashboard{padding:1rem}}@media(max-width:480px){.dashboard{padding:.75rem}}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2.5rem;font-weight:300;margin:0;color:#333}@media(max-width:768px){.dashboard-header h1{font-size:1.8rem}}.portal-name{color:#ff9800;font-size:1.2rem;margin:.5rem 0 0}@media(max-width:768px){.portal-name{font-size:1rem}}.welcome-section{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.profile-header{display:flex;align-items:flex-start;gap:2rem;padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:2px solid #f0f0f0}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #667eea4d;margin-top:.25rem}.profile-info{flex:1;display:grid;gap:.5rem}.profile-info h2{margin:0;color:#333;font-size:1.5rem;font-weight:600;line-height:1.2}.profile-detail{margin:0;color:#666;font-size:.95rem;display:flex;align-items:baseline;line-height:1.5}.profile-detail strong{color:#333;min-width:90px;font-weight:600}.welcome-text{margin-top:1rem}.welcome-text p{color:#666;line-height:1.6;margin:0}@media(max-width:768px){.profile-header{flex-direction:column;text-align:center;gap:1rem}.profile-avatar{width:60px;height:60px;font-size:1.5rem}.profile-info h2{font-size:1.2rem}}.get-started-section{margin-bottom:2rem}.get-started-section>h1{font-size:2rem;margin-bottom:2rem;color:#333}@media(max-width:768px){.get-started-section>h1{font-size:1.5rem}}.steps-container{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}@media(max-width:768px){.steps-container{gap:1rem}}.step-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.step-card.full-width{grid-column:1 / -1}@media(max-width:768px){.step-card{padding:1.5rem}}.step-card h2{margin-top:0;color:#333;font-size:1.5rem;margin-bottom:1.5rem}@media(max-width:768px){.step-card h2{font-size:1.3rem}}.install-options{display:flex;justify-content:space-around;align-items:flex-start;gap:1rem;flex-wrap:wrap}@media(max-width:768px){.install-options{flex-direction:column;align-items:center;gap:2rem}}.install-item{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;min-width:150px}@media(max-width:768px){.install-item{width:100%;max-width:300px}}.icon{width:100px;height:100px;margin-bottom:1rem;display:block;object-fit:contain;border-radius:8px}.install-item p{margin:.5rem 0;font-weight:500;color:#333}.links a{color:#007bff;text-decoration:none}.links a:hover{text-decoration:underline}.qr-section{display:flex;flex-direction:column;align-items:center}.qr-code{width:150px;height:150px;border:2px solid #ddd;border-radius:8px;padding:10px;background:#fff;max-width:100%;height:auto;aspect-ratio:1}@media(max-width:480px){.qr-code{width:120px;height:120px}}.qr-login-section{display:flex;justify-content:center;align-items:center;margin:2rem 0}.qr-code-container{position:relative;display:inline-block}.qr-code-large{display:block;border:3px solid #ddd;border-radius:8px;padding:15px;background:#fff;width:100%;max-width:330px}.qr-code-large svg{display:block;width:100%;height:auto}@media(max-width:768px){.qr-code-large{max-width:280px;padding:12px}}@media(max-width:480px){.qr-code-large{max-width:230px;padding:10px}}.tak-logo-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:10px;box-shadow:0 2px 8px #0003}@media(max-width:768px){.tak-logo-overlay{width:60px;height:60px;padding:8px}}@media(max-width:480px){.tak-logo-overlay{width:50px;height:50px;padding:6px}}.tak-logo-overlay img{width:100%;height:100%;object-fit:contain}.cant-scan{text-align:center;margin-top:1rem;padding:0 1rem}.cant-scan p{margin:0;font-size:.95rem;color:#666;word-wrap:break-word}.cant-scan a{color:#007bff;text-decoration:none;font-weight:500}.cant-scan a:hover{text-decoration:underline}@media(max-width:480px){.cant-scan p{font-size:.9rem}}.packages-table{width:100%;border-collapse:collapse;margin:1rem 0;display:table}@media(max-width:768px){.packages-table{width:100%;margin-left:0;margin-right:0;display:table}}.packages-table th,.packages-table td{padding:1rem;text-align:left;border-bottom:1px solid #e0e0e0}.packages-table th:first-child,.packages-table td:first-child{width:30%}.packages-table th:nth-child(2),.packages-table td:nth-child(2){width:50%}.packages-table th:last-child,.packages-table td:last-child{text-align:right;width:20%}@media(max-width:768px){.packages-table th,.packages-table td{padding:.75rem .5rem;font-size:.9rem;text-align:center}}@media(max-width:480px){.packages-table th,.packages-table td{padding:.5rem .3rem;font-size:.85rem}}.packages-table th{background:#f8f9fa;font-weight:600;color:#333}.download-btn{background:#ff9800;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}@media(max-width:768px){.download-btn{padding:.5rem 1rem;font-size:.9rem}}@media(max-width:480px){.download-btn{padding:.4rem .8rem;font-size:.85rem}}.download-btn:hover{background:#f57c00}.help-section{margin-top:1.5rem;text-align:center}.help-btn{background:#ffc107;color:#333;border:none;padding:.75rem 1.5rem;border-radius:4px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:background .2s}.help-btn:hover{background:#ffb300}.user-info-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}@media(max-width:768px){.user-info-section{padding:1.5rem}}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}@media(max-width:768px){.info-grid{grid-template-columns:1fr;gap:1.5rem}}.info-card{margin-bottom:1.5rem}@media(max-width:768px){.info-card{margin-bottom:1rem}}.info-card h3{margin:0 0 1rem;color:#333;font-size:1.1rem}@media(max-width:768px){.info-card h3{font-size:1rem}}.roles-list,.radios-list{display:flex;flex-wrap:wrap;gap:.5rem}.role-badge{background:#333;color:#fff!important;padding:.4rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;text-decoration:none!important}.radio-badge{background:#f0f0f0;color:#333;padding:.4rem 1rem;border-radius:4px;font-size:.9rem;border:1px solid #ddd}.no-items{color:#999;font-style:italic;font-size:.9rem}.action-buttons{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}@media(max-width:768px){.action-buttons{flex-direction:column;gap:.75rem}}.action-btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}@media(max-width:768px){.action-btn{width:100%;padding:.875rem 1rem}}.edit-profile{background:#ff9800;color:#fff}.edit-profile:hover{background:#f57c00}.change-password{background:#ff9800;color:#fff}.change-password:hover{background:#f57c00}.meshtastic-section{margin-top:3rem}@media(max-width:768px){.meshtastic-section{margin-top:2rem}}.meshtastic-section>h1{font-size:2rem;margin-bottom:2rem;color:#333}@media(max-width:768px){.meshtastic-section>h1{font-size:1.5rem;margin-bottom:1.5rem}}.meshtastic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}@media(max-width:768px){.meshtastic-grid{grid-template-columns:1fr;gap:1rem}}@media(max-width:480px){.meshtastic-grid{grid-template-columns:1fr}}.config-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}@media(max-width:768px){.config-card{padding:1.5rem}}.config-card h3{margin-top:0;color:#333}@media(max-width:768px){.config-card h3{font-size:1.1rem}}.config-card p{color:#666;line-height:1.6}@media(max-width:768px){.config-card p{font-size:.9rem}}.config-link{display:inline-block;margin-top:1rem;color:#007bff;text-decoration:none;font-weight:500}.config-link:hover{text-decoration:underline}.qr-codes-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:3rem;margin:1rem 0}@media(max-width:768px){.qr-codes-grid{flex-direction:column;align-items:center;gap:2rem}}.qr-code-section{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:280px}@media(max-width:480px){.qr-code-section{min-width:auto;width:100%}}.qr-label{font-size:1.2rem;font-weight:600;color:#333;margin-bottom:1rem;padding:.5rem 1rem;background:#f8f9fa;border-radius:8px;border:2px solid #e0e0e0}@media(max-width:768px){.qr-label{font-size:1.1rem}}.qr-info{margin-top:1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.qr-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.refresh-btn{padding:.5rem 1rem;border:none;border-radius:4px;font-weight:500;cursor:pointer;color:#fff;transition:opacity .2s}.refresh-btn:hover:not(:disabled){opacity:.9}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.copy-btn{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;font-weight:500;cursor:pointer;background:#fff;color:#333;transition:background .2s}.copy-btn:hover{background:#f5f5f5}.expiry-info{font-size:.9rem;color:#666;margin:0}.expiry-info strong{color:#333}.qr-loading{display:flex;align-items:center;justify-content:center;min-height:250px;color:#666;font-size:.95rem}.qr-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:1.5rem;background:#fff3f3;border:1px solid #ffcdd2;border-radius:8px;text-align:center}.qr-error p{margin:0 0 .5rem;color:#c62828;font-weight:500}.qr-error small{color:#666;font-size:.85rem;margin-bottom:.5rem}@media(max-width:480px){.welcome-section{padding:1rem}.welcome-section h2{font-size:1.2rem}.welcome-section p{font-size:.9rem}}.edit-profile-container{max-width:600px;margin:2rem auto;padding:2rem}@media(max-width:768px){.edit-profile-container{padding:1rem;margin:1rem auto}}.edit-profile-card{background:#fff;padding:2.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.edit-profile-card{padding:1.5rem}}.edit-profile-card h1{margin:0 0 2rem;color:#333;font-size:2rem;font-weight:300}@media(max-width:768px){.edit-profile-card h1{font-size:1.5rem;margin-bottom:1.5rem}}.edit-profile-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#ff9800}.form-actions{display:flex;gap:1rem;margin-top:1rem}@media(max-width:768px){.form-actions{flex-direction:column-reverse}}.btn-submit,.btn-cancel{flex:1;padding:.875rem 1.5rem;border:none;border-radius:4px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}@media(max-width:768px){.btn-submit,.btn-cancel{width:100%}}.btn-submit{background:#ff9800;color:#fff}.btn-submit:hover:not(:disabled){background:#f57c00}.btn-submit:disabled{background:#ccc;cursor:not-allowed}.btn-cancel{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-cancel:hover:not(:disabled){background:#e0e0e0}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#ffebee;color:#c62828;padding:1rem;border-radius:4px;border-left:4px solid #c62828;margin-bottom:1rem}.success-message{background:#e8f5e9;color:#2e7d32;padding:1rem;border-radius:4px;border-left:4px solid #2e7d32;margin-bottom:1rem}.loading{text-align:center;padding:2rem;color:#666}.change-password-container{max-width:600px;margin:2rem auto;padding:2rem}@media(max-width:768px){.change-password-container{padding:1rem;margin:1rem auto}}.change-password-card{background:#fff;padding:2.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}@media(max-width:768px){.change-password-card{padding:1.5rem}}.change-password-card h1{margin:0 0 2rem;color:#333;font-size:2rem;font-weight:300}@media(max-width:768px){.change-password-card h1{font-size:1.5rem;margin-bottom:1.5rem}}.change-password-form{display:flex;flex-direction:column;gap:1.5rem}.field-hint{color:#666;font-size:.85rem;margin-top:.25rem}.admin-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.admin-dashboard-header{margin-bottom:2rem}.admin-dashboard-header h1{font-size:2rem;font-weight:300;color:#333;margin:0 0 .5rem}.admin-dashboard-header p{color:#666;font-size:1rem}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.admin-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.admin-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.admin-card-icon{width:64px;height:64px;margin-bottom:1rem;font-size:3rem;display:flex;align-items:center;justify-content:center;color:#333}.admin-card-icon svg{width:100%;height:100%}.admin-card h2{margin:0 0 .5rem;font-size:1.25rem;font-weight:500;color:#333}.admin-card p{color:#666;margin:0;font-size:.9rem;line-height:1.5}@media(max-width:768px){.admin-dashboard{padding:1rem}.admin-grid{grid-template-columns:1fr}}.admin-actions{display:flex;gap:1rem;align-items:center}.search-box{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:300px}.search-box:focus{outline:none;border-color:#333}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-decoration:none;display:inline-block}.btn-primary{background-color:#333;color:#fff}.btn-primary:hover:not(:disabled){background-color:#555}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-sm{padding:.5rem 1rem;font-size:.9rem}.btn:disabled{opacity:.6;cursor:not-allowed}.admin-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.admin-table th{padding:1rem;text-align:left;font-weight:600;color:#495057;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.admin-table td{padding:1rem;border-bottom:1px solid #dee2e6;color:#333;text-align:left}.admin-table tbody tr:hover{background-color:#f8f9fa}.admin-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:.5rem}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-top:1px solid #dee2e6}.pagination-info{color:#666;font-size:.9rem}.loading-state,.error-state,.empty-state{padding:3rem;text-align:center;color:#666}.error-state{color:#dc3545}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;display:inline-block;margin-right:.25rem;margin-bottom:.25rem}.badge-primary{background-color:#e3f2fd;color:#1976d2}.badge-success{background-color:#e8f5e9;color:#388e3c}.badge-warning{background-color:#fff3e0;color:#f57c00}.badge-danger{background-color:#ffebee;color:#d32f2f}.badge-secondary{background-color:#f5f5f5;color:#666}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{padding:1.5rem;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.5rem;font-weight:500;color:#333}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px}.modal-close:hover{background-color:#f8f9fa;color:#333}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s ease;background:#fff;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#333}.form-group textarea{min-height:100px;resize:vertical;font-family:inherit}.form-group .help-text{font-size:.85rem;color:#666;margin-top:.25rem}.form-group .error-text{font-size:.85rem;color:#dc3545;margin-top:.25rem}.form-group input[type=checkbox]{width:auto;cursor:pointer;margin:0;flex-shrink:0}.form-group label.checkbox-label{display:flex;align-items:center;justify-content:space-between;font-weight:400;cursor:pointer;margin-bottom:0;padding:.5rem 0}.form-group label.checkbox-label input[type=checkbox]{order:2}.form-group .checkbox-list{display:flex;flex-direction:column;gap:.75rem}.alert{padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem}.alert-error{background-color:#fee;border:1px solid #fcc;color:#c33}.alert-success{background-color:#efe;border:1px solid #cfc;color:#3c3}.alert-info{background-color:#eef;border:1px solid #ccf;color:#33c}.form-group .quill{background:#fff}.form-group .ql-container{min-height:150px;font-size:1rem;font-family:inherit}.form-group .ql-editor{min-height:150px}.form-group .ql-toolbar{border-top-left-radius:4px;border-top-right-radius:4px;background:#f8f9fa}.form-group .ql-container{border-bottom-left-radius:4px;border-bottom-right-radius:4px}@media(max-width:768px){.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-actions{width:100%;flex-direction:column}.search-box{width:100%}.admin-table-container{overflow-x:auto}.admin-table{min-width:800px}.modal{width:95%;max-height:95vh}}.pending-registrations-container{padding:2rem;max-width:1400px;margin:0 auto}.pending-registrations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.pending-registrations-header h1{margin:0;color:#333}.header-actions{display:flex;gap:1rem}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33}.no-data{text-align:center;padding:3rem;background-color:#f5f5f5;border-radius:8px;color:#666}.no-data .hint{font-size:.9rem;color:#999;margin-top:.5rem}.pending-registrations-table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.pending-registrations-table{width:100%;border-collapse:collapse}.pending-registrations-table thead{background-color:#f5f5f5}.pending-registrations-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.pending-registrations-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.pending-registrations-table tbody tr:hover{background-color:#f9f9f9}.pending-registrations-table tbody tr.expired-row{background-color:#fff3f3}.pending-registrations-table tbody tr.expired-row:hover{background-color:#ffe8e8}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;display:inline-block}.status-badge.pending{background-color:#fff3cd;color:#856404}.status-badge.expired{background-color:#f8d7da;color:#721c24}.status-badge.approval-pending{background-color:#cce5ff;color:#004085}.approval-info{margin-top:.25rem}.approval-info small{color:#666;font-size:.75rem}.actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-small{padding:.4rem .8rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover{background-color:#138496}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-warning{background-color:#ffc107;color:#000;padding:.6rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.btn-warning:hover{background-color:#e0a800}.btn-secondary{background-color:#6c757d;color:#fff;padding:.6rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.btn-secondary:hover{background-color:#5a6268}.btn-primary{background-color:#333;color:#fff;padding:.6rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.btn-primary:hover{background-color:#555}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#333;font-size:1.5rem}.close-btn{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;line-height:1}.modal-form{padding:1.5rem;overflow-y:auto;flex:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input,.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s;background-color:#fff;color:#333}.form-group select{cursor:pointer;appearance:auto;-webkit-appearance:menulist;-moz-appearance:menulist}.form-group select option{background-color:#fff;color:#333;padding:.5rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#333}.form-group small{color:#666;font-size:.85rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e0e0e0;background:#fff;flex-shrink:0}.modal-actions button{min-width:120px}@media(max-width:768px){.form-row{grid-template-columns:1fr}.modal-content{max-height:95vh}.modal-header h2{font-size:1.2rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.pending-registrations-stats{margin-top:1.5rem;padding:1rem;background-color:#f5f5f5;border-radius:4px;text-align:center;color:#666}.pending-registrations-stats strong{color:#333;font-weight:600}@media(max-width:1200px){.pending-registrations-table{font-size:.9rem}.pending-registrations-table th,.pending-registrations-table td{padding:.75rem .5rem}}@media(max-width:768px){.pending-registrations-container{padding:1rem}.pending-registrations-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%}.pending-registrations-table-container{overflow-x:scroll}.pending-registrations-table{min-width:900px}}.file-browser{margin-top:1rem;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fff;box-shadow:0 2px 8px #00000014}.file-browser-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.file-browser-breadcrumb{font-size:.875rem;color:#666;font-weight:500}.file-browser-close{background:none;border:none;font-size:1.5rem;line-height:1;color:#999;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px}.file-browser-close:hover{background:#e0e0e0;color:#333}.file-browser-search{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e0e0e0}.file-browser-search svg{flex-shrink:0}.file-browser-search input{flex:1;border:none;outline:none;font-size:.9rem;padding:.25rem 0;background:transparent}.file-browser-search input::placeholder{color:#999}.search-clear{background:none;border:none;font-size:1.25rem;line-height:1;color:#999;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.search-clear:hover{color:#666}.file-browser-content{max-height:300px;overflow-y:auto}.file-browser-table{width:100%;border-collapse:collapse}.file-browser-table thead th{text-align:left;padding:.625rem 1rem;font-size:.8rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;background:#fafafa;border-bottom:1px solid #e0e0e0}.file-browser-table tbody .file-row{cursor:pointer;transition:background .15s}.file-browser-table tbody .file-row:hover{background:#f5f5f5}.file-browser-table tbody .file-row.selectable:hover{background:#e3f2fd}.file-browser-table tbody .file-row.selected{background:#bbdefb}.file-browser-table tbody td{padding:.5rem 1rem;border-bottom:1px solid #f0f0f0}.file-cell{display:flex;align-items:center;gap:.75rem}.file-cell svg{flex-shrink:0}.file-name{font-size:.9rem;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row.selectable .file-name{color:#1976d2}.file-path{font-size:.8rem;color:#888;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-message{text-align:center;padding:2rem!important;color:#999;font-size:.9rem}.file-browser-content::-webkit-scrollbar{width:8px}.file-browser-content::-webkit-scrollbar-track{background:#f5f5f5}.file-browser-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.file-browser-content::-webkit-scrollbar-thumb:hover{background:#bbb}.admin-page{padding:2rem;max-width:1400px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{font-size:2rem;font-weight:300;color:#333;margin:0;line-height:1}.settings-container{display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.settings-section h2{font-size:1.5rem;font-weight:500;color:#333;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e8e8e8}.settings-list{display:flex;flex-direction:column;gap:1.5rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border:1px solid #e8e8e8;border-radius:6px;transition:all .2s ease}.setting-item:hover{background:#f9f9f9;border-color:#ddd}.setting-info{flex:1;margin-right:2rem}.setting-info h4{font-size:1rem;font-weight:500;color:#333;margin:0 0 .5rem}.setting-description{font-size:.875rem;color:#666;margin:0;line-height:1.5}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#4caf50}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.setting-item-paired{flex-direction:column;align-items:stretch;gap:0}.setting-item-paired .setting-header{display:flex;justify-content:space-between;align-items:center;width:100%}.setting-item-paired .setting-info{margin-right:2rem}.setting-value-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.setting-value-description{font-size:.85rem;color:#666;margin:0 0 .5rem}.setting-item-text{flex-direction:column;align-items:stretch;gap:1rem}.setting-text-input{display:flex;flex-direction:column;gap:.75rem}.setting-text-input input[type=text]{width:100%;padding:.75rem 1rem;font-size:.95rem;border:1px solid #ddd;border-radius:4px;transition:border-color .2s ease}.setting-text-input input[type=text]:focus{outline:none;border-color:#333}.setting-text-input input[type=text]:disabled{background-color:#f5f5f5;cursor:not-allowed}.setting-text-actions{display:flex;gap:.5rem}.btn-save-setting,.btn-cancel-setting{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.btn-save-setting{background-color:#333;color:#fff}.btn-save-setting:hover{background-color:#555}.btn-save-setting:disabled{background-color:#999;cursor:not-allowed}.btn-cancel-setting{background-color:#e8e8e8;color:#333}.btn-cancel-setting:hover{background-color:#ddd}.btn-cancel-setting:disabled{opacity:.5;cursor:not-allowed}.setting-item-numeric{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.setting-numeric-input{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.setting-numeric-input input[type=number]{width:100px;padding:.5rem .75rem;font-size:.95rem;border:1px solid #ddd;border-radius:4px;text-align:center;transition:border-color .2s ease}.setting-numeric-input input[type=number]:focus{outline:none;border-color:#333}.setting-numeric-input input[type=number]:disabled{background-color:#f5f5f5;cursor:not-allowed}.setting-numeric-input .setting-text-actions{display:flex;gap:.5rem}.alert{padding:1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}@media(max-width:768px){.admin-page{padding:1rem}.setting-item{flex-direction:column;align-items:flex-start;gap:1rem}.setting-info{margin-right:0}.toggle-switch{align-self:flex-start}}/*!
 * Quill Editor v2.0.2
 * https://quilljs.com
 * Copyright (c) 2017-2024, Slab
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;padding-left:1.5em;position:relative}.ql-editor li>.ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0,decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media(pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.api-keys-info{background:#f8f9fa;padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem;border-left:4px solid #333}.api-keys-info p{margin:.5rem 0;color:#555;font-size:.9rem}.api-keys-info code{background:#e9ecef;padding:.2rem .5rem;border-radius:4px;font-family:monospace;font-size:.85rem}.api-keys-list{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.api-keys-table{width:100%;border-collapse:collapse}.api-keys-table th,.api-keys-table td{padding:1rem;text-align:left;border-bottom:1px solid #e8e8e8}.api-keys-table th{background:#f8f9fa;font-weight:500;color:#333;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.api-keys-table tr:hover{background:#f9f9f9}.api-keys-table tr.inactive{opacity:.6}.key-name{display:flex;flex-direction:column;gap:.25rem}.key-name strong{color:#333}.key-description{font-size:.8rem;color:#666}.key-prefix{font-family:monospace;background:#f0f0f0;padding:.25rem .5rem;border-radius:4px;font-size:.85rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.permission-count{font-size:.85rem;color:#666}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-small{padding:.35rem .75rem;font-size:.8rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;font-weight:500}.btn-edit{background:#e9ecef;color:#333}.btn-edit:hover{background:#dee2e6}.btn-regenerate{background:#fff3cd;color:#856404}.btn-regenerate:hover{background:#ffeeba}.btn-activate{background:#d4edda;color:#155724}.btn-activate:hover{background:#c3e6cb}.btn-deactivate{background:#f8d7da;color:#721c24}.btn-deactivate:hover{background:#f5c6cb}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.empty-state{text-align:center;padding:3rem;color:#666}.empty-state p{margin-bottom:1.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e8e8e8;flex-shrink:0}.modal-header h2{margin:0;font-size:1.25rem;font-weight:500}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:1rem 1.5rem;overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e8e8e8;display:flex;justify-content:flex-end;gap:1rem;flex-shrink:0}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#333}.form-group textarea{resize:vertical}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.75rem;max-height:150px;overflow-y:auto;padding:.5rem;border:1px solid #e8e8e8;border-radius:6px}.permission-checkbox{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem;border-radius:4px;cursor:pointer;transition:background .2s ease}.permission-checkbox:hover{background:#f8f9fa}.permission-checkbox input[type=checkbox]{margin-top:.25rem;width:16px;height:16px;cursor:pointer}.permission-label{display:flex;flex-direction:column;gap:.15rem}.permission-label strong{font-size:.9rem;color:#333}.permission-description{font-size:.75rem;color:#666}.btn-primary{background:#333;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-primary:hover{background:#555}.btn-secondary{background:#e9ecef;color:#333;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-secondary:hover{background:#dee2e6}.new-key-display{text-align:center}.warning-message{background:#fff3cd;color:#856404;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.key-value-container{display:flex;align-items:center;gap:1rem;background:#f8f9fa;padding:1rem;border-radius:6px;margin-bottom:1rem}.key-value{flex:1;font-family:monospace;font-size:.9rem;word-break:break-all;background:#e9ecef;padding:.75rem;border-radius:4px}.btn-copy{background:#333;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap}.btn-copy:hover{background:#555}@media(max-width:1024px){.api-keys-table{display:block;overflow-x:auto}}@media(max-width:768px){.action-buttons{flex-direction:column}.modal{max-width:100%;margin:1rem}.permissions-grid{grid-template-columns:1fr}}.api-docs-page{max-width:1000px}.api-docs-intro{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.api-docs-intro h2{font-size:1.5rem;font-weight:500;margin:0 0 1rem;color:#333}.api-docs-intro h3{font-size:1.1rem;font-weight:500;margin:1.5rem 0 .75rem;color:#333;padding-top:1rem;border-top:1px solid #eee}.api-docs-intro h3:first-of-type{border-top:none;padding-top:0}.api-docs-intro p{color:#555;line-height:1.6;margin:0 0 1rem}.base-url{display:block;background:#f8f9fa;padding:1rem;border-radius:6px;font-family:monospace;font-size:1rem;color:#333;border-left:4px solid #333}.auth-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.auth-method{background:#f8f9fa;padding:1.25rem;border-radius:6px}.auth-method h4{margin:0 0 .5rem;font-size:1rem;font-weight:500;color:#333}.auth-method p{margin:0 0 .75rem;font-size:.9rem;color:#666}.auth-method pre,.api-docs-intro>pre{background:#1e1e1e;color:#d4d4d4;padding:.75rem 1rem;border-radius:4px;font-size:.85rem;overflow-x:auto;margin:0}.api-docs-sections{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.api-docs-sections>h2{padding:1.5rem 2rem;margin:0;font-size:1.5rem;font-weight:500;color:#333;border-bottom:1px solid #eee}.api-section{border-bottom:1px solid #eee}.api-section:last-child{border-bottom:none}.section-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;cursor:pointer;transition:background .2s ease}.section-header:hover{background:#f8f9fa}.section-header h3{margin:0;font-size:1.1rem;font-weight:500;color:#333}.toggle-icon{font-size:1.5rem;color:#666;font-weight:300}.section-content{padding:0 2rem 2rem}.section-description{color:#666;margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.endpoints-list{display:flex;flex-direction:column;gap:1.5rem}.endpoint{background:#f8f9fa;border-radius:6px;padding:1.25rem;border:1px solid #e8e8e8}.endpoint-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.method{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.method-get{background:#d4edda;color:#155724}.method-post{background:#cce5ff;color:#004085}.method-put{background:#fff3cd;color:#856404}.method-delete{background:#f8d7da;color:#721c24}.path{font-family:monospace;font-size:.95rem;color:#333;background:#e9ecef;padding:.25rem .5rem;border-radius:4px}.endpoint-description{color:#555;margin:0 0 .75rem;font-size:.9rem}.endpoint-auth{font-size:.85rem;color:#666;margin-bottom:.75rem}.endpoint-auth strong{color:#333}.endpoint-params,.endpoint-body,.endpoint-response{margin-top:.75rem}.endpoint-params strong,.endpoint-body strong,.endpoint-response strong{display:block;margin-bottom:.5rem;font-size:.85rem;color:#333}.endpoint-params pre,.endpoint-body pre,.endpoint-response pre{background:#1e1e1e;color:#d4d4d4;padding:.75rem 1rem;border-radius:4px;font-size:.8rem;overflow-x:auto;margin:0}@media(max-width:768px){.api-docs-intro,.section-content{padding:1.5rem}.section-header{padding:1rem 1.5rem}.api-docs-sections>h2{padding:1rem 1.5rem}.auth-methods{grid-template-columns:1fr}.endpoint-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.announcement-history-page{max-width:700px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:300;color:#333;margin:0 0 .5rem}.page-header p{color:#666;margin:0}.loading{text-align:center;padding:3rem;color:#666}.empty-state{text-align:center;padding:4rem 2rem;background:#f8f9fa;border-radius:8px;color:#666}.announcements-list{display:flex;flex-direction:column;gap:1rem}.announcement-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.25rem;cursor:pointer;transition:box-shadow .2s,border-color .2s}.announcement-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#ccc}.announcement-card.unread{border-left:4px solid #2196F3;background:#f8fbff}.announcement-card.dismissed{opacity:.7}.announcement-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.announcement-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#333}.announcement-badges{display:flex;gap:.5rem;flex-shrink:0}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge-unread{background:#e3f2fd;color:#1976d2}.badge-dismissed{background:#f5f5f5;color:#666}.announcement-meta{margin-bottom:.75rem}.announcement-meta .date{font-size:.85rem;color:#888}.announcement-preview{color:#555;font-size:.95rem;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;max-width:700px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #eee;background:#f8f9fa}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;line-height:1}.close-btn:hover{color:#333}.modal-body{padding:1.5rem;overflow-y:auto;flex:1;color:#333;line-height:1.6}.modal-body p{margin:0 0 1rem}.modal-body p:last-child{margin-bottom:0}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #eee;background:#f8f9fa}.modal-footer .date{font-size:.85rem;color:#666}@media(max-width:768px){.announcement-history-page{padding:1rem}.announcement-header{flex-direction:column;gap:.5rem}.announcement-badges{align-self:flex-start}}.approvals-container{padding:2rem;max-width:1000px;margin:0 auto}.approvals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.approvals-header h1{margin:0;color:#333}.approver-info{display:flex;align-items:center;gap:.5rem}.approver-badge{background-color:#e7f3ff;color:#06c;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;border-left:4px solid #c33}.not-approver-message{text-align:center;padding:3rem;background-color:#f5f5f5;border-radius:8px}.not-approver-message h2{color:#666;margin-bottom:1rem}.not-approver-message p{color:#888;margin:.5rem 0}.no-approvals{text-align:center;padding:4rem 2rem;background-color:#f8fff8;border-radius:8px;border:2px dashed #28a745}.no-approvals-icon{margin-bottom:1rem}.no-approvals h2{color:#28a745;margin-bottom:.5rem}.no-approvals p{color:#666;margin:0}.approvals-count{margin-bottom:1.5rem;font-size:1.1rem;color:#555}.count-badge{display:inline-block;background-color:#ffc107;color:#000;padding:.25rem .75rem;border-radius:20px;font-weight:600;margin-right:.25rem}.approvals-list{display:flex;flex-direction:column;gap:1.5rem}.approval-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s}.approval-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.approval-card.expired{opacity:.7;background-color:#fff8f8}.approval-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.user-info h3{margin:0;color:#333;font-size:1.2rem}.user-info .username{color:#666;font-size:.9rem}.expiry-badge{padding:.4rem .8rem;border-radius:4px;font-size:.85rem;font-weight:500;background-color:#fff3cd;color:#856404}.expiry-badge.expired{background-color:#f8d7da;color:#721c24}.approval-card-body{padding:1.5rem}.detail-row{display:flex;margin-bottom:.75rem}.detail-row:last-child{margin-bottom:0}.detail-row .label{flex:0 0 140px;color:#666;font-weight:500}.detail-row .value{color:#333}.role-badge{background-color:#e7f3ff;color:#06c;padding:.2rem .6rem;border-radius:4px;font-size:.85rem}.approval-card-actions{display:flex;gap:1rem;padding:1.25rem 1.5rem;background-color:#f8f9fa;border-top:1px solid #e0e0e0}.approval-card-actions .btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.approval-card-actions .btn-success{background-color:#28a745;color:#fff}.approval-card-actions .btn-success:hover:not(:disabled){background-color:#218838}.approval-card-actions .btn-danger{background-color:#dc3545;color:#fff}.approval-card-actions .btn-danger:hover:not(:disabled){background-color:#c82333}.approval-card-actions .btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.approvals-container{padding:1rem}.approvals-header{flex-direction:column;align-items:flex-start}.approval-card-header{flex-direction:column;align-items:flex-start;gap:.75rem}.detail-row{flex-direction:column;gap:.25rem}.detail-row .label{flex:none}.approval-card-actions{flex-direction:column}}.announcements-badge-container{position:relative}.announcements-badge-btn{background:none;border:none;cursor:pointer;position:relative;padding:.5rem;color:#fff;display:flex;align-items:center;justify-content:center}.announcements-badge-btn:hover{opacity:.8}.badge-count{position:absolute;top:0;right:0;background:#dc3545;color:#fff;font-size:.7rem;padding:.1rem .4rem;border-radius:50%;min-width:1rem;text-align:center;line-height:1.2}.announcements-backdrop{position:fixed;inset:0;z-index:999}.announcements-panel{position:absolute;top:100%;right:0;width:320px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:1000;max-height:400px;overflow:hidden;margin-top:.5rem}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #eee;background:#f8f9fa}.panel-header h3{margin:0;font-size:1rem;color:#333}.panel-header button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#666;padding:0;line-height:1}.panel-header button:hover{color:#333}.panel-body{max-height:300px;overflow-y:auto}.announcements-list{list-style:none;margin:0;padding:0}.announcement-item{padding:.75rem 1rem;border-bottom:1px solid #eee;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:.5rem;color:#333}.announcement-item:hover{background:#f8f9fa}.announcement-item.unread{background:#e3f2fd}.announcement-item.unread strong{font-weight:700}.announcement-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.announcement-content strong{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.announcement-item .date{font-size:.75rem;color:#999;white-space:nowrap}.dismiss-btn{background:none;border:none;color:#999;cursor:pointer;padding:.25rem .5rem;font-size:1rem;line-height:1;border-radius:4px;flex-shrink:0}.dismiss-btn:hover{background:#eee;color:#666}.no-announcements{padding:2rem;text-align:center;color:#666;margin:0}.panel-footer{padding:.75rem 1rem;border-top:1px solid #eee;background:#f8f9fa}.view-history-btn{width:100%;padding:.5rem 1rem;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;color:#333;font-size:.85rem;cursor:pointer;transition:background .2s}.view-history-btn:hover{background:#e0e0e0}.announcement-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1001}.announcement-modal{background:#fff;border-radius:8px;max-width:600px;width:90%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.announcement-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #eee;background:#f8f9fa}.announcement-modal .modal-header h2{margin:0;font-size:1.25rem;color:#333}.announcement-modal .modal-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;line-height:1}.announcement-modal .modal-header button:hover{color:#333}.announcement-modal .modal-body{padding:1.5rem;max-height:50vh;overflow-y:auto;color:#333;line-height:1.6}.announcement-modal .modal-body p{margin:0 0 1rem}.announcement-modal .modal-body p:last-child{margin-bottom:0}.announcement-modal .modal-footer{padding:1rem 1.5rem;border-top:1px solid #eee;background:#f8f9fa}.announcement-modal .modal-footer .date{font-size:.85rem;color:#666}@media(max-width:768px){.announcements-panel{width:280px;right:-50px}}.layout{display:flex;flex-direction:column;min-height:100vh}.navbar{background-color:#333;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;right:0;z-index:1000}.navbar-brand a{color:#fff;text-decoration:none;font-size:1.5rem;font-weight:700}.navbar-brand a:hover{text-decoration:none}.hamburger{display:none;flex-direction:column;justify-content:space-around;width:28px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1002}.hamburger span{width:28px;height:3px;background-color:#fff;border-radius:2px;transition:all .3s ease;transform-origin:center}.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)}.navbar-menu{display:flex;gap:1rem;align-items:center}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem}.nav-link:hover{background-color:#555;text-decoration:none}.approvals-link{position:relative}.approvals-badge{background-color:#dc3545;color:#fff;font-size:.7rem;font-weight:600;padding:.15rem .4rem;border-radius:10px;margin-left:.4rem;min-width:18px;text-align:center}.dropdown-arrow{transition:transform .3s ease}.nav-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.nav-dropdown{position:relative;display:inline-block}.dropdown-content{display:none;position:absolute;background-color:#fff;min-width:200px;box-shadow:0 8px 16px #0003;z-index:1001;border-radius:4px;overflow:hidden;top:100%;left:0;padding-top:.5rem;margin-top:0}.dropdown-content:before{content:"";position:absolute;top:0;left:0;right:0;height:.5rem;background:transparent}.dropdown-content>*{position:relative;z-index:1}.dropdown-content a,.dropdown-content button{color:#333;padding:12px 16px;text-decoration:none;display:block;border:none;background:#fff;width:100%;text-align:left;cursor:pointer;transition:background-color .3s;font-size:1rem}.dropdown-content a:first-child{border-radius:4px 4px 0 0}.dropdown-content a:last-child,.dropdown-content button:last-child{border-radius:0 0 4px 4px}.dropdown-content a:hover,.dropdown-content button:hover{background-color:#f1f1f1;text-decoration:none}@media(min-width:769px){.nav-dropdown:hover .dropdown-content{display:block}}.main-content{flex:1;width:100%;background-color:#f5f5f5;margin-top:70px;margin-bottom:60px}.footer{background-color:#333;padding:1rem 2rem;text-align:center;border-top:1px solid #444;position:fixed;bottom:0;left:0;right:0;z-index:999}.footer p{margin:0;color:#ccc}.logout-btn{font-family:inherit;font-size:inherit}@media(max-width:768px){.navbar{padding:1rem}.hamburger{display:flex}.navbar-brand a{font-size:1.2rem}.navbar-menu{position:fixed;inset:60px 0 0;background-color:#333;flex-direction:column;align-items:stretch;padding:1rem;gap:0;transform:translate(100%);transition:transform .3s ease;overflow-y:auto;z-index:1001}.navbar-menu.open{transform:translate(0)}.nav-link{width:100%;padding:1rem;border-bottom:1px solid #444;justify-content:space-between}.nav-dropdown{width:100%}.nav-dropdown>.nav-link{display:flex;justify-content:space-between;align-items:center}.dropdown-content{position:static;display:none;width:100%;margin-top:0;padding-top:0;box-shadow:none;background-color:#444;border-radius:0}.dropdown-content:before{display:none}.dropdown-content a,.dropdown-content button{background-color:#444;color:#fff;padding:1rem 1rem 1rem 2rem;border-bottom:1px solid #555}.dropdown-content a:hover,.dropdown-content button:hover{background-color:#555}.dropdown-content a:first-child,.dropdown-content a:last-child,.dropdown-content button:last-child{border-radius:0}.nav-dropdown.open .dropdown-content{display:block}.main-content{margin-top:60px;margin-bottom:60px}.footer{padding:.75rem 1rem}.footer>div{flex-direction:column;gap:.25rem}.footer>div>span:last-child{display:none}}@media(max-width:480px){.navbar-brand a{font-size:1rem}.footer p{font-size:.75rem}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
