:root{--bg-main:#eef3f8;--bg-sidebar:#fff;--bg-card:#fff;--text-main:#0f172a;--text-sec:#64748b;--red:#f1416c;--red-light:#fff5f8;--yellow:#ffc700;--yellow-light:#fff8dd;--green:#50cd89;--green-light:#e8fff3;--blue:#009ef7;--border:#dbe4ee;--primary:#009ef7;--shadow-sm:0px 8px 24px #0f172a0a;--shadow-md:0px 18px 40px #0f172a14;--font-xs:10px;--font-sm:11px;--font-table:11.75px;--font-ui:12px;--font-base:13px;--font-body:14px;--font-brand:19px;--font-kpi:24px;--font-emphasis:15px;--font-md:16px;--font-section:18px;--font-drawer-title:28px;--font-title:30px;--font-display:34px}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:var(--font-body);background:radial-gradient(circle at top left, #009ef714, transparent 22%), linear-gradient(180deg, #f8fbff 0%, var(--bg-main) 28%, #eaf1f7 100%);color:var(--text-main);margin:0}.app-wrapper{height:100vh;display:flex;overflow:hidden}.toast-stack{z-index:2000;flex-direction:column;gap:10px;width:min(360px,100vw - 32px);display:flex;position:fixed;top:20px;right:20px}.toast-item{color:#f8fafc;background:#0f172af5;border:1px solid #94a3b833;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 14px;display:flex;box-shadow:0 18px 40px #0f172a40}.toast-item.success{background:#065f46f5}.toast-item.error{background:#991b1bf7}.toast-body{flex-direction:column;gap:3px;min-width:0;display:flex}.toast-body strong{font-size:var(--font-base);font-weight:700}.toast-body span{font-size:var(--font-ui);color:#f8fafce0;line-height:1.4}.toast-close-btn{color:inherit;cursor:pointer;opacity:.8;background:0 0;border:none;justify-content:center;align-items:center;padding:2px;display:inline-flex}.toast-close-btn:hover{opacity:1}.sidebar{width:260px;color:var(--text-main);border-right:1px solid var(--border);z-index:10;background:linear-gradient(#fffffffa,#f8fafcfa);flex-direction:column;flex-shrink:0;transition:all .3s;display:flex;box-shadow:12px 0 40px #0f172a0a}.sidebar-brand{font-size:var(--font-brand);border-bottom:1px solid var(--border);letter-spacing:-.03em;align-items:center;gap:12px;padding:28px 26px 24px;font-weight:800;display:flex}.brand-icon{color:var(--primary);filter:drop-shadow(0 6px 14px #009ef72e)}.sidebar-nav{flex-direction:column;flex:1;gap:8px;padding:18px 12px;display:flex}.nav-item{color:var(--text-sec);font-size:var(--font-base);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:14px;align-items:center;gap:12px;padding:12px 15px;font-weight:700;transition:all .2s;display:flex}.nav-item:hover{color:#0f172a;background:#f8fafcf2;box-shadow:inset 0 0 0 1px #bfdbfe73}.nav-item.active{color:#0369a1;background:linear-gradient(135deg,#e0f2fef5,#eff6fff2);box-shadow:inset 0 0 0 1px #7dd3fcb3,0 10px 24px #0ea5e914}.sidebar-separator{background:linear-gradient(90deg, transparent, var(--border), transparent);height:1px;margin:10px 6px}.sidebar-footer{border-top:1px solid var(--border);font-size:var(--font-sm);color:var(--text-sec);padding:20px 30px}.sidebar-footer strong{color:var(--text-main);font-size:var(--font-ui);margin-top:5px;display:block}.sidebar-footer-panel{background:linear-gradient(#f8fafc99,#fffffff2);flex-direction:column;justify-content:center;min-height:72px;display:flex}.sidebar-footer-caption{font-size:var(--font-sm);color:var(--text-sec);margin:0}.sidebar-footer-value{font-size:var(--font-base);color:var(--text-main);margin-top:2px}.sidebar-progress-block{width:100%}.sidebar-progress-label{font-size:var(--font-xs);color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;overflow:hidden}.sidebar-progress-label strong{color:#0f172a;margin:0;display:inline}.sidebar-progress-row{align-items:center;gap:8px;display:flex}.sidebar-progress-track{background:#dbeafe;border-radius:999px;flex:1;height:6px;overflow:hidden}.sidebar-progress-fill{background:linear-gradient(90deg,#38bdf8,#2563eb);height:100%;transition:width .4s}.sidebar-progress-count{font-size:var(--font-xs);color:#2563eb;font-weight:700}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:150;background:#ffffffb8;border-bottom:1px solid #dbe4eee6;justify-content:space-between;align-items:center;height:70px;padding:0 30px;display:flex;position:relative}.search-container{background:#f8fbfff2;border:1px solid #cbd5e1eb;border-radius:16px;align-items:center;gap:10px;min-width:500px;padding:10px 16px;display:flex;box-shadow:0 8px 24px #0f172a0a}.topbar-spacer{flex:auto;min-width:0}.topbar-connectivity-controls{z-index:160;flex:auto;align-items:center;gap:12px;min-width:0;margin-right:18px;display:flex;position:relative}.topbar-connectivity-controls .toolbar-search-field{background:#fffffff5;flex:auto;min-width:320px}.topbar-connectivity-controls .toolbar-cluster{flex-wrap:nowrap}.topbar-connectivity-controls .toolbar-select{min-width:180px}.topbar-connectivity-controls .toolbar-month-btn{min-width:210px}.search-container:focus-within{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f61f}.search-icon{color:#94a3b8}.search-container input{font-family:inherit;font-size:var(--font-base);width:100%;color:var(--text-main);background:0 0;border:none;outline:none}.search-divider{background:#cbd5e1e6;width:1px;height:20px;margin:0 5px}.search-clear-btn{color:var(--text-sec);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:all .15s;display:flex}.search-clear-btn:hover{color:var(--text-main);background:#0f172a14}.province-inline-icon{vertical-align:text-bottom;margin-right:6px;display:inline-block}.inline-hidden-file-input{display:none}.province-select{border:1px solid var(--border);font-family:inherit;font-size:var(--font-base);color:var(--text-main);cursor:pointer;background:#fff;border-radius:6px;outline:none;min-width:180px;padding:6px 12px;font-weight:600}.province-select:disabled{opacity:.5;cursor:not-allowed}.topbar-actions{align-items:center;gap:12px;display:flex}.action-btn{font-size:var(--font-ui);cursor:pointer;border:none;border-radius:14px;align-items:center;gap:8px;padding:9px 15px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 10px 24px #0f172a0a}.action-btn.export-btn{color:var(--text-main);background:#ffffffeb;border:1px solid #cbd5e1f2}.action-btn.export-btn:hover{background:#fff;border-color:#93c5fd;transform:translateY(-1px)}.action-btn.export-btn:disabled{opacity:.7;cursor:wait}.action-btn.refresh-btn{color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb)}.action-btn.refresh-btn:hover{filter:brightness(1.03);transform:translateY(-1px)}.action-btn.refresh-btn:disabled{opacity:.7;cursor:wait}.action-btn:disabled{filter:none;box-shadow:none;transform:none}.action-btn.edit-btn:disabled{opacity:.65;cursor:wait}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.workspace{flex:1;min-width:0;padding:20px 22px;overflow:hidden auto}.kpi-overview{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:25px;display:grid}.kpi-card{box-shadow:var(--shadow-sm);cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;flex-direction:row;justify-content:center;align-items:center;gap:10px;min-width:0;padding:13px 12px;transition:all .2s;display:flex}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card.normal.active{border-color:var(--green);background:var(--green-light)}.kpi-card.warning.active{border-color:var(--yellow);background:var(--yellow-light)}.kpi-card.danger.active{border-color:var(--red);background:var(--red-light)}.kpi-value{font-size:var(--font-kpi);flex-shrink:0;font-weight:800}.kpi-label{font-size:var(--font-xs);color:var(--text-sec);text-transform:uppercase;letter-spacing:.2px;font-weight:700;line-height:1.2}.kpi-card.normal .kpi-value{color:var(--green)}.kpi-card.warning .kpi-value{color:var(--yellow)}.kpi-card.danger .kpi-value{color:var(--red)}.kpi-card.obsolete{color:#5b21b6;background:#f5f3ff;border-color:#ddd6fe}.kpi-card.obsolete .kpi-value{color:#5b21b6}.kpi-card.obsolete.active{color:#fff;background:#4c1d95;border-color:#4c1d95}.kpi-card.obsolete.active .kpi-label,.kpi-card.obsolete.active .kpi-value{color:#fff}.filter-pills{align-items:center;gap:10px;margin-bottom:25px;display:flex}.filter-pills-tight{margin-bottom:12px}.filters-toolbar{background:linear-gradient(#fffffff5,#f8fafceb);border:1px solid #e2e8f0f2;border-radius:18px;align-items:center;gap:14px;min-width:0;margin-bottom:18px;padding:9px 14px;display:flex;box-shadow:0 12px 28px #0f172a0a}.filters-toolbar-group{flex:auto;align-items:center;gap:8px;min-width:0;display:flex}.filters-toolbar-group-primary{flex:1.35 1 0}.filters-toolbar-group-maintainers{flex:1 1 0}.filters-toolbar-label{white-space:nowrap;font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;color:#64748b;flex:none;margin-right:0;font-weight:800}.filters-toolbar-rail{scrollbar-width:thin;scrollbar-color:#94a3b88c transparent;flex-wrap:nowrap;align-items:center;gap:6px;min-width:0;padding:2px 2px 4px;display:flex;overflow:auto hidden}.filters-toolbar-rail::-webkit-scrollbar{height:6px}.filters-toolbar-rail::-webkit-scrollbar-thumb{background:#94a3b873;border-radius:999px}.filters-toolbar-divider{background:linear-gradient(#e2e8f000,#cbd5e1d9,#e2e8f000);align-self:stretch;width:1px;margin:2px 0}.filter-label{font-size:var(--font-base);color:var(--text-sec);margin-right:5px;font-weight:600}.filter-empty-label{font-size:var(--font-base);color:#94a3b8;font-weight:600}.pill{border:1px solid var(--border);color:var(--text-sec);font-size:var(--font-ui);cursor:pointer;background:#fff;border-radius:20px;padding:6px 14px;font-weight:600;transition:all .2s}.pill-compact{white-space:nowrap;font-size:var(--font-sm);flex:none;min-height:32px;padding:4px 11px}.pill:hover{border-color:var(--text-main);color:var(--text-main)}.pill.active{background:var(--text-main);color:#fff;border-color:var(--text-main)}.pill-icon{align-items:center;gap:5px;display:inline-flex}.pill-icon-svg{flex-shrink:0;margin-right:0}.pill-count{opacity:.62;font-size:var(--font-xs);margin-left:3px;font-weight:800}.supervision-table-wrap{background:#fffffffa;border:1px solid #dbe4eef2;border-radius:22px;margin-top:10px;overflow:auto;box-shadow:0 18px 44px #0f172a0d}.supervision-table-wrap.is-editing{z-index:30;position:relative;overflow:visible}.pulse-data-table{border-collapse:separate;border-spacing:0;width:100%;min-width:980px;box-shadow:none;background:0 0;border:none;border-radius:0;margin-top:0}.pulse-data-table th,.pulse-data-table td{text-align:left;font-size:var(--font-table);color:var(--text-main);vertical-align:middle;background:0 0;border-bottom:1px solid #f1f5f9f5;padding:8px 14px}.pulse-data-table th{z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-sec);text-transform:uppercase;letter-spacing:.08em;font-weight:800;font-size:var(--font-xs);background:#f8fafcf5;position:sticky;top:0}.table-row{background:0 0;transition:background .16s,box-shadow .16s}.table-row:hover{background:linear-gradient(90deg,#f8fafcf5,#eff6ffb8)}.table-row-interactive{cursor:pointer}.table-row.severity-s1 td:first-child{border-left:4px solid var(--red)}.table-row.severity-s2 td:first-child{border-left:4px solid var(--yellow)}.table-row.severity-normal td:first-child{border-left:4px solid var(--green)}.table-gvr{color:var(--text-sec);white-space:nowrap;font-family:monospace;font-weight:600}.table-name{font-weight:800;font-size:var(--font-base);white-space:nowrap;text-overflow:ellipsis;max-width:0;overflow:hidden}.col-drag{width:40px}.col-gvr{width:8%}.col-station{width:19%}.col-connection{width:12%}.col-assignment{width:15%}.col-state{width:34%}.col-updated{white-space:nowrap;width:12%}.drag-overlay-table{opacity:.92;width:1000px;box-shadow:0 28px 72px #0f172a3d}.table-skeleton-row td{padding-top:12px;padding-bottom:12px}.table-skeleton-block{background:linear-gradient(90deg,#e2e8f0 0%,#f8fafc 50%,#e2e8f0 100%) 0 0/200% 100%;border-radius:999px;width:100%;max-width:180px;height:14px;animation:1.4s ease-in-out infinite skeleton-shimmer;display:inline-block}.table-skeleton-block.is-short{max-width:72px}.table-skeleton-block.is-medium{max-width:120px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.hover-popup-container{box-sizing:border-box;z-index:9999;pointer-events:auto;background:#fff;border:1px solid #cbd5e1f2;border-radius:18px;flex-direction:column;width:min(780px,100vw - 360px);min-width:560px;display:flex;position:fixed;top:112px;bottom:24px;right:24px;overflow:hidden;box-shadow:0 28px 80px #0f172a38}.hover-popup-header{background:linear-gradient(#fff,#f8fafc);border-bottom:1px solid #e2e8f0f2;flex:none;justify-content:space-between;align-items:flex-start;gap:14px;padding:14px 18px 12px;display:flex}.hover-popup-heading{min-width:0}.hover-popup-heading .station-title{white-space:normal;max-width:100%;margin:0}.hover-popup-meta{color:#64748b;font-size:var(--font-sm);flex-wrap:wrap;gap:8px 14px;margin-top:8px;font-weight:700;display:flex}.hover-popup-body{flex:auto;min-height:0;padding:12px 18px;overflow-y:auto}.hover-popup-body .tank-detail-box{margin-bottom:10px;padding:11px 14px}.hover-popup-summary-grid{grid-template-columns:minmax(0,1fr) minmax(220px,.52fr);align-items:start;gap:10px;display:grid}.hover-popup-summary-box{height:auto;min-height:0}.hover-popup-alerts-list{flex-direction:column;gap:6px;display:flex}.hover-popup-alerts-list .alert-item{background:#fff1f2;border-radius:10px;align-items:center;width:100%;min-height:28px;padding:6px 9px}.hover-popup-alerts-list .alert-text{font-size:var(--font-sm);overflow-wrap:anywhere;line-height:1.2}.hover-popup-critical-box{background:snow}.hover-popup-critical-list{flex-direction:column;gap:6px;display:flex}.hover-popup-critical-list .rupture-focus-item{color:var(--red);font-size:var(--font-sm);background:#fff1f2;border-radius:8px;padding:5px 8px;line-height:1.2}.hover-popup-tank-box{overflow:visible}.hover-popup-tank-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.equipement-row.hover-popup-tank-row{background:#fff;border:1px solid #e2e8f0e6;border-radius:10px;grid-template-columns:minmax(82px,auto) minmax(0,1fr);align-items:flex-start;gap:8px;padding:8px;display:grid}.equipement-row.hover-popup-tank-row:last-child{border-bottom:1px solid #e2e8f0e6;padding-bottom:8px}.hover-popup-tank-row .cuve-info-col{flex-flow:wrap;justify-content:flex-end;align-items:center;gap:5px}.hover-popup-tank-row .cuve-badge{white-space:normal;max-width:100%;line-height:1.15}.hover-popup-tank-row .cuve-metric,.hover-popup-tank-row .cuve-status{min-height:24px;font-size:var(--font-xs);background:#f8fafc;border-radius:7px;align-items:center;padding:3px 7px;font-weight:800;line-height:1.15;display:inline-flex}.hover-popup-tank-row .cuve-metric-critical,.hover-popup-tank-row .status-danger{background:#fff1f2}.hover-popup-tank-row .cuve-metric-autonomy{background:#fffbeb}.hover-popup-comment-box{background:#f8fafc;margin-bottom:0}.hover-popup-comment-text{white-space:pre-wrap;color:#0f172a;font-size:var(--font-sm);font-weight:650;line-height:1.35}.hover-popup-comment-meta{border-top:1px dashed var(--border);color:#64748b;font-size:var(--font-sm);margin-top:8px;padding-top:8px;font-weight:700}.station-detail-backdrop{z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a61;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.station-detail-modal{background:radial-gradient(circle at 100% 0,#3b82f60f,#0000 30%),linear-gradient(#fffffffa,#f8fafcfa);border:1px solid #dbe4eef2;border-radius:24px;flex-direction:column;width:min(1040px,100vw - 48px);max-height:calc(100vh - 48px);display:flex;overflow:hidden;box-shadow:0 32px 84px #0f172a38}.station-detail-header{border-bottom:1px solid #e2e8f0e6;justify-content:space-between;align-items:flex-start;gap:20px;padding:24px 26px 18px;display:flex}.station-detail-header-main{min-width:0}.station-detail-kicker{font-size:var(--font-sm);letter-spacing:.1em;text-transform:uppercase;color:#64748b;margin-bottom:8px;font-weight:800}.station-detail-header h3{font-size:var(--font-title);letter-spacing:-.03em;color:#0f172a;margin:0;line-height:1.05}.station-detail-subline{font-size:var(--font-base);color:#475569;flex-wrap:wrap;gap:10px 18px;margin-top:12px;font-weight:600;display:flex}.station-detail-header-actions{flex-shrink:0;align-items:flex-start;gap:10px;display:flex}.station-detail-close-btn{color:#334155;cursor:pointer;background:#ffffffeb;border:1px solid #cbd5e1f2;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .18s;display:inline-flex}.station-detail-close-btn:hover{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.station-detail-body{grid-template-columns:minmax(300px,.9fr) minmax(420px,1.25fr);gap:18px;padding:20px 26px 26px;display:grid;overflow:auto}.station-detail-column{min-width:0}.station-detail-panel{height:100%;margin-bottom:0}.station-detail-comment-panel{grid-column:1/-1;margin-bottom:0}.station-detail-empty{font-size:var(--font-base);color:var(--text-sec);padding:14px 0 2px;font-weight:600}.station-detail-sensor-list{flex-direction:column;gap:10px;display:flex}.station-detail-sensor-row{border-bottom:1px dashed var(--border);grid-template-columns:minmax(110px,140px) minmax(0,1fr);align-items:start;gap:14px;padding:10px 0;display:grid}.station-detail-sensor-row:last-child{border-bottom:none;padding-bottom:0}.station-detail-sensor-name{padding-top:2px}.station-detail-sensor-metrics{flex-wrap:wrap;gap:8px 12px;min-width:0;display:flex}.station-detail-sensor-metrics .cuve-metric,.station-detail-sensor-metrics .cuve-status{white-space:normal}.station-detail-sensor-status{max-width:100%}.station-comment-textarea{resize:vertical;width:100%;min-height:132px;font:inherit;font-size:var(--font-body);color:#0f172a;background:#fffffff5;border:1px solid #cbd5e1f2;border-radius:16px;padding:14px 16px;line-height:1.55;transition:border-color .18s,box-shadow .18s}.station-comment-textarea:focus{border-color:#93c5fd;outline:none;box-shadow:0 0 0 4px #3b82f61f}.station-comment-textarea:disabled{color:#64748b;background:#f8fafc}.station-comment-footer{justify-content:space-between;align-items:center;gap:16px;margin-top:14px;display:flex}.station-comment-meta{min-width:0;font-size:var(--font-ui);color:#64748b;font-weight:600}.station-comment-meta strong{color:#334155}.station-comment-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.station-comment-secondary-btn,.station-comment-primary-btn{font-size:var(--font-base);cursor:pointer;border-radius:999px;padding:10px 16px;font-weight:700;transition:all .18s}.station-comment-secondary-btn{color:#475569;background:#fff;border:1px solid #cbd5e1f2}.station-comment-primary-btn{color:#fff;background:#0f172a;border:1px solid #0f172a}.station-comment-secondary-btn:hover:not(:disabled){color:#0f172a;border-color:#94a3b8}.station-comment-primary-btn:hover:not(:disabled){background:#1e293b;border-color:#1e293b}.station-comment-secondary-btn:disabled,.station-comment-primary-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-controls{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-top:12px;padding:12px 20px;display:flex}.page-info{font-size:var(--font-ui);color:var(--text-main)}.page-total-count{color:var(--text-sec);margin-left:8px}.page-sort-indicator{color:#475569;margin-left:10px;font-weight:700}.table-drag-cell{vertical-align:middle;text-align:center;width:40px;padding:0 10px}.table-diagnostic{font-size:var(--font-ui);white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.table-diagnostic.is-normal{color:var(--text-sec)}.table-diagnostic.is-alert{color:var(--text-main)}.diagnostic-inline{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;min-width:0;max-width:100%;font-weight:500;display:inline-flex;overflow:hidden}.diagnostic-empty{color:var(--text-sec)}.table-last-poll{font-size:var(--font-sm);color:var(--text-sec);white-space:nowrap;font-weight:700}.table-last-poll-content{justify-content:space-between;align-items:center;gap:8px;width:100%;min-width:0;display:inline-flex}.table-last-poll-content span{text-overflow:ellipsis;min-width:0;overflow:hidden}.station-refresh-btn{color:#2563eb;cursor:pointer;background:#ffffffeb;border:1px solid #cbd5e1f2;border-radius:8px;flex:0 0 28px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .16s,border-color .16s,color .16s,transform .16s;display:inline-flex}.station-refresh-btn:hover:not(:disabled){background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px)}.station-refresh-btn:disabled{opacity:.65;cursor:wait;transform:none}.colored-meta{color:var(--meta-color,var(--text-main));font-weight:600}.table-assignment,.table-connection{min-width:0}.table-connection-badge{min-width:92px;max-width:100%;font-size:var(--font-xs);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;padding:4px 9px;font-weight:800;line-height:1;display:inline-flex}.table-connection-badge.connection-fo{color:#2563eb;background:#dbeafee6}.table-connection-badge.connection-jovena{color:#7c3aed;background:#ede9feeb}.table-connection-badge.connection-number{color:#c2410c;background:#ffedd5eb}.table-connection-badge.connection-other{color:#0f766e;background:#ccfbf1eb}.table-connection-badge.connection-unknown{color:#64748b;background:#e2e8f0eb}.table-assignment-inline{white-space:nowrap;align-items:center;gap:12px;min-width:0;max-width:100%;display:inline-flex}.table-assignment-main{grid-template-columns:18px minmax(0,1fr);align-items:center;column-gap:10px;min-width:0;max-width:100%;display:grid;overflow:hidden}.table-assignment-icon{flex:0 0 18px;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.table-assignment-label{text-overflow:ellipsis;min-width:0;overflow:hidden}.table-assignment-owner{min-width:42px;font-weight:700;font-size:var(--font-sm);letter-spacing:.04em;background:#94a3b81f;border-radius:999px;flex:none;justify-content:center;align-items:center;padding:4px 10px;line-height:1;display:inline-flex}.table-assignment-edit{z-index:40;flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:relative}.table-state{white-space:nowrap;min-width:0}.table-state-pill{vertical-align:middle;margin-right:10px}.table-diagnostic-inline{vertical-align:middle;max-width:calc(100% - 170px);display:inline-block}.page-btn{border:1px solid var(--border);font-size:var(--font-ui);color:var(--text-main);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-weight:600;transition:all .2s;display:flex}.page-btn:not(:disabled):hover{background:#f8fafc;border-color:#cbd5e1}.page-btn:disabled{opacity:.5;cursor:not-allowed;background:#f8fafc}.station-card{box-shadow:var(--shadow-sm);border-top:4px solid var(--border);background:#fff;border-radius:12px;padding:16px;transition:transform .2s}.station-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.station-card.severity-s1{border-top-color:var(--red)}.station-card.severity-s2{border-top-color:var(--yellow)}.station-card.severity-normal{border-top-color:var(--green)}.station-header{justify-content:space-between;margin-bottom:20px;display:flex}.station-header-compact{margin-bottom:10px}.station-info h2{font-size:var(--font-md);color:var(--text-main);margin:0 0 2px;font-weight:800}.station-title{font-size:var(--font-md);color:var(--text-main);margin:0;font-weight:800}.gvr-block{font-size:var(--font-ui);color:var(--text-sec);gap:10px;display:flex}.gvr-block-tight{margin-top:4px}.status-pill{font-size:var(--font-sm);border-radius:6px;height:fit-content;padding:5px 10px;font-weight:700}.status-pill.s1{background:var(--red-light);color:var(--red)}.status-pill.s2{background:var(--yellow-light);color:#d35400}.status-pill.normal{background:var(--green-light);color:#1e8b4c}.status-pill-inline{display:inline-block}.status-pill-obsolete{color:#fff;background:#475569}.status-pill-rupture{color:#fff;background:#ef4444;animation:2s infinite pulse}.tank-detail-box{border:1px solid var(--border);background:#fcfcfc;border-radius:8px;margin-bottom:12px;padding:15px}.tank-detail-tight{margin-bottom:10px}.tank-detail-flush{margin-bottom:0}.box-title{font-size:var(--font-sm);text-transform:uppercase;color:var(--text-sec);margin-bottom:10px;font-weight:700}.box-title-inline{align-items:center;display:flex}.title-icon-inline{margin-right:6px}.alerts-list{flex-direction:column;gap:8px;display:flex}.alert-item{align-items:flex-start;gap:8px;display:flex}.alert-text{font-size:var(--font-base);font-weight:600;line-height:1.4}.alert-text.s1-text{color:var(--red)}.alert-text.s2-text{color:#d35400}.rupture-focus-box{border-top:1px dashed var(--border);margin-top:12px;padding-top:12px}.rupture-focus-title{font-size:var(--font-sm);letter-spacing:.06em;text-transform:uppercase;color:var(--red);margin-bottom:6px;font-weight:800}.rupture-focus-list{flex-direction:column;gap:4px;display:flex}.rupture-focus-item{font-size:var(--font-ui);color:var(--text-main);font-weight:700}.equipement-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.equipement-row:last-child{border-bottom:none;padding-bottom:0}.cuve-badge{background:var(--bg-main);font-size:var(--font-ui);border-radius:4px;padding:4px 8px;font-weight:700}.cuve-info-col{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.cuve-metric{font-size:var(--font-ui);font-weight:600;line-height:1.35}.cuve-metric-volume{color:var(--text-main)}.cuve-metric-critical{color:var(--red)}.cuve-metric-autonomy{color:#92400e}.cuve-status{font-size:var(--font-sm);color:var(--text-sec);font-weight:600}.cuve-status.status-danger{color:var(--red)}.tank-detail-note{border-top:1px dashed var(--border);font-size:var(--font-sm);color:var(--text-sec);align-items:center;gap:6px;margin-top:12px;padding-top:12px;font-weight:600;display:flex}.empty-state{text-align:center;background:#fff;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state h3{color:var(--text-main);margin:15px 0 5px}.empty-state p{color:var(--text-sec);font-size:var(--font-body);margin:0}.empty-state-icon.ok{color:#50cd89}.view-header{margin-bottom:30px}.view-header h2{font-size:var(--font-kpi);margin:0 0 5px;font-weight:800}.view-header p{color:var(--text-sec);font-size:var(--font-body);margin:0}.stats-premium-view{background:radial-gradient(circle at 100% 0,#10b98114,#0000 24%),linear-gradient(#ffffffeb,#f4f7fbfa);border:1px solid #dbe4eef5;border-radius:24px;padding:22px;box-shadow:0 24px 60px #0f172a0d}.stats-premium-view .view-header h2{font-size:var(--font-display);letter-spacing:-.03em;line-height:1.05}.stats-premium-view .view-header p{color:#667085;max-width:780px}.solutions-grid{max-width:900px}.solution-card{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:20px;padding:25px}.sol-card-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:15px;padding-bottom:15px;display:flex}.sol-card-header h3{font-size:var(--font-section);margin:0}.solution-steps{font-size:var(--font-body);color:#4b5563;margin:0;padding-left:20px;line-height:1.8}.chart-card{border:1px solid var(--border);background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 15px #00000005}.chart-card h3{font-size:var(--font-md);color:var(--text-main);text-transform:uppercase;letter-spacing:.5px;margin:0 0 30px;font-weight:800}.stats-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:20px;display:grid}.stats-chart-card{border-radius:22px;box-shadow:0 18px 44px #0f172a0d}.stats-chart-card-wide{margin-bottom:0}.chart-frame{background:linear-gradient(#f8fafcbf,#ffffffeb);border:1px solid #e2e8f0e6;border-radius:18px;width:100%}.chart-frame-medium{height:300px}.chart-frame-tall{height:400px}.province-legend-item{background:#ffffffe0;border:1px solid #dbe4eef5;border-radius:18px;align-items:center;gap:10px;padding:14px 16px;display:flex;box-shadow:0 12px 28px #0f172a0a}.pleg-dot{border-radius:999px;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 0 4px #ffffffe6}.pleg-name{font-size:var(--font-base);color:#0f172a;align-items:center;min-width:0;font-weight:700;display:inline-flex}.pleg-count{color:#475569;font-size:var(--font-ui);white-space:nowrap;margin-left:auto;font-weight:700}.pleg-alerts{color:#b91c1c;font-size:var(--font-sm);white-space:nowrap;background:#fee2e2;border-radius:999px;padding:5px 8px;font-weight:800}.settings-card{max-width:800px;margin:0 auto}.settings-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.settings-table{border-collapse:collapse;text-align:left;width:100%;font-size:var(--font-body)}.settings-table th,.settings-table td{border-bottom:1px solid var(--border);padding:9px 10px}.settings-table th{color:var(--text-sec);border-bottom-width:2px}.settings-name-cell{font-weight:600}.settings-input{border:1px solid var(--border);border-radius:10px;width:100%;padding:7px 10px;font-family:inherit}.settings-color-input{cursor:pointer;width:40px;height:30px;padding:0}.settings-color-dot{background:var(--dot-color,#cbd5e1);border:2px solid #0000001a;border-radius:50%;width:16px;height:16px;display:inline-block}.settings-status-chip{font-size:var(--font-ui);border-radius:12px;padding:4px 8px;font-weight:600}.settings-status-chip.active{color:#10b981;background:#d1fae5}.settings-status-chip.inactive{color:#ef4444;background:#fee2e2}.settings-action-row{justify-content:flex-end;gap:8px;display:flex}.settings-outline-btn,.settings-toggle-btn,.settings-icon-btn{cursor:pointer;font-family:inherit}.settings-outline-btn{border:1px solid var(--border);color:var(--text-main);background:0 0;border-radius:10px;align-items:center;padding:6px 10px;display:inline-flex}.btn-icon-inline{margin-right:4px}.settings-toggle-btn{border:none;border-radius:10px;padding:6px 10px;font-weight:600}.settings-toggle-btn.danger{color:#ef4444;background:#fee2e2}.settings-toggle-btn.success{color:#10b981;background:#d1fae5}.settings-icon-btn{border:none;border-radius:10px;margin-left:6px;padding:6px 12px}.settings-icon-btn.success{color:#fff;background:#10b981}.settings-icon-btn.neutral{color:var(--text-main);background:#f1f5f9}.settings-new-row{background:#f8fafc}.settings-empty{text-align:center;color:var(--text-sec);padding:20px}.align-right{text-align:right}.connectivity-view{background:radial-gradient(circle at 0 0,#009ef714,#0000 28%),linear-gradient(#ffffffe6,#f4f7fbf5);border:1px solid #e4e6efe6;border-radius:24px;min-width:0;padding:18px 20px 20px;box-shadow:0 24px 60px #0f172a0d}.connectivity-view .view-header{margin-bottom:12px}.connectivity-view .view-header h2{font-size:var(--font-title);letter-spacing:-.03em;line-height:1.05}.connectivity-view .view-header p{color:#667085;max-width:760px;font-size:var(--font-body)}.connectivity-toolbar{box-shadow:none;background:0 0;border:0;border-radius:0;flex-wrap:wrap;align-items:center;gap:10px;margin:-2px 0 8px;padding:0;display:flex}.connectivity-subtabs{align-items:center;gap:8px;margin-bottom:14px;display:flex}.connectivity-subtab-btn{color:#667085;font-weight:700;font-size:var(--font-base);cursor:pointer;background:#ffffffc7;border:1px solid #cbd5e1d9;border-radius:999px;padding:9px 15px;transition:all .18s}.connectivity-subtab-btn:hover{color:#0f172a;background:#fff;border-color:#93c5fd}.connectivity-subtab-btn.active{color:#fff;background:linear-gradient(135deg,#1e293b,#334155);border-color:#1e293b;box-shadow:0 10px 24px #1e293b2e}.toolbar-search-field{background:#f8fbff;border:1px solid #cbd5e1eb;border-radius:14px;flex:360px;align-items:center;gap:10px;min-width:260px;height:46px;padding:0 14px;display:flex;box-shadow:inset 0 1px #ffffffbf}.toolbar-search-icon{color:#94a3b8;flex-shrink:0}.toolbar-search-field input{min-width:0;font-family:inherit;font-size:var(--font-base);color:var(--text-main);background:0 0;border:none;outline:none;flex:1}.toolbar-search-clear-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:background .15s,color .15s;display:inline-flex}.toolbar-search-clear-btn:hover{color:#0f172a;background:#0f172a14}.toolbar-search-field:focus-within{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f61f}.toolbar-cluster,.toolbar-action-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.toolbar-select,.toolbar-month-btn{height:46px;font-family:inherit;font-size:var(--font-base);color:#0f172a;background:#fff;border:1px solid #cbd5e1eb;border-radius:14px;padding:0 14px;font-weight:600;box-shadow:0 4px 12px #0f172a0a}.toolbar-select{min-width:170px}.toolbar-select:focus,.toolbar-month-btn:focus{border-color:#93c5fd;outline:none;box-shadow:0 0 0 4px #3b82f61f}.toolbar-month-btn{cursor:pointer;align-items:center;gap:9px;display:inline-flex}.toolbar-month-btn.is-open{border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f61f}.toolbar-btn{border-radius:12px;min-height:40px}.connectivity-kpis{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:12px;display:grid}.connectivity-kpi-card{appearance:none;text-align:left;cursor:pointer;background:linear-gradient(#fffffffa,#f8fafcf5);border:1px solid #e4e6eff2;border-radius:18px;flex-direction:column;gap:6px;padding:13px 16px;transition:transform .16s,border-color .16s,box-shadow .16s,background .16s;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 34px #0f172a0a}.connectivity-kpi-card:before{content:"";background:linear-gradient(90deg,#009ef7,#38bdf8);width:100%;height:3px;position:absolute;inset:0 auto auto 0}.connectivity-kpi-card:hover{border-color:#93c5fdf2;transform:translateY(-1px);box-shadow:0 18px 36px #2563eb1a}.connectivity-kpi-card.active{background:linear-gradient(#eff6fffa,#fffffffa);border-color:#3b82f659;box-shadow:0 18px 38px #2563eb1f}.connectivity-kpi-card.active:before{background:linear-gradient(90deg,#2563eb,#0ea5e9);height:4px}.connectivity-kpi-card span{font-size:var(--font-xs);color:#667085;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.connectivity-kpi-card strong{font-size:var(--font-kpi);color:var(--text-main);line-height:1}.connectivity-import-report{color:#155e75;font-size:var(--font-base);background:linear-gradient(135deg,#effcff,#f8fdff);border:1px solid #bae6fd;border-radius:16px;margin-bottom:14px;padding:12px 14px;box-shadow:0 10px 24px #06b6d414}.recharge-history-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px;display:grid}.recharge-history-card{background:linear-gradient(#fffffffa,#f8fafcf0);border:1px solid #e2e8f0f2;border-radius:18px;flex-direction:column;justify-content:center;gap:6px;min-height:94px;padding:14px 16px;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 32px #0f172a0a}.recharge-history-card:before{content:"";background:linear-gradient(90deg,#94a3b8,#cbd5e1);height:3px;position:absolute;inset:0 0 auto}.recharge-history-card.primary:before{background:linear-gradient(90deg,#2563eb,#0ea5e9)}.recharge-history-card span{color:#667085;font-size:var(--font-sm);letter-spacing:.08em;text-transform:uppercase;font-weight:800}.recharge-history-card strong{color:var(--text-main);font-size:var(--font-kpi);line-height:1}.recharge-history-card small{color:#64748b;min-width:0;font-size:var(--font-ui);text-overflow:ellipsis;white-space:nowrap;font-weight:650;overflow:hidden}.recharge-history-top-row{align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.recharge-history-import-btn{flex:none;min-height:46px}.recharge-history-summary-shell{flex:auto;min-width:0}.recharge-history-summary-tab{color:#475569;cursor:pointer;text-align:left;background:linear-gradient(135deg,#eff6fffa,#fffffffa);border:1px solid #bfdbfed9;border-radius:16px;align-items:center;gap:12px;width:100%;min-height:46px;padding:0 14px;transition:border-color .18s,box-shadow .18s,background .18s;display:flex;box-shadow:0 10px 26px #0f172a0a}.recharge-history-summary-tab:hover,.recharge-history-summary-shell.is-open .recharge-history-summary-tab{border-color:#60a5fab8;box-shadow:0 12px 28px #2563eb14}.history-summary-tab-title{color:#64748b;font-size:var(--font-sm);letter-spacing:.08em;text-transform:uppercase;flex:none;font-weight:850}.recharge-history-summary-tab strong{color:#0f172a;min-width:0;font-size:var(--font-base);white-space:nowrap;line-height:1.1}.history-summary-tab-period{color:#64748b;min-width:0;font-size:var(--font-ui);text-overflow:ellipsis;white-space:nowrap;margin-left:auto;font-weight:750;overflow:hidden}.recharge-history-summary-panel{background:#ffffffeb;border:1px solid #bfdbfec2;border-radius:14px;margin-top:8px;padding:10px 12px}.history-summary-metrics{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:8px;min-width:0;display:flex}.history-summary-metrics span{color:#475569;min-height:26px;font-size:var(--font-ui);white-space:nowrap;background:#ffffffc2;border:1px solid #cbd5e1d1;border-radius:999px;align-items:center;padding:0 10px;font-weight:750;display:inline-flex}.recharge-history-guidance{color:#334155;background:linear-gradient(135deg,#eff6fff5,#fffffff5);border:1px solid #bfdbfebf;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;padding:13px 16px;display:flex}.recharge-history-guidance div:first-child{flex-direction:column;gap:3px;min-width:0;display:flex}.recharge-history-guidance strong{color:#0f172a;font-size:var(--font-base)}.recharge-history-guidance span{font-size:var(--font-ui);font-weight:600;line-height:1.45}.recharge-import-chipset{flex-wrap:wrap;flex:none;justify-content:flex-end;align-items:center;gap:8px;max-width:520px;display:flex}.recharge-import-chipset span{color:#475569;min-height:28px;font-size:var(--font-sm);white-space:nowrap;background:#ffffffe6;border:1px solid #cbd5e1e6;border-radius:999px;align-items:center;padding:0 10px;font-weight:800;display:inline-flex}.history-station-cell,.history-source-detail{flex-direction:column;gap:3px;min-width:0;display:flex}.history-station-cell strong,.history-source-detail strong{color:#0f172a;font-size:var(--font-base);line-height:1.2}.history-station-cell span,.history-source-detail span{color:#64748b;font-size:var(--font-sm);font-weight:600;line-height:1.25}.history-source-badge{min-height:26px;font-size:var(--font-sm);white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;padding:0 10px;font-weight:800;display:inline-flex}.history-source-badge.import{color:#1d4ed8;background:#dbeafe;border:1px solid #93c5fd}.history-source-badge.manual{color:#9a3412;background:#ffedd5;border:1px solid #fdba74}.history-source-badge.mixed{color:#6d28d9;background:#f3e8ff;border:1px solid #c4b5fd}.history-group-row{background:#f8fafcb8}.history-group-row td{border-top:1px solid #cbd5e1a6}.history-line-cell,.history-source-stack{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.history-line-cell span:last-child{color:#475569;font-size:var(--font-ui);font-weight:750}.history-detail-btn{color:#0f172a;min-height:32px;font-size:var(--font-ui);cursor:pointer;background:#fff;border:1px solid #cbd5e1f5;border-radius:10px;padding:0 12px;font-weight:800}.history-detail-btn:hover{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.history-detail-drawer{width:min(720px,100vw - 24px)}.history-detail-events{gap:12px;display:grid}.history-detail-event-card{background:#ffffffe6;border:1px solid #e2e8f0eb;border-radius:16px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px;display:grid}.history-detail-event-card div{flex-direction:column;gap:4px;min-width:0;display:flex}.history-detail-event-card span{color:#64748b;font-size:var(--font-sm);letter-spacing:.06em;text-transform:uppercase;font-weight:800}.history-detail-event-card strong{color:#0f172a;min-width:0;font-size:var(--font-base);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.connectivity-table-wrap{z-index:1;background:#fffffffa;border:1px solid #e4e6eff2;border-radius:22px;position:relative;overflow:auto visible;box-shadow:0 18px 44px #0f172a0d}.connectivity-table-wrap.has-date-editor{z-index:1;overflow:auto hidden}.connectivity-table{border-collapse:collapse;width:100%;min-width:1200px}.connectivity-table th{z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#667085;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;text-align:left;background:#f8fafcf5;border-bottom:1px solid #e4e6eff2;padding:8px 12px;font-weight:800;position:sticky;top:0}.table-sort-btn{font:inherit;color:inherit;text-transform:inherit;letter-spacing:inherit;font-weight:inherit;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;display:inline-flex}.table-sort-btn:hover,.table-sort-btn.active{color:#0f172a}.table-sort-icon{color:#94a3b8;align-items:center;display:inline-flex}.table-sort-btn.active .table-sort-icon{color:#2563eb}.connectivity-table td{font-size:var(--font-table);color:var(--text-main);white-space:nowrap;vertical-align:middle;border-bottom:1px solid #f1f5f9f5;padding:5px 12px;line-height:1.25;overflow:visible}.connectivity-table tbody tr{min-height:40px}.connectivity-table td input,.connectivity-table td select{border:1px solid var(--border);width:100%;min-width:100px;font-family:inherit;font-size:var(--font-ui);border-radius:6px;padding:3px 7px}.connectivity-inline-display{width:100%;min-width:92px;min-height:26px;color:inherit;font:inherit;text-align:left;cursor:pointer;background:#f8fbff59;border:1px dashed #bfdbfe2e;border-radius:10px;align-items:center;gap:6px;padding:3px 8px;transition:border-color .2s,background-color .2s,color .2s,box-shadow .2s;display:inline-flex}.connectivity-inline-display.is-comment{position:relative;overflow:visible}.inline-comment-cell{align-items:center;width:100%;min-width:0;display:inline-flex}.inline-comment-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.inline-comment-tooltip{z-index:40;color:#f8fafc;width:max-content;max-width:min(360px,100vw - 80px);font-size:var(--font-ui);white-space:normal;opacity:0;pointer-events:none;background:#0f172af5;border:1px solid #94a3b82e;border-radius:12px;padding:10px 12px;line-height:1.45;transition:opacity .16s,transform .16s;position:absolute;top:calc(100% + 10px);left:0;transform:translateY(-4px);box-shadow:0 18px 40px #0f172a2e}.connectivity-inline-display.has-tooltip:hover .inline-comment-tooltip,.connectivity-inline-display.has-tooltip:focus-visible .inline-comment-tooltip{opacity:1;transform:translateY(0)}.connectivity-inline-display:hover{color:#0f172a;background:#fff;border-color:#bfdbfe;box-shadow:0 8px 18px #3b82f614}.connectivity-inline-display.is-date{min-width:132px}.connectivity-inline-display.has-network-detail{justify-content:space-between}.network-followup-cell{width:100%;display:inline-block;position:relative}.network-followup-info-icon{color:#64748b;margin-left:auto}.network-followup-popover{z-index:120;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);white-space:normal;background:#fffffffa;border:1px solid #cbd5e1f2;border-radius:18px;width:min(380px,100vw - 80px);padding:14px;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 28px 70px #0f172a2e}.network-followup-title{color:#0f172a;align-items:center;gap:8px;margin-bottom:12px;display:flex}.network-followup-title strong{font-size:var(--font-base)}.network-followup-grid{grid-template-columns:110px minmax(0,1fr);align-items:start;gap:8px 12px;display:grid}.network-followup-grid span{color:#64748b;font-size:var(--font-sm);text-transform:uppercase;letter-spacing:.06em;font-weight:800}.network-followup-grid strong{color:#0f172a;min-width:0;font-size:var(--font-ui);overflow-wrap:anywhere;line-height:1.35}.network-followup-empty{color:#94a3b8;font-size:var(--font-ui);border-top:1px solid #e2e8f0f2;margin:12px 0 0;padding-top:10px;font-weight:700}.connectivity-inline-display.is-saving,.connectivity-inline-input.is-saving{opacity:.65}.connectivity-inline-input{width:100%;min-width:92px;font-family:inherit;font-size:var(--font-ui);color:var(--text-main);background:#fff;border:1px solid #93c5fd;border-radius:10px;outline:none;padding:4px 8px;box-shadow:0 0 0 3px #3b82f61f}.connectivity-inline-hint{font-size:var(--font-sm);color:var(--text-sec);font-weight:600}.connectivity-actions-cell{white-space:normal}.connectivity-manual-chip{color:#9a3412;min-height:20px;font-size:var(--font-sm);letter-spacing:.04em;text-transform:uppercase;vertical-align:middle;background:#fff7ed;border:1px solid #fdba74;border-radius:999px;justify-content:center;align-items:center;margin-bottom:4px;margin-right:6px;padding:0 8px;font-weight:800;display:inline-flex}.connectivity-detail-btn{color:#0f172a;min-height:28px;font:inherit;font-size:var(--font-ui);cursor:pointer;background:#fff;border:1px solid #cbd5e1eb;border-radius:10px;align-items:center;gap:5px;margin-right:6px;padding:0 9px;font-weight:700;display:inline-flex}.connectivity-detail-btn:hover{color:#2563eb;background:#f8fbff;border-color:#93c5fd}.status-chip{font-size:var(--font-sm);letter-spacing:.05em;text-transform:uppercase;border-radius:999px;justify-content:center;align-items:center;padding:5px 10px;font-weight:800;display:inline-flex}.status-chip.ok{color:#166534;background:#dcfce7}.status-chip.warning{color:#92400e;background:#fef3c7}.status-chip.danger{color:#b91c1c;background:#fee2e2}.status-chip.muted{color:#475569;background:#e2e8f0}.status-chip.auto{color:#1d4ed8;background:#dbeafe}.date-picker-shell,.month-picker-shell{z-index:170;position:relative}.date-picker-control .date-picker-popover{left:0;right:auto}.date-picker-trigger{color:#0f172a;width:100%;min-width:162px;min-height:42px;font-family:inherit;font-size:var(--font-ui);background:linear-gradient(#fff,#eff6ff);border:1px solid #93c5fd;border-radius:12px;align-items:center;gap:8px;padding:0 12px;font-weight:600;display:inline-flex;box-shadow:0 0 0 3px #3b82f61f}.date-picker-popover,.month-picker-popover{z-index:220;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffffa;border:1px solid #cbd5e1e6;border-radius:20px;width:320px;padding:14px;position:absolute;top:calc(100% + 10px);left:0;box-shadow:0 28px 70px #0f172a2e}.date-picker-popover-portal{z-index:2400;position:fixed}.connectivity-table .date-picker-shell{min-width:190px}.connectivity-table .date-picker-popover{left:auto;right:0}.month-picker-popover{width:280px}.date-picker-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.date-picker-header strong{font-size:var(--font-body);text-transform:capitalize}.date-nav-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1e6;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.date-nav-btn:hover{color:#0f172a;border-color:#93c5fd}.date-weekdays{grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px;display:grid}.date-weekdays span{font-size:var(--font-sm);color:#94a3b8;text-align:center;text-transform:uppercase;font-weight:700}.date-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.date-day-btn,.month-grid-btn{color:#0f172a;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:12px;font-family:inherit}.date-day-btn{height:36px;font-size:var(--font-ui);font-weight:600}.date-day-btn.is-outside{color:#cbd5e1}.date-day-btn:hover,.month-grid-btn:hover{background:#eff6ff;border-color:#bfdbfe}.date-day-btn.is-selected,.month-grid-btn.is-selected{color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb);border-color:#0000;box-shadow:0 10px 20px #2563eb38}.date-day-btn.is-today{border-color:#93c5fd}.date-picker-footer{justify-content:space-between;align-items:center;gap:10px;margin-top:14px;display:flex}.date-footer-btn{color:#1d4ed8;font-size:var(--font-ui);cursor:pointer;background:#eff6ff;border:1px solid #bfdbfee6;border-radius:12px;padding:8px 10px;font-weight:700}.date-footer-btn.subtle{color:#475569;background:#fff;border-color:#cbd5e1e6}.drawer-backdrop{z-index:1400;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a57;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer-panel{background:linear-gradient(#fffffffc,#f8fafcfa);border-left:1px solid #dbe4eef5;width:min(540px,100vw - 24px);height:100vh;padding:24px 22px;overflow-y:auto;box-shadow:-18px 0 44px #0f172a2e}.drawer-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;display:flex}.drawer-eyebrow{font-size:var(--font-sm);text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin-bottom:8px;font-weight:800}.drawer-header h3{font-size:var(--font-drawer-title);letter-spacing:-.03em;margin:0;line-height:1.05}.drawer-header p{color:#64748b;font-size:var(--font-base);margin:6px 0 0;font-weight:600}.drawer-close-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1eb;border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.drawer-close-btn:hover{color:#e11d48;background:#fff1f2;border-color:#fecdd3}.drawer-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.drawer-meta-card{background:#ffffffeb;border:1px solid #e4e6eff5;border-radius:16px;padding:14px 16px;box-shadow:0 10px 24px #0f172a0a}.drawer-meta-card span{font-size:var(--font-sm);letter-spacing:.08em;text-transform:uppercase;color:#64748b;margin-bottom:6px;font-weight:800;display:block}.drawer-meta-card strong{font-size:var(--font-body);color:#0f172a}.drawer-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.drawer-field{flex-direction:column;gap:8px;display:flex}.drawer-field-span-2{grid-column:span 2}.drawer-field span{font-size:var(--font-ui);color:#475569;font-weight:700}.drawer-field input,.drawer-field select,.drawer-field textarea{color:#0f172a;width:100%;font-family:inherit;font-size:var(--font-base);box-sizing:border-box;background:#fffffffa;border:1px solid #cbd5e1f5;border-radius:14px;padding:11px 12px}.drawer-field textarea{resize:vertical;min-height:120px}.drawer-field input:focus,.drawer-field select:focus,.drawer-field textarea:focus{border-color:#93c5fd;outline:none;box-shadow:0 0 0 4px #3b82f61f}.drawer-footer{border-top:1px solid #e2e8f0eb;justify-content:space-between;align-items:center;gap:14px;margin-top:20px;padding-top:20px;display:flex}.drawer-dirty-indicator{font-size:var(--font-ui);color:#475569;font-weight:700}.drawer-footer-actions{align-items:center;gap:10px;display:flex}.drawer-secondary-btn,.drawer-primary-btn{min-height:42px;font:inherit;font-size:var(--font-base);cursor:pointer;border-radius:12px;padding:0 16px;font-weight:700}.drawer-secondary-btn{color:#0f172a;background:#fff;border:1px solid #cbd5e1f5}.drawer-primary-btn{color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb);border:1px solid #2563eb}.drawer-secondary-btn:disabled,.drawer-primary-btn:disabled,.drawer-close-btn:disabled{opacity:.6;cursor:not-allowed}.month-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.month-grid-btn{min-height:42px;font-size:var(--font-ui);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.line-identity-cell{align-items:center;gap:8px;display:inline-flex}.line-kind-badge{font-size:var(--font-sm);border:1px solid #0000;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:1px 8px;font-weight:700;line-height:1.15;display:inline-flex}.line-kind-badge.fo{color:#166534;background:#dcfce7;border-color:#86efac}.line-kind-badge.number{color:#9a3412;background:#ffedd5;border-color:#fdba74}.line-kind-badge.type{color:#334155;background:#e2e8f0;border-color:#cbd5e1}.line-raw-value{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--font-ui);color:var(--text-main)}.chart-clickable-bar{cursor:pointer}.connectivity-table tbody tr:hover{background:linear-gradient(90deg,#f8fafcf2,#eff6ffbf)}.connectivity-empty{text-align:center;color:var(--text-sec)!important;padding:26px!important}.coming-soon{text-align:center;background:#fff;border-radius:12px;padding:100px 20px}.coming-soon h3{margin:20px 0 10px}.coming-soon p{color:var(--text-sec);max-width:400px;margin:0 auto;line-height:1.6}.text-red-500{color:var(--red)!important}.text-blue-500{color:var(--blue)!important}.text-yellow-500{color:var(--yellow)!important}.text-gray-500{color:var(--text-sec)!important}.text-gray-300{color:#e2e8f0!important}.topbar{flex-wrap:wrap;gap:10px;min-height:70px;height:auto!important;padding:12px 30px!important}.province-tabs{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ptab{color:var(--text-sec);font-size:var(--font-sm);cursor:pointer;white-space:nowrap;background:#ffffffeb;border:1.5px solid #cbd5e1e6;border-radius:999px;padding:7px 13px;font-weight:700;transition:all .2s}.ptab:hover{border-color:var(--pcolor,#6b7280);color:var(--pcolor,#6b7280);background:color-mix(in srgb, var(--pcolor,#6b7280) 8%, white)}.ptab.active{background:var(--pcolor,#334155);color:#fff;border-color:#0000;box-shadow:0 10px 24px #0f172a24}.ptab-content{align-items:center;gap:6px;display:inline-flex}.maintainer-filter{margin-left:16px}.shell-select{min-height:40px;color:var(--text-main);font-family:inherit;font-size:var(--font-ui);cursor:pointer;background:#fffffff5;border:1px solid #cbd5e1eb;border-radius:14px;outline:none;padding:0 13px;font-weight:600;box-shadow:0 8px 24px #0f172a0a}.shell-select:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f61f}.action-btn.edit-btn{border:1.5px solid var(--border);color:var(--text-main);background:#fff}.action-btn.edit-btn:hover{color:#7c3aed;border-color:#7c3aed}.action-btn.edit-btn.edit-active{color:#fff;background:#7c3aed;border-color:#7c3aed}.edit-mode-banner{color:#fff;font-size:var(--font-base);background:linear-gradient(135deg,#7c3aed,#5b21b6);border-radius:10px;align-items:center;gap:10px;margin-bottom:20px;padding:10px 18px;font-weight:600;animation:.3s slideDown;display:flex}.edit-mode-banner button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:6px;align-items:center;margin-left:auto;padding:4px 8px;display:flex}.edit-mode-banner button:hover{background:#ffffff59}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.edit-mode-card{background:#faf5ff!important;border:1.5px dashed #c4b5fd!important}.drag-handle{color:#c4b5fd;cursor:grab;border-radius:4px;align-items:center;padding:4px;transition:color .2s,background .2s;display:flex;position:absolute;top:12px;right:12px}.drag-handle:hover{color:#7c3aed;background:#ede9fe}.drag-handle:active{cursor:grabbing}.drag-handle-inline{display:inline-flex;position:static}.province-pill-btn{color:#fff;font-size:var(--font-sm);cursor:pointer;white-space:nowrap;background:var(--pill-color,#64748b);border:none;border-radius:12px;align-items:center;gap:5px;padding:3px 10px;font-weight:700;transition:filter .2s,transform .1s;display:inline-flex}.province-pill-btn:hover{filter:brightness(1.15);transform:scale(1.04)}.province-pill-container{z-index:45;position:relative}.province-pill-btn-inline{margin:0;padding:4px 10px}.pill-edit-icon{margin-left:4px}.province-dropdown{z-index:250;border:1px solid var(--border);background:#fff;border-radius:10px;min-width:200px;animation:.15s popIn;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden;box-shadow:0 8px 30px #0000001f}@keyframes popIn{0%{opacity:0;transform:scale(.95)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}.province-dropdown-header{font-size:var(--font-sm);text-transform:uppercase;color:var(--text-sec);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-weight:700;display:flex}.province-dropdown-header button{cursor:pointer;color:var(--text-sec);background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;display:flex}.province-dropdown-header button:hover{background:var(--bg-main)}.province-dropdown-item{width:100%;font-size:var(--font-base);cursor:pointer;text-align:left;color:var(--text-main);background:0 0;border:none;align-items:center;gap:8px;padding:9px 14px;font-weight:600;transition:background .15s;display:flex}.province-dropdown-item:hover{background:var(--bg-main)}.province-dropdown-item.active{background:color-mix(in srgb, var(--pcolor) 10%, white)}.prov-dot{background:var(--pcolor,#6b7280);border-radius:50%;flex-shrink:0;width:8px;height:8px}.dropdown-check{color:var(--pcolor,#6b7280);margin-left:auto}.drag-overlay-card{cursor:grabbing!important;border-top:4px solid #7c3aed!important}.provinces-legend{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:24px;display:grid}.province-legend-item{background:linear-gradient(#fffffffa,#f8fafcf5);border:1px solid #dbe4eef5;border-radius:16px;grid-template-columns:minmax(0,1fr);row-gap:10px;padding:14px 16px;display:grid;box-shadow:0 10px 24px #0f172a0a}.province-legend-head{align-items:center;gap:10px;min-width:0;display:flex}.province-legend-metrics{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pleg-dot{background:var(--legend-dot,#6b7280);border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 0 4px #ffffffeb}.pleg-name{min-width:0;font-size:var(--font-emphasis);color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;flex:auto;align-items:center;font-weight:700;display:inline-flex;overflow:hidden}.pleg-count{color:#475569;font-size:var(--font-ui);background:#94a3b81f;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-weight:700;display:inline-flex}.pleg-alerts{font-size:var(--font-ui);color:#fff;background:var(--red);border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-weight:700;display:inline-flex}@media (width<=1680px){.provinces-legend{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=1180px){.provinces-legend{grid-template-columns:minmax(0,1fr)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.75}}.sidebar-profile{border-top:1px solid var(--border);background:linear-gradient(#f8fafcd9,#fffffffa);justify-content:space-between;align-items:center;margin-top:auto;padding:16px 18px;display:flex}.profile-info{align-items:center;gap:10px;display:flex;overflow:hidden}.profile-icon{color:var(--text-sec);background:linear-gradient(#fff,#eff6ff);border:1px solid #cbd5e1f2;border-radius:999px;padding:6px;box-shadow:0 8px 20px #0f172a0d}.profile-name{font-size:var(--font-ui);color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-weight:700;overflow:hidden}.logout-btn{color:var(--text-sec);cursor:pointer;background:#ffffffe6;border:1px solid #cbd5e1eb;border-radius:12px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;box-shadow:0 8px 18px #0f172a0d}.logout-btn:hover{color:var(--red);background:#fff1f2;border-color:#fecdd3}@media (width<=1200px){.hover-popup-container{width:min(680px,100vw - 320px);min-width:0;right:18px}.topbar-actions,.province-tabs{width:100%}.pagination-controls{flex-wrap:wrap;gap:12px}.connectivity-kpis,.recharge-history-overview{grid-template-columns:repeat(2,minmax(0,1fr))}.recharge-history-guidance{flex-direction:column;align-items:stretch}.recharge-import-chipset{justify-content:flex-start;max-width:none}.stats-chart-grid,.provinces-legend{grid-template-columns:1fr}.toolbar-action-row{justify-content:flex-end;width:100%}}@media (width<=1024px){.app-wrapper{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.sidebar{border-right:none;border-bottom:1px solid var(--border);z-index:auto;width:100%;box-shadow:0 12px 30px #0f172a0d}.sidebar-brand{padding:20px 20px 18px}.sidebar-nav{flex-flow:wrap;flex:none;padding:14px 12px}.nav-item{flex:calc(50% - 8px);justify-content:center}.sidebar-footer{padding:14px 20px}.sidebar-profile{margin-top:0}.main-content{flex:none;width:100%;min-width:0}.workspace{padding:18px}.kpi-overview{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-pills{flex-wrap:wrap}.filters-toolbar{flex-direction:column;align-items:stretch;gap:12px}.filters-toolbar-group{flex-wrap:wrap}.filters-toolbar-divider{display:none}.filters-toolbar-rail{width:100%}.connectivity-subtabs{flex-wrap:wrap}.connectivity-subtab-btn{text-align:center;flex:180px}.recharge-history-overview{grid-template-columns:1fr}}@media (width<=720px){.hover-popup-container{display:none}.topbar{padding:12px 16px!important}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.nav-item{min-width:0;font-size:var(--font-base);justify-content:flex-start}.sidebar-profile{padding:14px 16px}.search-container{min-width:100%}.maintainer-filter{width:100%;margin-left:0}.shell-select{width:100%}.connectivity-view,.stats-premium-view{border-radius:18px;padding:16px}.connectivity-view .view-header h2,.stats-premium-view .view-header h2{font-size:var(--font-drawer-title)}.connectivity-kpis{grid-template-columns:1fr}.kpi-overview{grid-template-columns:1fr;gap:14px}.province-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.ptab{text-align:center;justify-content:center;width:100%}.toolbar-search-field,.toolbar-cluster,.toolbar-action-row{width:100%}.recharge-history-top-row{flex-direction:column;align-items:stretch}.recharge-history-import-btn,.recharge-history-summary-shell{width:100%}.toolbar-search-field{min-width:100%}.toolbar-select,.toolbar-month-btn,.toolbar-btn{width:100%}.pagination-controls{flex-direction:column;align-items:stretch;padding:12px 14px}.page-btn{justify-content:center}.supervision-table-wrap,.connectivity-table-wrap{border-radius:18px}.drawer-panel{width:100vw;padding:18px 16px}.drawer-header h3{font-size:var(--font-kpi)}.drawer-meta-grid,.drawer-form-grid{grid-template-columns:1fr}.drawer-field-span-2{grid-column:auto}.drawer-footer{flex-direction:column;align-items:stretch}.drawer-footer-actions{flex-direction:column;width:100%}.drawer-secondary-btn,.drawer-primary-btn{width:100%}.date-picker-popover,.month-picker-popover{width:min(320px,100vw - 64px)}.station-detail-backdrop{padding:16px}.station-detail-modal{width:min(960px,100vw - 32px);max-height:calc(100vh - 32px)}.station-detail-header{padding:20px 20px 16px}.station-detail-header h3{font-size:var(--font-kpi)}.station-detail-body{grid-template-columns:1fr;padding:18px 20px 20px}.station-comment-footer{flex-direction:column;align-items:stretch}.station-comment-actions{justify-content:flex-end}}@media (width<=540px){.sidebar-brand{font-size:var(--font-section);padding:18px 16px 16px}.sidebar-nav,.province-tabs{grid-template-columns:1fr}.station-detail-backdrop{padding:0}.station-detail-modal{border-radius:0;width:100vw;height:100vh;max-height:100vh}.station-detail-header{flex-direction:column;align-items:stretch;gap:14px}.station-detail-header-actions{justify-content:space-between;align-items:center}.station-detail-body{padding:16px}.station-detail-sensor-row{grid-template-columns:1fr;gap:8px}.station-comment-actions{flex-direction:column;width:100%}.station-comment-secondary-btn,.station-comment-primary-btn{width:100%}.topbar-actions{flex-direction:column;width:100%}.action-btn{justify-content:center;width:100%}.workspace{padding:14px}.connectivity-view,.stats-premium-view{border-radius:16px;padding:14px}}
