:root{--teal: #0ea5a8;--teal-dark: #0c8b8e;--teal-light: #e6f7f7;--orange: #F26522;--white: #ffffff;--bg: #f0f4f8;--surface: #ffffff;--text: #1a2332;--text-muted: #64748b;--text-light: #94a3b8;--green: #10b981;--green-bg: #ecfdf5;--warn-color: #f59e0b;--warn-bg: #fffbeb;--danger-color:#ef4444;--danger-bg: #fef2f2;--border: #e2e8f0;--shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);--shadow: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 12px 40px rgba(0,0,0,.14);--radius: 10px;--radius-sm: 6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.brand-text-fallback{align-items:center;justify-content:center;font-size:22px;font-weight:600}.brand-vega{color:var(--teal);font-weight:800}.brand-ent{color:var(--text-muted);font-weight:400}.dashboard-page{min-height:100vh;background:var(--bg)}.dashboard-page:before{content:"";display:block;height:220px;background:linear-gradient(135deg,#0ea5a8,#0c8b8e,#0a7275);position:absolute;top:0;left:0;right:0;z-index:0}.dashboard-container{position:relative;z-index:1;max-width:1440px;margin:0 auto;padding:0 24px 32px}.dashboard-topbar{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:16px 0 0}.topbar-username{color:#ffffffd9;font-size:13px;font-weight:600;letter-spacing:.2px}.btn-logout{padding:6px 18px;background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.4);border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s,border-color .2s;letter-spacing:.2px}.btn-logout:hover{background:#ffffff47;border-color:#ffffffb3}.dashboard-header{text-align:center;padding:8px 0 28px}.dashboard-title{font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}.brand-section{display:flex;justify-content:center;align-items:center;margin-bottom:4px;min-height:40px}.dashboard-logo{max-height:38px;max-width:180px;object-fit:contain;background:#fff;border-radius:8px;padding:5px 14px}.location-subtitle{font-size:13px;color:#fffc;letter-spacing:1px;margin-top:4px;font-weight:500}.dashboard-content{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 22px 24px;margin-bottom:20px}.status-bar{display:flex;align-items:center;gap:10px;margin-bottom:20px}.live-badge{display:inline-flex;align-items:center;gap:6px;background:var(--green-bg);border:1px solid #6ee7b7;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:800;color:#065f46;letter-spacing:1.2px;text-transform:uppercase}.live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:livePulse 1.6s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(1.5)}}.btn-refresh{padding:5px 16px;background:var(--green);color:var(--white);border:none;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:background .2s,opacity .2s}.btn-refresh:hover:not(:disabled){background:#0ca678}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.upload-widget{flex:1;min-width:320px}.upload-dropzone{position:relative;padding:16px;border:2px dashed rgba(255,255,255,.2);border-radius:8px;background:#ffffff05;transition:all .2s ease;cursor:pointer}.upload-dropzone:hover{border-color:#fff6;background:#ffffff0a}.upload-dropzone.active{border-color:#60a5fa;background:#60a5fa1a}.upload-input{display:none}.upload-prompt{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;text-align:center}.upload-icon{font-size:20px}.upload-text{font-size:13px;color:#ffffffe6}.upload-text strong{color:#60a5fa}.upload-hint{font-size:11px;color:#ffffff80}.file-list{margin-top:12px;padding:8px;background:#0003;border-radius:6px}.file-item{display:flex;align-items:center;gap:10px;padding:8px;background:#ffffff0d;border-radius:6px;margin-bottom:6px;font-size:12px}.file-item:last-of-type:not(:has(+button)){margin-bottom:12px}.file-icon{font-size:16px}.file-name{color:#ffffffe6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#ffffff80;font-size:11px}.file-remove{padding:4px 8px;background:#ef444433;color:#ef4444;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:700;transition:background .2s}.file-remove:hover:not(:disabled){background:#ef444466}.file-remove:disabled{opacity:.5;cursor:not-allowed}.btn-upload-submit{width:100%;padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s,opacity .2s}.btn-upload-submit:hover:not(:disabled){background:#2563eb}.btn-upload-submit:disabled{opacity:.5;cursor:not-allowed}.upload-results{margin-top:12px;padding:8px;background:#0003;border-radius:6px;max-height:200px;overflow-y:auto}.result-item{display:flex;gap:8px;padding:8px;border-radius:4px;margin-bottom:6px;font-size:12px}.result-item:last-child{margin-bottom:0}.result-item.success{background:#10b98126;border-left:3px solid #10b981;color:#d1fae5}.result-item.error{background:#ef444426;border-left:3px solid #ef4444;color:#fee2e2}.result-icon{font-weight:700;flex-shrink:0}.result-text{flex:1}.result-text strong{display:block;color:#fffffff2}.result-text small{opacity:.8}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:15px}.channels-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:4px 0}@media (max-width: 1200px){.channels-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 860px){.channels-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.channels-grid{grid-template-columns:1fr}}@media (max-width: 860px){.dashboard-title{font-size:1.35rem}}@media (max-width: 520px){.dashboard-title{font-size:1.1rem}}.channel-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:transform .18s,box-shadow .18s}.channel-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.card-header{padding:12px 14px 10px;display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--teal),var(--teal-dark))}.card-header.ok{background:linear-gradient(135deg,#10b981,#059669)}.card-header.warn{background:linear-gradient(135deg,#f59e0b,#d97706)}.card-header.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.channel-number{min-width:30px;height:30px;background:#ffffff38;border:1.5px solid rgba(255,255,255,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:800;font-size:13px;flex-shrink:0}.channel-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.channel-label{font-size:9px;color:#ffffffb8;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.channel-name{font-size:14px;color:var(--white);font-weight:700;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-body{padding:8px 14px 12px}.metrics-grid{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:baseline;gap:16px;margin-bottom:8px}.metric-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:3px}.metric-label{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:18px;font-weight:700;line-height:1.2;color:var(--text)}.metric-value.danger{color:var(--danger-color)}.metric-value.warn{color:var(--warn-color)}.metric-value.ok{color:var(--green)}.metric-value-litres,.metric-value-distance{font-size:16px;font-weight:700;line-height:1.2;color:var(--text)}.metric-divider{width:1px;height:28px;background:var(--border)}.progress-bar-container{margin:10px 0 8px}.progress-bar-bg{width:100%;height:8px;background:var(--border);border-radius:99px;overflow:hidden;box-shadow:inset 0 1px 2px #0000000d}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--green));border-radius:99px;transition:width .3s ease,background .3s ease}.progress-bar-fill.danger{background:linear-gradient(90deg,var(--danger-color),#dc2626)}.progress-bar-fill.warn{background:linear-gradient(90deg,var(--warn-color),#d97706)}.progress-bar-fill.ok{background:linear-gradient(90deg,var(--green),#059669)}.capacity-row,.updated-row{font-size:12px;color:var(--text-muted);margin-bottom:3px;line-height:1.5}.capacity-value{font-weight:600;color:var(--text)}.level-bar-row{display:flex;align-items:center;gap:8px;margin-top:10px}.level-bar-container{flex:1;background:var(--border);border-radius:99px;height:6px;overflow:hidden}.level-bar{height:100%;border-radius:99px;transition:width .6s ease}.level-bar.ok{background:var(--green)}.level-bar.warn{background:var(--warn-color)}.level-bar.danger{background:var(--danger-color)}.level-pct{font-size:11px;font-weight:700;min-width:34px;text-align:right;white-space:nowrap}.level-pct.ok{color:var(--green)}.level-pct.warn{color:var(--warn-color)}.level-pct.danger{color:var(--danger-color)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:var(--surface);border-radius:14px;box-shadow:var(--shadow-lg);width:100%;max-width:880px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:var(--white)}.modal-title{font-size:16px;font-weight:700;letter-spacing:.2px}.modal-subtitle{font-size:12px;opacity:.8;margin-top:3px}.modal-close{background:#ffffff2e;border:none;color:var(--white);font-size:18px;line-height:1;width:28px;height:28px;border-radius:50%;cursor:pointer;flex-shrink:0;transition:background .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#ffffff52}.modal-toolbar{padding:14px 24px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;background:#fafbfc}.modal-toolbar-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.modal-toolbar-label{font-size:11px;font-weight:700;color:var(--text-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.modal-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text);background:var(--white);cursor:pointer;outline:none;transition:border-color .18s,box-shadow .18s}.modal-select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0ea5a81f}.btn-download{padding:6px 18px;background:var(--teal);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;transition:background .18s;white-space:nowrap}.btn-download:hover:not(:disabled){background:var(--teal-dark)}.btn-download:disabled{opacity:.45;cursor:not-allowed}.modal-record-count{font-size:12px;color:var(--text-light);margin-left:2px}.modal-date-range{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.modal-date-input{padding:5px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;background:var(--white)}.modal-date-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0ea5a81f}.modal-table-wrap{overflow:auto;flex:1;padding:0 24px 20px}.modal-empty{text-align:center;padding:48px;color:var(--text-muted)}.history-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:16px}.history-table th{background:var(--teal);color:var(--white);padding:10px 14px;text-align:left;font-weight:600;font-size:12px;letter-spacing:.3px;white-space:nowrap;position:sticky;top:0}.history-table th:first-child{border-radius:6px 0 0}.history-table th:last-child{border-radius:0 6px 0 0}.history-table td{padding:9px 14px;border-bottom:1px solid #f1f5f9;color:var(--text)}.history-table tbody tr:hover{background:var(--teal-light)}.history-table tbody tr:last-child td{border-bottom:none}.dash-dl-panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.dash-dl-title{font-size:11px;font-weight:700;color:var(--teal-dark);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;padding-right:16px;border-right:1px solid var(--border)}.dash-dl-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.dash-dl-group{display:flex;align-items:center;gap:6px}.dash-dl-label{font-size:11px;font-weight:700;color:var(--text-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.dash-dl-label--mid{margin-left:6px}.dash-dl-error{width:100%;margin-top:4px;font-size:13px;color:var(--danger-color);background:var(--danger-bg);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:7px 12px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#0ea5a8,#0a7275);padding:20px}.login-wrapper{width:100%;max-width:420px}.login-card{background:var(--white);border-radius:16px;box-shadow:var(--shadow-lg);padding:36px 32px 28px}.brand-header{display:flex;justify-content:center;margin-bottom:12px}.brand-logo{max-height:60px;max-width:180px;object-fit:contain}.login-subtitle{text-align:center;color:var(--text-muted);font-size:14px;font-weight:500;margin-bottom:24px}.alert-error{background:var(--danger-bg);color:var(--danger-color);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:18px;text-align:center}.login-form .form-group{margin-bottom:16px;display:flex;flex-direction:column}.login-form label{font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.login-form input{padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);transition:border-color .2s,box-shadow .2s;outline:none;background:#fafbfc}.login-form input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0ea5a824;background:var(--white)}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{flex:1;padding-right:40px}.btn-eye{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0;display:flex;align-items:center}.btn-eye:hover{color:var(--teal)}.btn-login{width:100%;padding:11px;background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.5px;margin-top:8px;transition:opacity .2s,transform .15s}.btn-login:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{text-align:center;margin-top:20px;font-size:12px;color:var(--text-light)}.btn-upload-data,.btn-upload-records{padding:5px 16px;background:var(--teal);color:var(--white);border:none;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:background .2s,opacity .2s}.btn-upload-data:hover:not(:disabled),.btn-upload-records:hover:not(:disabled){background:var(--teal-dark)}.btn-upload-data:disabled,.btn-upload-records:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-width:600px;width:100%;max-height:80vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--teal),var(--teal-dark))}.modal-header h2{color:var(--white);font-size:18px;font-weight:700;margin:0}.modal-close-btn{background:#fff3;color:var(--white);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.modal-close-btn:hover{background:#ffffff4d}.modal-body{flex:1;overflow-y:auto;padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg)}.upload-dropzone{position:relative;padding:32px 24px;border:2px dashed var(--teal);border-radius:8px;background:var(--teal-light);transition:all .2s ease;cursor:pointer;text-align:center}.upload-dropzone:hover{border-color:var(--teal-dark);background:#0ea5a826}.upload-dropzone.active{border-color:#60a5fa;background:#60a5fa1a;border-style:solid}.upload-dropzone p{color:var(--text);font-size:14px;font-weight:500;margin-bottom:12px}.file-input-label{display:inline-block;padding:8px 16px;background:var(--teal);color:var(--white);border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.file-input-label:hover{background:var(--teal-dark)}.modal-file-list{margin-top:20px}.modal-file-list h4{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.file-list{background:var(--bg);border-radius:6px;padding:8px;max-height:200px;overflow-y:auto}.file-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:6px;font-size:12px}.file-item:last-child{margin-bottom:0}.file-icon{font-size:18px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-muted);font-size:11px;margin-top:2px}.file-remove-btn{padding:4px 8px;background:var(--danger-bg);color:var(--danger-color);border:1px solid #fecaca;border-radius:4px;cursor:pointer;font-size:12px;font-weight:700;transition:all .2s;flex-shrink:0}.file-remove-btn:hover{background:#fee2e2;border-color:#ef4444}.upload-results-container{margin-top:16px}.upload-results-container h4{font-size:13px;font-weight:600;color:var(--text);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.upload-result{display:flex;gap:12px;padding:12px;border-radius:6px;margin-bottom:8px;font-size:12px;border-left:4px solid transparent}.upload-result.success{background:var(--green-bg);border-left-color:var(--green)}.upload-result.error{background:var(--danger-bg);border-left-color:var(--danger-color)}.result-icon{font-weight:700;font-size:16px;flex-shrink:0}.upload-result.success .result-icon{color:var(--green)}.upload-result.error .result-icon{color:var(--danger-color)}.result-info{flex:1}.result-filename{color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-message{color:var(--text-muted);font-size:11px;margin-top:2px}.loading-message,.empty-message{text-align:center;padding:32px 24px;color:var(--text-muted);font-size:14px}.records-table-wrapper{overflow-x:auto}.records-table{width:100%;border-collapse:collapse;font-size:13px}.records-table th{background:var(--teal);color:var(--white);padding:12px;text-align:left;font-weight:600;font-size:12px;letter-spacing:.3px;position:sticky;top:0;white-space:nowrap}.records-table td{padding:11px 12px;border-bottom:1px solid var(--border);color:var(--text)}.records-table tbody tr:hover{background:var(--teal-light)}.records-table tbody tr:last-child td{border-bottom:none}.records-table .filename{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-cell{text-align:center;padding:0!important}.btn-delete-record{padding:6px 10px;background:transparent;border:none;color:var(--danger-color);cursor:pointer;font-size:16px;transition:all .2s;border-radius:4px}.btn-delete-record:hover:not(:disabled){background:var(--danger-bg);transform:scale(1.1)}.btn-delete-record:disabled{opacity:.6;cursor:not-allowed}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--teal);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--teal-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}
