:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{margin:0;font-family:Segoe UI,sans-serif;background-color:#1e1e2f;color:#fff;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.app{display:flex;flex-direction:column;height:100vh}@media (min-width: 768px){.app{flex-direction:row}}.sidebar{width:240px;background-color:#2c2c3c;display:flex;flex-direction:column;padding:1rem;transform:translate(-100%);transition:transform .3s ease;position:fixed;top:0;left:0;height:100%;z-index:1000;overflow-y:auto}.sidebar.open{transform:translate(0)}@media (min-width: 768px){.sidebar{transform:translate(0);position:static;width:240px;height:100vh;overflow-y:auto}}.logo{font-size:24px;font-weight:700;color:#00ab57;text-align:center;padding:20px 0;border-bottom:1px solid #333;margin-bottom:20px}.quara-logo{display:flex;justify-content:center;align-items:center;transition:transform .3s ease}.quara-logo img{max-width:100%;height:auto;transition:filter .3s ease}.quara-logo:hover img{filter:drop-shadow(0 4px 8px rgba(0,171,87,.5)) brightness(1.1)}.sidebar nav{display:flex;flex-direction:column;gap:.5rem}.sidebar nav a{color:#fff;text-decoration:none;padding:.75rem 1rem;border-radius:6px;transition:all .3s ease}.sidebar nav a:hover{background-color:#3c3c4c}.sidebar nav a.active{background-color:#00ab57;color:#fff}.mqtt-menu{margin-bottom:.5rem}.mqtt-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;color:#fff;cursor:pointer;border-radius:6px;transition:all .3s ease}.mqtt-header.expandable:hover{background-color:#3c3c4c}.mqtt-header.disabled{cursor:default;opacity:.6}.mqtt-header.disabled:hover{background-color:transparent}.mqtt-options{margin-left:1rem;margin-top:.25rem;display:flex;flex-direction:column;gap:.25rem}.mqtt-options a{font-size:.9rem;padding:.5rem 1rem;color:#fff;text-decoration:none;border-radius:6px;transition:all .3s ease}.mqtt-options a:hover{background-color:#3c3c4c}.mqtt-options a.active{background-color:#00ab57;color:#fff}.mqtt-disabled-info{margin-left:1rem;margin-top:.25rem;padding:.5rem 1rem}.disabled-text{color:#999;font-size:.8rem;font-style:italic}.disabled-indicator{font-size:.8rem;opacity:.7}.device-menu{margin-bottom:.5rem}.device-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;color:#fff;cursor:pointer;border-radius:6px;transition:all .3s ease}.device-header:hover,.device-header.active{background-color:#3c3c4c}.arrow{font-size:.8rem;transition:transform .3s ease}.arrow.expanded{transform:rotate(180deg)}.device-options{margin-left:1rem;margin-top:.25rem;display:flex;flex-direction:column;gap:.25rem}.device-options a{font-size:.9rem;padding:.5rem 1rem}.logout-link{margin-top:auto;color:#d50000!important}.logout-link:hover{background-color:#d500001a!important}.sidebar-footer{margin-top:auto;display:flex;align-items:center;gap:10px;color:#aaa;padding-top:1rem;background-color:#1e1e2f}.power-icon{margin-left:auto;color:#d50000;cursor:pointer}.health-status{background:#1a1a1a;border-radius:8px;padding:20px;margin:20px 0;border-left:4px solid;box-shadow:0 2px 4px #0003}.health-status.loading{border-color:#ffc107;opacity:.7}.health-status.error{border-color:#d50000}.health-details{flex:1}.health-details h2{margin:0 0 15px;color:#fff;font-size:1.5rem}.attributes{display:flex;gap:15px;margin-bottom:15px}.attributes span{background:#ffffff1a;padding:4px 12px;border-radius:4px;color:#e0e0e0;font-size:.9rem}.status-section{margin-bottom:15px}.status{font-size:1.1rem;font-weight:500;margin:0 0 5px}.response-time{color:#888;font-size:.9rem;margin:0}.details{color:#e0e0e0;font-size:.95rem;line-height:1.4}.details p{margin:5px 0}.error-message{color:#ff6b6b;font-size:.9rem;margin:5px 0}.loading{border-left-color:#666}.error{border-left-color:#d50000}@media (max-width: 768px){.health-status{flex-direction:column;align-items:center;text-align:center}.health-indicator{margin-bottom:10px}}h1{font-size:44px;font-weight:700;color:#fff;text-align:center;margin-bottom:1rem}.dashboard{flex:1;padding:1rem;overflow-y:auto;margin-top:0}.dashboard-header{text-align:center;margin-bottom:1rem}.charts-row{display:flex;flex-direction:column;gap:1rem;align-items:stretch;justify-content:flex-start}@media (min-width: 768px){.charts-row{flex-direction:row;gap:20px;align-items:flex-start}}.charts-card{flex:1;max-width:700px;height:auto;background-color:#1e1e2f;border-radius:10px;padding:20px;box-shadow:0 4px 6px #0000001a;text-align:center}.chart-title{font-size:18px;font-weight:600;margin-bottom:10px;color:#fff}.filter-bar{background-color:#1e1e2f;padding:1rem;border-radius:10px;margin-bottom:1rem;color:#fff;text-align:center;box-shadow:0 4px 6px #0000001a}.filter-bar label{margin-right:10px;font-weight:500}.filter-bar select{background-color:#2e2e3e;color:#fff;padding:.5rem 1rem;border-radius:6px;border:none;outline:none;font-size:1rem}.device-status-card{background:#1a1a1a;border-radius:8px;padding:20px;margin:20px 0;border-left:4px solid;box-shadow:0 2px 4px #0003}.device-status-card h2{margin:0 0 15px;color:#fff;font-size:1.5rem}.export-csv-btn{background-color:#00ab57;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .3s ease;margin-left:1rem}.export-csv-btn:hover{background-color:#008f47}.export-csv-btn:disabled{background-color:#666;cursor:not-allowed}.status-details{display:flex;flex-direction:column;gap:10px}.status-indicator{display:inline-block;padding:6px 12px;border-radius:4px;color:#fff;font-weight:500;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.status-description{color:#e0e0e0;font-size:.95rem;line-height:1.4}.apexcharts-menu{background:#23233a!important;color:#fff!important;border-radius:8px!important;box-shadow:0 2px 8px #0000004d!important}.apexcharts-menu-item{color:#fff!important;background:transparent!important;font-size:1rem!important}.apexcharts-menu-item:hover{background:#335!important;color:#00ab57!important}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:120px}.spinner{border:6px solid #23233a;border-top:6px solid #00ab57;border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader-message{color:#fff;font-size:1.1rem;font-weight:500;text-align:center}.improved-filters-bar{display:flex;gap:2rem;align-items:center;margin-bottom:1.5rem;background:#181828;border-radius:10px;padding:1rem 2rem;box-shadow:0 2px 8px #0000001f}.improved-filter-group{display:flex;align-items:center;gap:.7rem;background:#23233a;padding:.5rem 1.2rem;border-radius:8px;box-shadow:0 1px 4px #0000001a}.improved-filters-bar label{color:#fff;font-weight:500;font-size:1.05rem}.improved-filters-bar select{background:#23233a;color:#fff;border:1px solid #333355;border-radius:4px;padding:.35rem .9rem;font-size:1rem;font-weight:500;transition:border .2s}.improved-filters-bar select:focus{outline:none;border:1.5px solid #00ab57}.custom-range-inputs{display:flex;gap:1rem;align-items:center;margin-top:1rem;padding:1rem;background:#23233a;border-radius:8px;border:1px solid #333355}.custom-range-inputs input[type=datetime-local]{background:#2e2e3e;color:#fff;padding:.5rem 1rem;border-radius:6px;border:1px solid #333355;outline:none;font-size:1rem;transition:border .2s}.custom-range-inputs input[type=datetime-local]:focus{border:1.5px solid #00ab57}.custom-range-inputs input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.custom-range-submit-btn{background:#00ab57;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.custom-range-submit-btn:hover:not(:disabled){background:#00994d}.custom-range-submit-btn:disabled{background:#555;cursor:not-allowed;opacity:.6}.custom-range-reset-btn{background:#dc3545;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.custom-range-reset-btn:hover:not(:disabled){background:#c82333}.custom-range-reset-btn:disabled{background:#555;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.custom-range-inputs{flex-direction:column;gap:.5rem}.custom-range-inputs input[type=datetime-local],.custom-range-submit-btn,.custom-range-reset-btn{width:100%}}.app{display:flex;flex-direction:column;min-height:100vh;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.hamburger-menu{position:fixed;top:0rem;right:0rem;background:none;border:none;font-size:2rem;color:#fff;cursor:pointer;z-index:1000}.dashboard{flex:1;margin-left:0;padding:1rem;transition:margin-left .3s ease}@media (min-width: 768px){.app{flex-direction:row}.hamburger-menu{display:none}}*{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea,[contenteditable=true]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}html,body{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.login-container{flex:1;display:flex;justify-content:center;align-items:center;height:100vh;background-color:#121212;padding:1rem}.login-form{background-color:#1e1e2f;padding:2.5rem;border-radius:12px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;width:100%;max-width:400px;text-align:center;gap:1rem}.logo-container{margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center}.quara-logo{max-width:200px;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:transform .3s ease}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500;font-size:.9rem}.login-form input{width:100%;padding:.75rem;border:none;border-radius:5px;font-size:1rem;background-color:#2c2c3e;color:#fff;box-sizing:border-box;transition:background-color .3s ease}.login-form input:focus{outline:none;background-color:#3c3c4e;box-shadow:0 0 0 2px #00ab574d}.login-form input::placeholder{color:#aaa}.login-form button{width:100%;padding:.75rem;background-color:#00ab57;color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.login-form button:hover{background-color:#00994d}.error-message{background-color:#d50000;color:#fff;padding:.5rem;margin-bottom:1rem;border-radius:5px;font-size:.9rem}@media (max-width: 768px){.quara-logo{max-width:150px}.login-form{padding:2rem;max-width:350px;gap:.75rem}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.85rem}}.home-container{padding:2rem;max-width:1200px;margin:0 auto}.hero-section{text-align:center;margin-bottom:4rem;padding:2rem;background:linear-gradient(135deg,#1e1e2f,#2c2c3c);border-radius:12px;box-shadow:0 4px 6px #0000001a}.logo-container{margin-bottom:1rem;display:flex;justify-content:center;align-items:center}.quara-logo{max-width:300px;height:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:transform .3s ease}.quara-logo:hover{transform:scale(1.05)}.subtitle{font-size:1.2rem;color:#e0e0e0;margin-bottom:1.5rem}.hero-description{max-width:600px;margin:0 auto;color:#b0b0b0;line-height:1.6}.features-section{margin-bottom:4rem}.features-section h2{text-align:center;color:#00ab57;margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.feature-card{background:#2c2c3c;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-card h3{color:#00ab57;margin-bottom:1rem}.feature-card p{color:#b0b0b0;line-height:1.5}.devices-section{margin-bottom:2rem}.devices-section h2{text-align:center;color:#00ab57;margin-bottom:2rem}.devices-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.device-card{background:#2c2c3c;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.device-card h3{color:#00ab57;margin-bottom:1rem}.device-card p{color:#b0b0b0;margin-bottom:1.5rem;line-height:1.5}.device-actions{display:flex;gap:1rem}.action-button{flex:1;padding:.75rem 1rem;border-radius:6px;text-align:center;text-decoration:none;font-weight:500;transition:all .3s ease}.action-button:not(.secondary){background-color:#00ab57;color:#fff}.action-button:not(.secondary):hover{background-color:#00994d}.action-button.secondary{background-color:transparent;border:1px solid #00ab57;color:#00ab57}.action-button.secondary:hover{background-color:#00ab571a}@media (max-width: 768px){.home-container{padding:1rem}.hero-section{padding:1.5rem}.quara-logo{max-width:250px}.features-grid,.devices-grid{grid-template-columns:1fr}.device-actions{flex-direction:column}}.device-management{padding:20px;max-width:1400px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.filters{display:flex;gap:15px;margin-bottom:30px;padding:20px;background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;box-shadow:0 2px 4px #0000004d}.filters select{padding:10px;border:1px solid #3c3c4c;border-radius:4px;font-size:14px;min-width:150px;background-color:#1a1a2e;color:#e0e0e0}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.device-card{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;box-shadow:0 2px 4px #0000004d;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.device-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.device-header h3{margin:0;color:#e0e0e0;font-size:1.2rem}.device-badges{display:flex;flex-direction:column;gap:5px;align-items:flex-end}.status-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.status-active{background-color:#00ab57;color:#fff}.status-inactive{background-color:#6c757d;color:#fff}.status-maintenance{background-color:#ffc107;color:#000}.status-error{background-color:#dc3545;color:#fff}.online-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.online-badge.online{background-color:#00ab57;color:#fff}.online-badge.offline{background-color:#dc3545;color:#fff}.device-info{margin-bottom:15px}.device-info p{margin:5px 0;font-size:14px;color:silver}.device-info strong{color:#e0e0e0}.device-tags{margin-bottom:15px}.tag{display:inline-block;background-color:#1a1a2e;color:#e0e0e0;padding:2px 8px;border-radius:12px;font-size:11px;margin-right:5px;margin-bottom:5px;border:1px solid #3c3c4c}.device-actions{display:flex;gap:8px;flex-wrap:wrap}.modal{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.device-form{padding:20px}@media (max-width: 768px){.header{flex-direction:column;gap:20px;align-items:stretch}.header-actions{justify-content:center}.filters{flex-direction:column}.filters select{min-width:auto}.devices-grid{grid-template-columns:1fr}.device-actions{justify-content:center}.form-actions{flex-direction:column}}@media (max-width: 480px){.device-management{padding:10px}.header h1{font-size:2rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.device-header{flex-direction:column;align-items:flex-start}.device-badges{flex-direction:row;margin-top:10px}}.alert-management{padding:20px;max-width:1400px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.header h1{color:#e0e0e0;margin:0;font-size:2.5rem}.header-actions{display:flex;gap:10px}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:5px}.btn-primary:hover{background-color:#008f47}.btn-secondary:hover{background-color:#545b62}.btn-sm{padding:5px 10px;font-size:12px}.error-message{background-color:#f8d7da;color:#721c24;padding:15px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#721c24;font-size:18px;cursor:pointer}.loading{text-align:center;padding:40px;font-size:18px;color:#666}.smtp-status{padding:15px;border-radius:6px;margin-bottom:20px;font-weight:500}.smtp-status.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.smtp-status.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.test-email-section{background:#2c2c3c;border:1px solid #3c3c4c;padding:20px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000004d}.test-email-section h3{margin:0 0 15px;color:#e0e0e0}.test-email-form{display:flex;gap:10px}.test-email-form input{flex:1;padding:10px;border:1px solid #3c3c4c;border-radius:4px;font-size:14px;background-color:#1a1a2e;color:#e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#2c2c3c;border:1px solid #3c3c4c;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000004d;text-align:center;border-left:4px solid #00ab57}.stat-card h3{margin:0 0 10px;color:#e0e0e0;font-size:14px;text-transform:uppercase;letter-spacing:1px;font-weight:600}.stat-number{font-size:2.5rem;font-weight:700;color:#00ab57;margin:0}.filters{display:flex;gap:15px;margin-bottom:30px;padding:20px;background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;box-shadow:0 2px 4px #0000004d;flex-wrap:wrap}.filters select,.filters input{padding:10px;border:1px solid #3c3c4c;border-radius:4px;font-size:14px;min-width:150px;background-color:#1a1a2e;color:#e0e0e0}.filters input{flex:1;min-width:200px}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.alert-card{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;box-shadow:0 2px 4px #0000004d;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.alert-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.alert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.alert-header h3{margin:0;color:#e0e0e0;font-size:1.2rem}.alert-badges{display:flex;flex-direction:column;gap:5px;align-items:flex-end}.active-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.active-badge.active{background-color:#00ab57;color:#fff}.active-badge.inactive{background-color:#6c757d;color:#fff}.alert-info{margin-bottom:15px}.alert-info p{margin:5px 0;font-size:14px;color:silver}.alert-info strong{color:#e0e0e0}.alert-actions{display:flex;gap:8px;flex-wrap:wrap}.empty-state{text-align:center;padding:40px;color:silver;font-size:16px}.modal{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.alert-form{padding:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#e0e0e0}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #3c3c4c;border-radius:4px;font-size:14px;box-sizing:border-box;background-color:#1a1a2e;color:#e0e0e0}.form-group textarea{height:80px;resize:vertical}.form-group small{display:block;margin-top:5px;color:silver;font-size:12px}.email-input-group{display:flex;gap:10px;margin-bottom:10px}.email-input-group input{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}@media (max-width: 768px){.header{flex-direction:column;gap:20px;align-items:stretch}.header-actions{justify-content:center}.filters{flex-direction:column}.filters select,.filters input{min-width:auto;width:100%}.alerts-grid{grid-template-columns:1fr}.alert-actions{justify-content:center}.form-actions,.test-email-form{flex-direction:column}}@media (max-width: 480px){.alert-management{padding:10px}.header h1{font-size:2rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.alert-header{flex-direction:column;align-items:flex-start}.alert-badges{flex-direction:row;margin-top:10px}}.mqtt-configurations{padding:2rem;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.configurations-list{display:grid;gap:1.5rem}.config-card{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000004d;transition:all .3s ease}.config-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.config-header h3{margin:0;color:#e0e0e0;font-size:1.2rem}.config-actions{display:flex;gap:.5rem}.config-details{display:grid;gap:.75rem}.config-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.config-row .label{font-weight:500;color:#666;min-width:120px}.config-row .value{color:#e0e0e0;font-family:Courier New,monospace;background-color:#1a1a2e;padding:.25rem .5rem;border-radius:4px;font-size:.9rem;border:1px solid #3c3c4c}.status{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #3c3c4c;border-radius:6px;font-size:1rem;transition:border-color .3s ease;background-color:#1a1a2e;color:#e0e0e0}.form-group input:focus{outline:none;border-color:#00ab57;box-shadow:0 0 0 2px #00ab5733}@media (max-width: 768px){.mqtt-configurations{padding:1rem}.header,.config-header{flex-direction:column;gap:1rem;align-items:stretch}.config-actions{justify-content:center}.form-row{grid-template-columns:1fr}.modal{width:95%;margin:1rem}}.mqtt-messages{padding:2rem;max-width:1400px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.btn:disabled{opacity:.6;cursor:not-allowed}.client-status{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.client-status h3{margin:0 0 1rem;color:#e0e0e0}.status-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.status-item .label{font-weight:500;color:#666}.status-item .value{color:#e0e0e0;font-family:Courier New,monospace}.status-item .value.connected{color:#28a745}.status-item .value.disconnected{color:#dc3545}.stats-section h3{margin:0 0 1rem;color:#e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:#1a1a2e;border:1px solid #3c3c4c;border-radius:6px;padding:1rem;text-align:center}.stat-card h4{margin:0 0 .5rem;color:#999;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.stat-number{font-size:1.5rem;font-weight:700;color:#00ab57}.filters-section h3{margin:0 0 1rem;color:#333}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column}.filter-group input,.filter-group select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#00ab57;box-shadow:0 0 0 2px #00ab5733}.filter-actions{display:flex;align-items:end}.messages-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.messages-header h3{margin:0;color:#333}.messages-actions{display:flex;gap:.5rem}.messages-list{display:flex;flex-direction:column;gap:1rem}.message-card{border:1px solid #e0e0e0;border-radius:6px;padding:1rem;transition:all .3s ease}.message-card.processed{background-color:#f8f9fa;border-left:4px solid #28a745}.message-card.unprocessed{background-color:#fff3cd;border-left:4px solid #ffc107}.message-card:hover{box-shadow:0 2px 8px #0000001a}.message-info{display:flex;flex-direction:column;gap:.25rem}.message-info .topic{font-family:Courier New,monospace;font-weight:700;color:#333;font-size:.9rem}.message-info .timestamp{color:#666;font-size:.8rem}.message-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.message-actions .status{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.message-actions .status.processed{background-color:#d4edda;color:#155724}.message-actions .status.unprocessed{background-color:#fff3cd;color:#856404}.message-actions .message-type{background-color:#e2e3e5;color:#383d41;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;text-transform:uppercase}.message-actions .qos{background-color:#d1ecf1;color:#0c5460;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-family:Courier New,monospace}.message-content pre{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:.75rem;margin:0;font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.message-meta{display:flex;gap:1rem;font-size:.8rem;color:#666;flex-wrap:wrap}.message-meta .retain{color:#dc3545;font-weight:500}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid #f0f0f0}.page-info{color:#666;font-weight:500}.modal{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header h2{margin:0;color:#333}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#00ab57;box-shadow:0 0 0 2px #00ab5733}.form-group textarea{resize:vertical;min-height:80px}@media (max-width: 768px){.mqtt-messages{padding:1rem}.header{flex-direction:column;gap:1rem;align-items:stretch}.message-header{flex-direction:column;gap:.5rem}.message-actions{justify-content:flex-start}.filters-grid,.form-row{grid-template-columns:1fr}.modal{width:95%;margin:1rem}}.mqtt-topics{padding:2rem;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.header-actions{display:flex;gap:1rem}.filters-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.filter-group{display:flex;flex-direction:column;max-width:300px}.filter-group label{margin-bottom:.5rem;font-weight:500;color:#333}.filter-group select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.filter-group select:focus{outline:none;border-color:#00ab57;box-shadow:0 0 0 2px #00ab5733}.topics-list{display:grid;gap:1.5rem}.empty-state{text-align:center;padding:3rem;color:#6c757d}.empty-state p{font-size:1.1rem;margin-bottom:1.5rem}.topic-card{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000004d;transition:all .3s ease}.topic-card.active{border-left:4px solid #28a745}.topic-card.inactive{border-left:4px solid #6c757d;background-color:#1a1a2e}.topic-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.topic-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.topic-info{flex:1}.topic-name{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.topic-icon{font-size:1.2rem}.topic-text{font-family:Courier New,monospace;font-weight:700;color:#e0e0e0;font-size:1.1rem}.topic-meta{display:flex;gap:1rem;align-items:center}.device-id{background-color:#1a1a2e;color:#e0e0e0;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-family:Courier New,monospace;border:1px solid #3c3c4c}.topic-type{background-color:#1a1a2e;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase;border:1px solid #3c3c4c}.topic-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.status.active{background-color:#d4edda;color:#155724}.status.inactive{background-color:#f8d7da;color:#721c24}.subscription-status{background-color:#d1ecf1;color:#0c5460;padding:.25rem .5rem;border-radius:12px;font-size:.75rem}.topic-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.detail-row .label{font-weight:500;color:#666;min-width:120px}.detail-row .value{color:#e0e0e0;font-family:Courier New,monospace;background-color:#1a1a2e;padding:.25rem .5rem;border-radius:4px;font-size:.9rem;border:1px solid #3c3c4c}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#2c2c3c;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #00000080;border:1px solid #3c3c4c}.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:#e0e0e0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:.25rem}.close-btn:hover{color:#333}.modal form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#e0e0e0}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #3c3c4c;border-radius:6px;font-size:1rem;transition:border-color .3s ease;background-color:#1a1a2e;color:#e0e0e0}.form-group input:focus,.form-group select:focus{outline:none;border-color:#00ab57;box-shadow:0 0 0 2px #00ab5733}.form-group input[type=checkbox]{width:auto;margin-right:.5rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}@media (max-width: 768px){.mqtt-topics{padding:1rem}.header,.topic-header{flex-direction:column;gap:1rem;align-items:stretch}.topic-actions{justify-content:center}.topic-details,.form-row{grid-template-columns:1fr}.modal{width:95%;margin:1rem}}.mqtt-monitoring{padding:2rem;max-width:1400px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.error-message{background-color:#f8d7da;color:#721c24;padding:1rem;border-radius:6px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#721c24;cursor:pointer;font-size:1.2rem}.client-status-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.client-status-section h2{margin:0 0 1.5rem;color:#e0e0e0}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.status-card{background:#1a1a2e;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.status-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.status-icon{font-size:2rem;min-width:3rem;text-align:center}.status-info h3{margin:0 0 .5rem;color:#e0e0e0;font-size:1rem}.status-info p{margin:0;font-weight:500}.status-info p.connected{color:#28a745}.status-info p.disconnected{color:#dc3545}.stats-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.stats-section h2{margin:0 0 1.5rem;color:#e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:linear-gradient(135deg,#00ab57,#008f47);color:#fff;border-radius:8px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00ab574d}.stat-icon{font-size:2rem;min-width:3rem;text-align:center}.stat-info h3{margin:0 0 .5rem;font-size:1rem;opacity:.9;color:#e0e0e0}.stat-number{font-size:1.5rem;font-weight:700;margin:0}.message-types-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.message-types-section h2{margin:0 0 1.5rem;color:#e0e0e0}.message-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.message-type-card{background:#1a1a2e;border:1px solid #3c3c4c;border-radius:8px;padding:1rem;text-align:center;transition:all .3s ease}.message-type-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.message-type-icon{font-size:2rem;margin-bottom:.5rem}.message-type-info h3{margin:0 0 .5rem;color:#e0e0e0;text-transform:capitalize;font-size:.9rem}.message-type-count{font-size:1.2rem;font-weight:700;color:#00ab57;margin:0}.top-devices-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.top-devices-section h2{margin:0 0 1.5rem;color:#333}.devices-list{display:flex;flex-direction:column;gap:1rem}.device-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:6px;transition:all .3s ease}.device-item:hover{background:#e9ecef}.device-rank{background:#00ab57;color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.device-info{flex:1}.device-info h3{margin:0 0 .25rem;color:#333;font-size:1rem}.device-info p{margin:0;color:#666;font-size:.9rem}.last-message{font-style:italic}.recent-messages-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000004d}.recent-messages-section h2{margin:0 0 1.5rem;color:#e0e0e0}.recent-messages-list{display:flex;flex-direction:column;gap:1rem}.empty-state{text-align:center;padding:2rem;color:#6c757d}.recent-message-card{background:#1a1a2e;border:1px solid #3c3c4c;border-radius:6px;padding:1rem;transition:all .3s ease}.recent-message-card:hover{box-shadow:0 2px 8px #0000001a}.message-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.message-topic{display:flex;align-items:center;gap:.5rem}.message-type-icon{font-size:1.2rem}.topic-text{font-family:Courier New,monospace;font-weight:700;color:#e0e0e0;font-size:.9rem}.message-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.message-type{background-color:#1a1a2e;border:1px solid #3c3c4c;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;text-transform:uppercase;font-weight:500}.timestamp{color:#666;font-size:.8rem}.message-content{margin-bottom:.75rem}.message-content pre{background-color:#1a1a2e;border:1px solid #3c3c4c;border-radius:4px;padding:.75rem;margin:0;font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;color:#e0e0e0}.message-footer{display:flex;gap:1rem;font-size:.8rem;color:#666;flex-wrap:wrap}.status{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.status.processed{background-color:#d4edda;color:#155724}.status.unprocessed{background-color:#fff3cd;color:#856404}.qos{background-color:#d1ecf1;color:#0c5460;padding:.25rem .5rem;border-radius:12px;font-family:Courier New,monospace}.device-id{background-color:#e9ecef;color:#495057;padding:.25rem .5rem;border-radius:12px;font-family:Courier New,monospace}@media (max-width: 768px){.mqtt-monitoring{padding:1rem}.header{flex-direction:column;gap:1rem;align-items:stretch}.header-actions{justify-content:space-between}.status-grid,.stats-grid{grid-template-columns:1fr}.message-types-grid{grid-template-columns:repeat(2,1fr)}.message-header{flex-direction:column;gap:.5rem}.message-meta{justify-content:flex-start}}.mqtt-client-status{padding:2rem;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#e0e0e0}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.header h1{color:#e0e0e0;margin:0}.header-actions{display:flex;align-items:center;gap:1rem}.refresh-controls{display:flex;align-items:center;gap:.5rem}.refresh-controls label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#e0e0e0}.refresh-controls select{padding:.5rem;border:1px solid #3c3c4c;border-radius:4px;font-size:.9rem;background-color:#1a1a2e;color:#e0e0e0}.refresh-controls select:disabled{opacity:.6;cursor:not-allowed}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{background-color:#008f47;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.error-message{background-color:#2c1810;color:#f8d7da;padding:1rem;border-radius:6px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;border:1px solid #721c24}.error-message button{background:none;border:none;color:#f8d7da;cursor:pointer;font-size:1.2rem}.main-status-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.connection-status{margin-bottom:2rem}.status-indicator{display:flex;align-items:center;gap:1.5rem;padding:2rem;border-radius:8px;color:#fff;background:linear-gradient(135deg,#00ab57,#008f47)}.status-icon{font-size:3rem;min-width:4rem;text-align:center}.status-text h2{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#fff}.status-text p{margin:0;opacity:.9;font-size:1rem;color:#fff}.client-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-card{background:#1a1a2e;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.info-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.info-icon{font-size:2rem;min-width:3rem;text-align:center;color:#00ab57}.info-content h3{margin:0 0 .5rem;color:#e0e0e0;font-size:1rem}.info-content p{margin:0;font-weight:500;color:#999}.topics-section{background:#2c2c3c;border:1px solid #3c3c4c;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000004d}.topics-section h2{margin:0 0 1.5rem;color:#e0e0e0}.topics-list{display:flex;flex-direction:column;gap:1rem}.topic-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#1a1a2e;border:1px solid #3c3c4c;border-radius:6px;transition:all .3s ease}.topic-item:hover{background:#2c2c3c}.topic-info{display:flex;flex-direction:column;gap:.25rem}.topic-name{font-family:Courier New,monospace;font-weight:700;color:#e0e0e0;font-size:1rem}.topic-status{color:#28a745;font-size:.9rem;font-weight:500}.topic-actions{display:flex;gap:.5rem}.quick-actions-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.quick-actions-section h2{margin:0 0 1.5rem;color:#333}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.action-card{background:#f8f9fa;border-radius:8px;padding:1.5rem;text-align:center;transition:all .3s ease}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.action-card h3{margin:0 0 .5rem;color:#333;font-size:1.1rem}.action-card p{margin:0 0 1rem;color:#666;font-size:.9rem}.common-topics{display:flex;flex-direction:column;gap:.5rem}.connection-history-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.connection-history-section h2{margin:0 0 1.5rem;color:#333}.history-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.history-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:6px;transition:all .3s ease}.history-item:hover{background:#e9ecef}.history-timestamp{min-width:100px;font-size:.9rem;color:#666;font-family:Courier New,monospace}.history-status{display:flex;align-items:center;gap:.5rem;min-width:120px}.status-dot{width:8px;height:8px;border-radius:50%}.history-details{display:flex;gap:1rem;font-size:.8rem;color:#666;flex:1;justify-content:flex-end}.loading{text-align:center;padding:3rem;color:#6c757d;font-size:1.1rem}@media (max-width: 768px){.mqtt-client-status{padding:1rem}.header{flex-direction:column;gap:1rem;align-items:stretch}.header-actions{justify-content:space-between}.status-indicator{flex-direction:column;text-align:center;gap:1rem}.status-text h2{font-size:1.5rem}.client-info-grid,.quick-actions-grid{grid-template-columns:1fr}.topic-item{flex-direction:column;gap:1rem;align-items:stretch}.topic-actions{justify-content:center}.history-item{flex-direction:column;gap:.5rem;align-items:stretch}.history-details{justify-content:flex-start}}.access-denied{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.access-denied-container{background:#fff;border-radius:12px;padding:3rem;text-align:center;box-shadow:0 10px 25px #0003;max-width:500px;width:100%}.access-denied-icon{font-size:4rem;margin-bottom:1.5rem}.access-denied h1{color:#333;margin:0 0 1rem;font-size:2rem;font-weight:700}.access-denied p{color:#666;margin:0 0 1rem;font-size:1.1rem;line-height:1.6}.access-denied-detail{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:1rem;margin:1.5rem 0;color:#495057}.access-denied-detail strong{color:#00ab57;font-weight:700}.access-denied-actions{margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;font-size:1rem}.btn-primary{background-color:#00ab57;color:#fff}.btn-primary:hover{background-color:#008f47;transform:translateY(-1px);box-shadow:0 4px 8px #00ab574d}@media (max-width: 768px){.access-denied{padding:1rem}.access-denied-container{padding:2rem}.access-denied-icon{font-size:3rem}.access-denied h1{font-size:1.5rem}.access-denied p{font-size:1rem}}.user-preferences{padding:2rem;max-width:800px;margin:0 auto;min-height:100vh;color:#fff}.preferences-container{background:#2c2c3ccc;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000004d}.preferences-container h1{margin:0 0 2rem;color:#e0e0e0;font-size:2rem;border-bottom:2px solid #00ab57;padding-bottom:1rem}.preferences-section{margin-bottom:2rem}.preferences-section h2{margin:0 0 .5rem;color:#e0e0e0;font-size:1.5rem}.section-description{color:#b0b0b0;margin-bottom:1.5rem;font-size:.95rem}.color-picker-section{margin-bottom:2rem}.color-picker-section label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500}.color-input-group{display:flex;gap:1rem;align-items:center}.color-picker{width:80px;height:50px;border:2px solid #555;border-radius:8px;cursor:pointer;background:none;padding:0}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:6px}.color-text-input{flex:1;padding:.75rem;border:2px solid #555;border-radius:8px;background:#2c2c3c;color:#fff;font-size:1rem;font-family:monospace}.color-text-input:focus{outline:none;border-color:#00ab57}.preset-colors-section{margin-top:2rem}.preset-colors-section label{display:block;margin-bottom:.5rem;color:#e0e0e0;font-weight:500}.preset-colors{display:flex;gap:1rem;flex-wrap:wrap}.preset-color-btn{width:60px;height:60px;border:3px solid transparent;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5)}.preset-color-btn:hover{transform:scale(1.1);border-color:#00ab57}.preset-color-btn.active{border-color:#00ab57;box-shadow:0 0 10px #00ab5780}.message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.message.success{background-color:#2d5016;color:#90ee90;border:1px solid #4caf50}.message.error{background-color:#501616;color:#ff6b6b;border:1px solid #f44336}.actions{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}.save-btn,.reset-btn,.cancel-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.save-btn{background-color:#00ab57;color:#fff}.save-btn:hover:not(:disabled){background-color:#008f47;transform:translateY(-2px)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.reset-btn{background-color:#6c757d;color:#fff}.reset-btn:hover:not(:disabled){background-color:#5a6268}.cancel-btn{background-color:transparent;color:#e0e0e0;border:2px solid #555}.cancel-btn:hover{border-color:#777;background-color:#ffffff0d}.loading{text-align:center;padding:2rem;color:#b0b0b0}@media (max-width: 768px){.user-preferences{padding:1rem}.preferences-container{padding:1.5rem}.color-input-group{flex-direction:column;align-items:stretch}.color-picker{width:100%}.actions{flex-direction:column}.actions button{width:100%}}
