:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-box h1{margin-bottom:1.5rem;text-align:center}.login-box form div{margin-bottom:1rem}.login-box label{display:block;margin-bottom:.5rem;font-weight:500}.login-box input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.login-box button{width:100%;padding:.75rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-box button:hover{background-color:#0056b3}.login-box .error{color:red;margin-top:.5rem;text-align:center}.navigation{display:flex;align-items:center;padding:1rem 2rem;background:#2c3e50;color:#fff;box-shadow:0 2px 4px #0000001a}.nav-brand h2{margin:0;font-size:1.5rem}.nav-links{flex:1;display:flex;gap:2rem;margin-left:3rem}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background .2s}.nav-links a:hover{background:#ffffff1a}.nav-links a.active{background:#fff3}.nav-user{display:flex;align-items:center;gap:1rem}.nav-user button{padding:.5rem 1rem;background:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer}.nav-user button:hover{background:#c0392b}table{border-collapse:collapse;margin-top:1rem}.error{color:red}.filters{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.filters label{display:flex;align-items:center;gap:.5rem}.pagination{display:flex;gap:1rem;align-items:center;margin-top:1rem}.pagination button:disabled{opacity:.5;cursor:not-allowed}.table-container{overflow-x:auto}.chart-container{margin:1rem 0}.view-toggle{display:flex;gap:0}.view-toggle button{padding:.5rem 1rem;border:1px solid #ccc;background:#fff;cursor:pointer}.view-toggle button.active{background:#007bff;color:#fff;border-color:#007bff}.view-toggle button:first-child{border-radius:4px 0 0 4px}.view-toggle button:last-child{border-radius:0 4px 4px 0}.table-container{overflow-x:auto;max-height:500px;overflow-y:auto}.table-container table{border-collapse:collapse;width:100%}.table-container th,.table-container td{border:1px solid #ccc;padding:.5rem 1rem;text-align:left}.table-container th{position:sticky;top:0;background-color:#f0f0f0;box-shadow:0 1px #ccc;z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none}.table-container th:hover{background-color:#e0e0e0}.column-toggle{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;align-items:center}.column-toggle label{display:flex;align-items:center;gap:.25rem;font-size:.85rem}.export-button{padding:.5rem 1rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer}.export-button:hover{background-color:#218838}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-header h2{margin:0}.page-container{padding:2rem;max-width:1400px;margin:0 auto}.device-count{color:#666;margin-bottom:2rem}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.device-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s}.device-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.device-card.online{border-left:4px solid #27ae60}.device-card.warning{border-left:4px solid #f39c12}.device-card.offline{border-left:4px solid #e74c3c}.device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.device-header h3{margin:0;font-size:1.2rem;color:#2c3e50}.status-badge{font-size:1.5rem}.status-badge.online{color:#27ae60}.status-badge.warning{color:#f39c12}.status-badge.offline{color:#e74c3c}.device-info{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;justify-content:space-between;font-size:.9rem}.info-row .label{color:#7f8c8d;font-weight:500}.info-row .value{color:#2c3e50}.error{color:#e74c3c;padding:1rem;background:#fee;border-radius:4px}.device-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-button{padding:.5rem 1rem;background:#ecf0f1;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.back-button:hover{background:#bdc3c7}.controls-panel{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.date-range-selector{margin-bottom:1.5rem}.date-range-selector label{display:block;font-weight:600;margin-bottom:.5rem}.range-buttons{display:flex;gap:.5rem}.range-buttons button{padding:.5rem 1rem;border:2px solid #3498db;background:#fff;color:#3498db;border-radius:4px;cursor:pointer;transition:all .2s}.range-buttons button:hover{background:#ebf5fb}.range-buttons button.active{background:#3498db;color:#fff}.channel-selector label{display:block;font-weight:600;margin-bottom:.5rem}.channel-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.channel-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem}.channel-checkbox input{cursor:pointer}.chart-area{background:#fff;padding:2rem;border-radius:8px;margin-bottom:2rem;min-height:400px;box-shadow:0 2px 4px #0000001a}.export-section{display:flex;justify-content:flex-end}.export-button{padding:.75rem 1.5rem;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.export-button:hover{background:#229954}
