:root{color:#f3f4f6;background:#14121f;font-family:Inter,system-ui,Arial,sans-serif}*{box-sizing:border-box}body{color:#f3f4f6;background:radial-gradient(circle at 10% 15%,#fb923c33,#0000 24%),radial-gradient(circle at 85% 10%,#10b98124,#0000 28%),linear-gradient(#14121f 0%,#1f1830 100%);margin:0}button{font:inherit}.dashboard-page{background:radial-gradient(circle at 0 0,#fb923c33,#0000 28%),radial-gradient(circle at 80% 5%,#2dd4bf2b,#0000 28%),linear-gradient(#14121ff2 0%,#1f1830f2 100%);min-height:100vh;padding:24px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-header h1{margin:0 0 8px;font-size:32px}.page-header p{color:#9ca3af;margin:0}.brand-block{align-items:center;gap:14px;display:flex}.brand-logo{object-fit:contain;background:#f8fafceb;border:1px solid #cbd5e1;border-radius:12px;width:72px;height:72px;padding:6px}.refresh-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f97316 0%,#ef4444 100%);border:none;border-radius:12px;padding:12px 18px;font-weight:600}.refresh-btn:disabled{opacity:.65;cursor:not-allowed}.tabs-row{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.tab-btn{color:#e5e7eb;cursor:pointer;background:#111827;border:1px solid #334155;border-radius:999px;padding:10px 16px}.tab-btn.active{background:linear-gradient(135deg,#14b8a6 0%,#22c55e 100%);border-color:#14b8a6}.cards-section{flex-direction:column;gap:20px;display:flex}.device-summary{background:#111827e6;border:1px solid #1f2937;border-radius:20px;padding:20px;box-shadow:0 10px 30px #00000040}.device-summary-header{flex-wrap:wrap;justify-content:space-between;gap:20px;margin-bottom:20px;display:flex}.device-summary-header h2{margin:0 0 10px}.device-summary-header p{color:#cbd5e1;margin:4px 0}.signal-box{background:#0f172a;border:1px solid #334155;border-radius:16px;min-width:220px;padding:16px}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}.device-trend-chart{background:#0f172ab3;border:1px solid #334155;border-radius:14px;margin-top:16px;padding:12px}.device-trend-chart h3{color:#dbeafe;margin:0 0 8px;font-size:15px}.device-trend-chart p{color:#cbd5e1;margin:8px 0}.day-chart-toggle-row{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.device-day-chart{background:#0f172a8c;border:1px solid #334155;border-radius:14px;margin-top:12px;padding:12px}.day-chart-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.day-chart-header h3{color:#dbeafe;margin:0;font-size:15px}.day-chart-controls{align-items:center;gap:8px;display:flex}.day-chart-controls label{color:#cbd5e1;font-size:13px}.day-export-btn{color:#f8fafc;cursor:pointer;background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);border:1px solid #22c55e;border-radius:10px;padding:8px 12px;font-weight:700}.day-export-btn:disabled{opacity:.55;cursor:not-allowed}.day-chart-controls input{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:8px 10px}.day-date-input{appearance:none;color:#f1f5f9;letter-spacing:.2px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:linear-gradient(#111827 0%,#0f172a 100%);border:1px solid #334155;border-radius:10px;min-width:170px;height:38px;padding:8px 10px;font-weight:600;box-shadow:inset 0 0 0 1px #94a3b81f}.day-date-input::-webkit-calendar-picker-indicator{filter:invert()brightness(200%);opacity:1;cursor:pointer}.day-date-input:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 3px #60a5fa38}.day-chart-caption{color:#cbd5e1;margin:4px 0 10px;font-size:13px}.chart-zoom-row{gap:8px;margin:4px 0 10px;display:flex}.chart-zoom-btn{border-radius:10px;padding:7px 12px}.device-compare-chart{background:#0f172a8c;border:1px solid #334155;border-radius:14px;margin-top:12px;padding:12px}.compare-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.compare-header h3{color:#dbeafe;margin:0;font-size:15px}.compare-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.compare-controls .day-date-input{min-width:162px;height:38px}.compare-controls label{color:#cbd5e1;font-size:13px}.compare-metric-select{color:#f1f5f9;background:linear-gradient(#111827 0%,#0f172a 100%);border:1px solid #334155;border-radius:10px;min-width:150px;height:38px;padding:8px 10px;box-shadow:inset 0 0 0 1px #94a3b81f}.compare-metric-select:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 3px #60a5fa38}.compare-metric-select option,.sensor-map-visual-controls select option,.sensor-map-admin-controls select option,.profile-box select option,.user-form select option,.alert-filter-form select option,.rule-form select option{color:#0f172a;background:#f8fafc}.sensor-map-section{background:#111827e6;border:1px solid #1f2937;border-radius:20px;margin-top:30px;padding:20px}.sensor-map-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.sensor-map-header h2{margin:0}.sensor-map-legend{color:#cbd5e1;flex-wrap:wrap;align-items:center;gap:14px;font-size:13px;display:flex}.status-dot{border-radius:50%;width:10px;height:10px;margin-right:6px;display:inline-block}.status-ok{background:#22c55e}.status-warning{background:#f59e0b}.status-critical{background:#ef4444}.status-stale{background:#94a3b8}.sensor-map-wrapper{width:100%;overflow-x:auto}.sensor-map-visual-controls{flex-wrap:wrap;align-items:center;gap:10px;margin:6px 0 12px;display:flex}.heatmap-toggle-label{color:#dbeafe;align-items:center;gap:8px;font-size:13px;display:inline-flex}.heatmap-toggle-label input{accent-color:#22c55e}.sensor-map-visual-controls label{color:#cbd5e1;font-size:13px}.sensor-map-visual-controls select{color:#f1f5f9;background:linear-gradient(#111827 0%,#0f172a 100%);border:1px solid #334155;border-radius:10px;min-width:120px;padding:8px 10px}.sensor-map-canvas{--heatmap-scale-end:1.65;--heatmap-opacity-start:.72;--heatmap-blur:10px;--heatmap-size:56px;cursor:crosshair;-webkit-user-select:none;user-select:none;border:1px solid #334155;border-radius:14px;width:min(100%,980px);min-width:560px;margin:0 auto;position:relative;overflow:hidden}.sensor-map-image{object-fit:contain;width:100%;max-height:470px;display:block}.sensor-marker{z-index:2;flex-direction:column;align-items:center;gap:4px;display:flex;position:absolute;transform:translate(-50%,-50%)}.sensor-marker:before{content:"";border:2px solid #0f172a;border-radius:50%;width:14px;height:14px;box-shadow:0 0 0 2px #ffffff1f}.sensor-marker:after{content:"";width:var(--heatmap-size);height:var(--heatmap-size);opacity:var(--heatmap-opacity-start);filter:blur(var(--heatmap-blur));z-index:-1;border-radius:50%;animation:1.9s ease-out infinite marker-heat-pulse;position:absolute;top:-14px;left:50%;transform:translate(-50%)scale(.78)}.sensor-map-canvas.heatmap-disabled .sensor-marker:after{display:none}.sensor-map-canvas.heatmap-low{--heatmap-size:48px;--heatmap-blur:8px;--heatmap-opacity-start:.58;--heatmap-scale-end:1.6}.sensor-map-canvas.heatmap-medium{--heatmap-size:62px;--heatmap-blur:12px;--heatmap-opacity-start:.76;--heatmap-scale-end:1.95}.sensor-map-canvas.heatmap-high{--heatmap-size:78px;--heatmap-blur:15px;--heatmap-opacity-start:.92;--heatmap-scale-end:2.35}.marker-ok:before{background:#22c55e;box-shadow:0 0 0 2px #0f172ad1,0 0 12px #22c55e8c}.marker-ok:after{background:radial-gradient(circle,#22c55ef2 0%,#22c55e6b 45%,#22c55e00 74%);animation-duration:1.45s}.marker-warning:before{background:#f59e0b;box-shadow:0 0 0 2px #0f172ad1,0 0 12px #f59e0b94}.marker-warning:after{background:radial-gradient(circle,#f59e0bfa 0%,#f59e0b7a 46%,#f59e0b00 75%);animation-duration:1.15s}.marker-critical:before{background:#ef4444;box-shadow:0 0 0 2px #0f172ad1,0 0 14px #ef44449e}.marker-critical:after{background:radial-gradient(circle,#ef4444 0%,#ef444494 50%,#ef444400 78%);animation-duration:.95s}.marker-stale:before,.marker-unknown:before{background:#94a3b8;box-shadow:0 0 0 2px #0f172ad1,0 0 8px #94a3b873}.marker-stale:after,.marker-unknown:after{background:radial-gradient(circle,#94a3b8cc 0%,#94a3b857 45%,#94a3b800 72%);animation-duration:1.95s}.marker-draft:before{background:#38bdf8;animation:1.4s infinite draft-pulse}.marker-draft:after{background:radial-gradient(circle,#38bdf8e6 0%,#38bdf866 46%,#38bdf800 74%);animation-duration:1.1s}@keyframes marker-heat-pulse{0%{opacity:var(--heatmap-opacity-start);transform:translate(-50%)scale(.78)}65%{opacity:.35}to{transform:translateX(-50%) scale(var(--heatmap-scale-end));opacity:0}}@keyframes draft-pulse{0%{box-shadow:0 0 #38bdf859}to{box-shadow:0 0 0 10px #38bdf800}}.sensor-marker-label{color:#f8fafc;white-space:nowrap;background:#0f172aeb;border:1px solid #334155;border-radius:8px;padding:2px 6px;font-size:11px}.sensor-marker-chip{color:#dbeafe;text-transform:uppercase;background:#0f172ad1;border:1px solid #334155;border-radius:999px;padding:1px 6px;font-size:10px}.sensor-map-admin{background:#0f172a80;border:1px solid #334155;border-radius:12px;margin-top:12px;padding:12px}.sensor-map-admin h3{color:#dbeafe;margin:0 0 6px;font-size:15px}.sensor-map-admin p{color:#cbd5e1;margin:4px 0 12px}.sensor-map-admin-controls{grid-template-columns:minmax(180px,1fr) minmax(220px,1.2fr) auto auto;align-items:center;gap:10px;display:grid}.sensor-map-admin-controls select,.sensor-map-admin-controls input{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:10px 12px}.sensor-map-pos-text{color:#cbd5e1;margin-top:10px;font-size:13px}.map-error-text{color:#fca5a5}.metric-card{background:linear-gradient(#172033 0%,#111827 100%);border:1px solid #334155;border-radius:18px;padding:16px}.metric-label{color:#94a3b8;margin:0 0 8px;font-size:14px}.metric-value{margin:0;font-size:28px;line-height:1.1}.history-section,.admin-users-section,.admin-alerts-section,.admin-rules-section{margin-top:30px}.profile-box{background:#0f172aa6;border:1px solid #334155;border-radius:14px;flex-direction:column;gap:8px;min-width:180px;padding:10px;display:flex}.profile-box label{color:#cbd5e1;font-size:13px}.profile-box span{color:#f8fafc;font-weight:600}.profile-password-form{flex-direction:column;gap:8px;display:flex}.profile-password-form input{color:#e5e7eb;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:10px 12px}.profile-password-error,.profile-password-success{margin:0;font-size:12px}.profile-password-error{color:#fca5a5}.profile-password-success{color:#86efac}.logout-btn{color:#e2e8f0;cursor:pointer;background:#111827;border:1px solid #475569;border-radius:10px;padding:8px 12px}.profile-box select,.user-form input,.user-form select{color:#e5e7eb;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:10px 12px}.user-form{grid-template-columns:1.2fr 1.6fr 1.2fr .9fr auto;gap:10px;margin-bottom:14px;display:grid}.alert-filter-form,.rule-form{grid-template-columns:repeat(5,minmax(120px,1fr));gap:10px;margin-bottom:14px;display:grid}.alert-filter-form input,.alert-filter-form select,.rule-form input,.rule-form select{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:10px 12px}.rule-form label{color:#cbd5e1;align-items:center;gap:8px;font-size:14px;display:flex}.pagination-row{color:#cbd5e1;justify-content:flex-end;align-items:center;gap:12px;margin-top:14px;display:flex}.login-page{place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{background:#0f172ae6;border:1px solid #334155;border-radius:18px;width:100%;max-width:420px;padding:24px;box-shadow:0 12px 30px #0000004d}.login-card h1{margin-top:0;margin-bottom:8px}.login-card p{color:#94a3b8;margin-top:0}.login-form{flex-direction:column;gap:10px;display:flex}.forced-change-note{color:#fde68a;margin:0;font-size:14px}.forgot-password-box{border-top:1px solid #334155;margin-top:18px;padding-top:14px}.forgot-password-box h2{color:#dbeafe;margin:0 0 6px;font-size:16px}.forgot-password-box p{margin:0 0 10px}.forgot-success-message{color:#86efac;margin-top:10px;font-size:14px}.login-form input{color:#f1f5f9;background:#0f172a;border:1px solid #334155;border-radius:10px;padding:10px 12px}.history-section h2{margin-bottom:16px}.table-wrapper{background:#111827e6;border:1px solid #1f2937;border-radius:20px;padding:14px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;vertical-align:top;border-bottom:1px solid #1f2937;padding:12px}.data-table th{color:#93c5fd}.payload-pre{white-space:pre-wrap;word-break:break-word;color:#d1d5db;margin:0;font-size:12px}.error-banner{color:#fecaca;background:#7f1d1dcc;border:1px solid #dc2626;border-radius:14px;margin-bottom:20px;padding:14px 16px}.loading-block{text-align:center;color:#cbd5e1;background:#111827e6;border:1px solid #1f2937;border-radius:20px;padding:30px}@media (width<=768px){.page-header{flex-direction:column;align-items:stretch}.brand-block{align-items:flex-start}.brand-logo{width:56px;height:56px}.refresh-btn{width:100%}.profile-box{min-width:100%}.user-form{grid-template-columns:1fr}.day-chart-header,.compare-header{flex-direction:column;align-items:flex-start}.sensor-map-canvas{min-width:460px}.sensor-map-admin-controls{grid-template-columns:1fr}.sensor-map-visual-controls{align-items:flex-start}.alert-filter-form,.rule-form{grid-template-columns:1fr}.pagination-row{flex-wrap:wrap;justify-content:space-between}}
