:root{--bg-primary:#0f1923;--bg-secondary:#1a2632;--bg-card:#1e2d3d;--bg-hover:#253545;--accent:#00e676;--accent-dim:#00c853;--text-primary:#e0e6ed;--text-secondary:#8899aa;--border:#2a3a4a;--danger:#ff5252;--warning:#ffc107;--radius:10px;--radius-sm:6px}*{box-sizing:border-box}body{padding:0;margin:0;font:normal 14px 'Segoe UI',system-ui,-apple-system,sans-serif;color:var(--text-primary);background-color:var(--bg-primary);line-height:1.6;min-height:100vh}.container-background{background-color:transparent}.container{margin:0 auto;max-width:1200px;padding:20px}.center{text-align:center}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-secondary);border-radius:var(--radius);margin-bottom:20px;border:1px solid var(--border)}.app-header .logo-area{display:flex;align-items:center;gap:12px}.app-header .logo-area svg{width:36px;height:36px}.app-header h1{margin:0;font-size:1.3rem;font-weight:700;color:var(--accent);letter-spacing:1px}.header-right{display:flex;align-items:center;gap:12px}.btn-logout{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:8px 18px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.85rem;transition:all 0.2s;text-decoration:none;display:inline-block}.btn-logout:hover{color:var(--danger);border-color:var(--danger);background:rgba(255,82,82,0.08)}.btn-panic{background:transparent;color:var(--danger);border:2px solid var(--danger);padding:8px 20px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.85rem;font-weight:800;letter-spacing:1px;transition:all 0.2s}.btn-panic:hover{background:var(--danger);color:#fff}.btn-panic.active{background:var(--danger);color:#fff;animation:panic-pulse 1s infinite}@keyframes panic-pulse{0%,100%{background:var(--danger);box-shadow:0 0 0 0 rgba(255,82,82,0.6)}50%{background:#cc0000;box-shadow:0 0 20px 4px rgba(255,82,82,0.4)}}.panic-mode{animation:panic-border 1.5s infinite}@keyframes panic-border{0%,100%{box-shadow:inset 0 0 0 3px transparent}50%{box-shadow:inset 0 0 0 3px var(--danger)}}.panic-mode .app-header{border-color:var(--danger);box-shadow:0 0 15px rgba(255,82,82,0.15)}.status-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.status-chip{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 18px;flex:1;min-width:200px}.status-chip .status-icon{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-chip .status-icon.live{background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}.status-chip .status-icon.stale{background:var(--warning);box-shadow:0 0 8px var(--warning)}.status-chip .status-icon.offline{background:var(--danger);box-shadow:0 0 8px var(--danger)}@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}.status-chip .status-label{font-size:0.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.status-chip .status-value{font-size:0.95rem;font-weight:600;color:var(--text-primary)}.auto-refresh{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 16px;flex:1;min-width:200px}.auto-refresh label{font-size:0.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}.toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-primary);border:1px solid var(--border);border-radius:22px;transition:0.2s}.toggle-slider::before{content:"";position:absolute;height:16px;width:16px;left:2px;bottom:2px;background:var(--text-secondary);border-radius:50%;transition:0.2s}.toggle-switch input:checked + .toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked + .toggle-slider::before{transform:translateX(18px);background:var(--bg-primary)}.refresh-select{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:0.8rem;outline:none;cursor:pointer}.refresh-countdown{font-size:0.8rem;color:var(--text-secondary);min-width:30px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.card-title{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-secondary);margin:0 0 14px}.card-header-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}.card-header-row .card-title{margin-bottom:0}.rate-display{display:inline-flex;align-items:center;gap:8px;background:var(--bg-primary);padding:8px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:0.95rem}.rate-display .value{color:var(--accent);font-weight:700;font-size:1.1rem}.presets-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.preset-btn{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.85rem;font-weight:500;transition:all 0.2s;min-width:52px;text-align:center}.preset-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,230,118,0.06)}.preset-btn.active{border-color:var(--accent);background:var(--accent);color:var(--bg-primary);font-weight:700}.custom-rate-row{display:flex;gap:10px;align-items:stretch}.custom-rate-row input{flex:1;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:10px 14px;border-radius:var(--radius-sm);font-size:0.9rem;outline:none;transition:border-color 0.2s;max-width:220px}.custom-rate-row input:focus{border-color:var(--accent)}.custom-rate-row input::placeholder{color:var(--text-secondary)}.btn-primary{background:var(--accent);color:var(--bg-primary);border:none;padding:10px 22px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.85rem;font-weight:700;transition:all 0.2s;white-space:nowrap}.btn-primary:hover{background:var(--accent-dim)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.8rem;font-weight:500;transition:all 0.2s;white-space:nowrap}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.custom-preset-item{display:inline-flex;align-items:stretch;position:relative}.custom-preset-item .preset-btn{border-top-right-radius:0;border-bottom-right-radius:0}.preset-delete{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);border-left:none;border-top-right-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm);cursor:pointer;font-size:1rem;padding:0 8px;transition:all 0.2s;line-height:1}.preset-delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.preset-label-input{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:10px 14px;border-radius:var(--radius-sm);font-size:0.9rem;outline:none;transition:border-color 0.2s;width:120px}.preset-label-input:focus{border-color:var(--accent)}.preset-label-input::placeholder{color:var(--text-secondary)}.address-cell{white-space:normal !important;word-break:break-word;font-size:0.8rem;line-height:1.4;min-width:200px}.gmaps-btn{display:inline-flex;align-items:center;gap:4px;background:var(--accent);color:var(--bg-primary);text-decoration:none;padding:8px 14px;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:700;white-space:nowrap;transition:all 0.2s}.gmaps-btn:hover{background:var(--accent-dim);text-decoration:none;color:var(--bg-primary)}.map-card{padding:0;overflow:hidden;position:relative}#mapid{height:55vh;min-height:350px;z-index:1}.map-buttons{display:flex;gap:10px;margin-top:-10px;margin-bottom:20px}.leaflet-control-container{z-index:800 !important;position:relative !important}.leaflet-top, .leaflet-bottom{z-index:800 !important}.leaflet-control-zoom{z-index:800 !important}.leaflet-control-zoom a{background:var(--bg-card) !important;color:var(--text-primary) !important;border-color:var(--border) !important;width:36px !important;height:36px !important;line-height:36px !important;font-size:18px !important}.leaflet-control-zoom a:hover{background:var(--accent) !important;color:var(--bg-primary) !important}.battery-bar-wrapper{display:flex;align-items:center;gap:8px}.battery-bar{width:40px;height:14px;background:var(--bg-primary);border-radius:3px;overflow:hidden;border:1px solid var(--border);position:relative}.battery-bar-fill{height:100%;border-radius:2px;transition:width 0.3s}.battery-bar-fill.high{background:var(--accent)}.battery-bar-fill.medium{background:var(--warning)}.battery-bar-fill.low{background:var(--danger)}.battery-text{font-size:0.8rem;font-weight:600;min-width:32px}.battery-text.high{color:var(--accent)}.battery-text.medium{color:var(--warning)}.battery-text.low{color:var(--danger)}.filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.filter-row select,.filter-row input[type="date"]{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;font-size:0.8rem;outline:none;cursor:pointer}.filter-row select:focus,.filter-row input[type="date"]:focus{border-color:var(--accent)}.filter-row input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.7)}.filter-count{font-size:0.8rem;color:var(--text-secondary);margin-left:auto}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-height:500px;overflow-y:auto}table{border-collapse:collapse;width:100%;font-size:0.85rem}th{background:var(--bg-primary);color:var(--text-secondary);font-weight:600;font-size:0.75rem;text-transform:uppercase;letter-spacing:1px;padding:12px 14px;text-align:left;position:sticky;top:0;z-index:1}td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-primary);white-space:nowrap}tr:hover td{background:var(--bg-hover)}td a{color:var(--accent);text-decoration:none;font-weight:500}td a:hover{text-decoration:underline}footer{color:var(--text-secondary);text-align:center;padding:20px;font-size:0.8rem}footer b{color:var(--text-primary)}.login-card{max-width:380px;margin:60px auto;text-align:center}.login-card input{width:100%;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:12px 16px;border-radius:var(--radius-sm);font-size:0.95rem;outline:none;margin-bottom:12px;transition:border-color 0.2s}.login-card input:focus{border-color:var(--accent)}.login-card input::placeholder{color:var(--text-secondary)}.login-card .btn-primary{width:100%;padding:14px;font-size:1rem}.linkbutton{display:inline-block;padding:14px 40px;color:var(--accent);border:1px solid var(--accent);text-decoration:none;border-radius:var(--radius-sm);transition:all 0.2s;font-weight:600}.linkbutton:hover{color:var(--bg-primary);background-color:var(--accent)}hr{border:0;border-top:1px solid var(--border)}@media (max-width:768px){body{font-size:15px}.container{padding:10px}.app-header{padding:12px 16px;margin-bottom:14px;flex-direction:row;gap:8px}.app-header .logo-area svg{width:28px;height:28px}.app-header h1{font-size:1.15rem}.btn-logout{padding:8px 14px;font-size:0.9rem}.btn-panic{padding:10px 16px;font-size:0.9rem}.header-right{gap:8px}.status-bar{flex-direction:column;gap:10px;margin-bottom:14px}.status-chip, .auto-refresh{min-width:0;padding:14px 16px}.status-chip .status-label{font-size:0.8rem}.status-chip .status-value{font-size:1.05rem}.auto-refresh{flex-wrap:wrap;gap:10px}.auto-refresh label{font-size:0.85rem}.refresh-select{padding:6px 10px;font-size:0.9rem}.toggle-switch{width:46px;height:26px}.toggle-slider::before{width:20px;height:20px}.toggle-switch input:checked + .toggle-slider::before{transform:translateX(20px)}.card{padding:16px;margin-bottom:14px}.card-title{font-size:0.8rem;margin-bottom:12px}.rate-display{font-size:1rem;padding:10px 16px}.rate-display .value{font-size:1.2rem}.presets-grid{gap:8px}.preset-btn{padding:10px 14px;font-size:0.95rem;min-width:50px}.preset-delete{padding:0 10px;font-size:1.2rem}.custom-rate-row{flex-direction:column;gap:10px}.custom-rate-row input{max-width:100%;padding:12px 14px;font-size:1rem}.preset-label-input{width:100% !important;padding:12px 14px !important;font-size:1rem !important}.btn-primary{padding:14px 22px;font-size:1rem;width:100%;text-align:center}.btn-secondary{padding:12px 16px;font-size:0.95rem}#savePresetBtn{width:100%;text-align:center}#mapid{height:50vh;min-height:300px}.map-buttons{flex-direction:column;gap:8px;margin-top:-8px;margin-bottom:14px}.map-buttons .btn-secondary{width:100%;text-align:center;padding:14px;font-size:1rem}.leaflet-control-zoom a{width:44px !important;height:44px !important;line-height:44px !important;font-size:22px !important}.card-header-row{flex-direction:column;align-items:flex-start;gap:10px}.filter-row{flex-direction:column;align-items:stretch;width:100%}.filter-row select, .filter-row input[type="date"]{padding:10px 14px;font-size:0.95rem}.filter-count{margin-left:0;font-size:0.9rem}.table-wrapper{max-height:400px}td, th{padding:6px 8px;font-size:0.75rem}th{font-size:0.65rem;padding:6px 8px}.battery-bar{width:28px;height:10px}.battery-text{font-size:0.7rem;min-width:24px}.battery-bar-wrapper{gap:4px}.battery-text small{font-size:0.6rem}.address-cell{min-width:160px;font-size:0.7rem}.gmaps-btn{padding:8px 12px;font-size:0.8rem}}@media (max-width:480px){.container{padding:8px}.app-header h1{font-size:1.05rem}.app-header .logo-area svg{width:24px;height:24px}#mapid{height:45vh;min-height:260px}.presets-grid{gap:6px}.preset-btn{padding:9px 10px;font-size:0.9rem;min-width:44px}.preset-delete{padding:0 8px;font-size:1.1rem}.status-chip{padding:12px 14px}.status-chip .status-value{font-size:1rem}td:nth-child(1), th:nth-child(1), td:nth-child(2), th:nth-child(2){display:none}td, th{padding:5px 6px;font-size:0.7rem}th{font-size:0.6rem}.battery-bar{width:22px;height:8px}.battery-text{font-size:0.65rem}.address-cell{min-width:140px;font-size:0.65rem}.gmaps-btn{padding:7px 10px;font-size:0.75rem}}