/* assets/css/style.css */
:root {
  --bg:#f4f6fa; --surface:#fff; --surface2:#f8fafc; --surface3:#eef2f7;
  --border:#e2e8f0; --border2:#cbd5e0;
  --text:#1a202c; --text-dim:#718096; --text-light:#a0aec0;
  --green:#16a34a; --green-l:#22c55e; --green-bg:#f0fdf4; --green-bd:#bbf7d0;
  --yellow:#d97706; --yellow-l:#f59e0b; --yellow-bg:#fffbeb; --yellow-bd:#fde68a;
  --red:#dc2626; --red-l:#ef4444; --red-bg:#fef2f2; --red-bd:#fecaca;
  --accent:#2563eb; --accent-l:#3b82f6; --accent-bg:#eff6ff; --accent-bd:#bfdbfe;
  --pending:#64748b; --pending-l:#94a3b8; --pending-bg:#f8fafc; --pending-bd:#cbd5e0;
  --sh-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --sh:0 4px 12px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);
  --sh-lg:0 10px 30px rgba(0,0,0,.10),0 4px 12px rgba(0,0,0,.06);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Sarabun',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}

/* ── Header ── */
.header{background:#fff;border-bottom:1px solid var(--border);padding:0 28px;position:sticky;top:0;z-index:100;box-shadow:var(--sh-sm);}
.header-inner{max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px;}
.logo{display:flex;align-items:center;gap:12px;}
.logo-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px rgba(37,99,235,.3);}
.logo-text h1{font-size:15px;font-weight:700;color:var(--text);}
.logo-text p{font-size:11px;color:var(--text-dim);}
.update-badge{background:var(--green-bg);border:1px solid var(--green-bd);border-radius:20px;padding:5px 14px;font-size:12px;color:var(--green);display:flex;align-items:center;gap:6px;font-weight:500;}
.update-dot{width:7px;height:7px;border-radius:50%;background:var(--green-l);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

/* ── Nav Tabs ── */
.nav-tabs{background:#fff;border-bottom:1px solid var(--border);display:flex;padding:0 28px;}
.tab-btn{padding:14px 26px;border:none;background:transparent;color:var(--text-dim);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;border-bottom:3px solid transparent;transition:all .18s;display:flex;align-items:center;gap:8px;position:relative;top:1px;}
.tab-btn:hover{color:var(--accent);}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;}

/* ── District Selector Bar ── */
.district-selector-bar{background:#fff;border-bottom:1px solid var(--border);padding:10px 28px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-sm);}
.ds-label{font-size:13px;font-weight:600;color:var(--text-dim);white-space:nowrap;}
.ds-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:8px 36px 8px 14px;border-radius:8px;font-family:inherit;font-size:13px;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23718096' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;min-width:220px;transition:border-color .2s;}
.ds-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.ds-all-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text-dim);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap;}
.ds-all-btn.active{background:var(--accent-bg);border-color:var(--accent-bd);color:var(--accent);}
.ds-stat-pills{display:flex;gap:8px;margin-left:auto;}
.ds-pill{padding:5px 14px;border-radius:16px;font-size:12px;font-weight:600;border:1px solid;}
.ds-pill.green{background:var(--green-bg);border-color:var(--green-bd);color:var(--green);}
.ds-pill.yellow{background:var(--yellow-bg);border-color:var(--yellow-bd);color:var(--yellow);}
.ds-pill.red{background:var(--red-bg);border-color:var(--red-bd);color:var(--red);}
.ds-pill.pending{background:var(--pending-bg);border-color:var(--pending-bd);color:var(--pending);}

/* ── Views ── */
.view{display:none;}.view.active{display:block;}

/* ── Dashboard Layout ── */
.dashboard{max-width:1600px;margin:0 auto;padding:24px 28px;}

/* ── Stat Cards ── */
.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:22px;}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--sh-sm);display:flex;align-items:flex-start;gap:14px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden;}
.stat-card:hover{box-shadow:var(--sh);transform:translateY(-1px);}
.stat-accent-bar{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px;}
.stat-card.total .stat-accent-bar{background:var(--accent);}
.stat-card.green-card .stat-accent-bar{background:var(--green-l);}
.stat-card.yellow-card .stat-accent-bar{background:var(--yellow-l);}
.stat-card.red-card .stat-accent-bar{background:var(--red-l);}
.stat-card.pending-card .stat-accent-bar{background:var(--pending-l);}
.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.stat-card.total .stat-icon{background:var(--accent-bg);}
.stat-card.green-card .stat-icon{background:var(--green-bg);}
.stat-card.yellow-card .stat-icon{background:var(--yellow-bg);}
.stat-card.red-card .stat-icon{background:var(--red-bg);}
.stat-card.pending-card .stat-icon{background:var(--pending-bg);}
.stat-label{font-size:11px;color:var(--text-dim);margin-bottom:5px;font-weight:500;text-transform:uppercase;letter-spacing:.3px;}
.stat-value{font-size:30px;font-weight:800;line-height:1;font-family:'IBM Plex Sans Thai',sans-serif;}
.stat-card.total .stat-value{color:var(--accent);}
.stat-card.green-card .stat-value{color:var(--green);}
.stat-card.yellow-card .stat-value{color:var(--yellow);}
.stat-card.red-card .stat-value{color:var(--red);}
.stat-card.pending-card .stat-value{color:var(--pending);}
.stat-sub{font-size:11px;color:var(--text-light);margin-top:4px;}

/* ── Charts ── */
.charts-grid{display:grid;grid-template-columns:280px 1fr;gap:18px;margin-bottom:22px;}
.chart-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--sh-sm);}
.chart-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.chart-title::before{content:'';width:4px;height:14px;border-radius:2px;background:var(--accent);display:inline-block;}
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;}
.legend{display:flex;flex-direction:column;gap:8px;width:100%;}
.legend-item{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;border-radius:8px;background:var(--surface2);}
.legend-left{display:flex;align-items:center;gap:8px;}
.legend-dot{width:10px;height:10px;border-radius:50%;}
.legend-label{font-size:12px;color:var(--text-dim);}
.legend-count{font-weight:700;font-size:14px;}

/* ── District Grid ── */
.district-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-bottom:22px;}
.district-mini-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .18s;box-shadow:var(--sh-sm);}
.district-mini-card:hover{box-shadow:var(--sh);transform:translateY(-1px);border-color:var(--accent-bd);}
.district-mini-card.selected{border-color:var(--accent);background:var(--accent-bg);}
.dmc-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;}
.dmc-bar{height:6px;border-radius:3px;background:var(--surface3);overflow:hidden;display:flex;margin-bottom:8px;}
.dmc-bar-seg{height:100%;}
.dmc-bar-seg.g{background:var(--green-l);}
.dmc-bar-seg.y{background:var(--yellow-l);}
.dmc-bar-seg.r{background:var(--red-l);}
.dmc-bar-seg.p{background:var(--pending-l);}
.dmc-stats{display:flex;gap:6px;flex-wrap:wrap;}
.dmc-stat{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;}
.dmc-stat.g{background:var(--green-bg);color:var(--green);}
.dmc-stat.y{background:var(--yellow-bg);color:var(--yellow);}
.dmc-stat.r{background:var(--red-bg);color:var(--red);}
.dmc-stat.p{background:var(--pending-bg);color:var(--pending);}
.dmc-total{font-size:11px;color:var(--text-light);margin-left:auto;align-self:center;}

/* ── District Overview Dashboard ── */
.dov-summary-bar {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
  flex-wrap: wrap;
  box-shadow: var(--sh-sm);
  position: sticky;
  top: 130px;   /* under header + nav */
  z-index: 50;
}
.dov-sum-stat { text-align: center; min-width: 56px; }
.dov-sum-val {
  font-size: 24px;
  font-weight: 800;
  font-family: 'IBM Plex Sans Thai', sans-serif;
  color: var(--accent);
  line-height: 1;
}
.dov-sum-val.green  { color: var(--green); }
.dov-sum-val.yellow { color: var(--yellow); }
.dov-sum-val.red    { color: var(--red); }
.dov-sum-lbl { font-size: 10px; color: var(--text-dim); margin-top: 3px; white-space: nowrap; }
.dov-sum-divider { width: 1px; height: 38px; background: var(--border); flex-shrink: 0; }

.dov-filters { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.dov-status-filter { display: flex; gap: 5px; flex-wrap: wrap; }
.dov-filter-btn {
  padding: 5px 11px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text-dim);
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.dov-filter-btn:hover  { background: var(--surface2); color: var(--text); }
.dov-filter-btn.active { background: var(--accent-bg); border-color: var(--accent-bd); color: var(--accent); }
.dov-filter-btn.green.active  { background: var(--green-bg);  border-color: var(--green-bd);  color: var(--green); }
.dov-filter-btn.yellow.active { background: var(--yellow-bg); border-color: var(--yellow-bd); color: var(--yellow); }
.dov-filter-btn.red.active    { background: var(--red-bg);    border-color: var(--red-bd);    color: var(--red); }

.dov-view-toggle { display: flex; gap: 3px; }
.dov-view-btn {
  width: 32px; height: 32px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text-dim);
  cursor: pointer;
  font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.dov-view-btn:hover  { border-color: var(--accent); color: var(--accent); }
.dov-view-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Grid: tighter to fit 50 districts on screen */
.district-overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}
.district-mini-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 11px;
  padding: 12px 14px;
  cursor: pointer;
  transition: all .15s;
  box-shadow: var(--sh-sm);
  position: relative;
}
.district-mini-card:hover { box-shadow: var(--sh); transform: translateY(-1px); }
.district-mini-card.selected { border-color: var(--accent) !important; background: var(--accent-bg); }
.dmc-rank {
  position: absolute;
  top: 8px; right: 10px;
  font-size: 10px;
  color: var(--text-light);
  font-weight: 600;
}
.dmc-bar { height: 5px; border-radius: 3px; background: var(--surface3); overflow: hidden; display: flex; margin-bottom: 5px; }
.dmc-bar-seg { height: 100%; }
.dmc-bar-seg.g { background: var(--green-l); }
.dmc-bar-seg.y { background: var(--yellow-l); }
.dmc-bar-seg.r { background: var(--red-l); }
.dmc-bar-seg.p { background: var(--pending-l); }
.dmc-stats { display: flex; gap: 5px; flex-wrap: wrap; }
.dmc-stat { font-size: 11px; font-weight: 600; padding: 2px 6px; border-radius: 9px; }
.dmc-stat.g { background: var(--green-bg);  color: var(--green); }
.dmc-stat.y { background: var(--yellow-bg); color: var(--yellow); }
.dmc-stat.r { background: var(--red-bg);    color: var(--red); }
.dmc-stat.p { background: var(--pending-bg); color: var(--pending); }
.dmc-total  { font-size: 10px; color: var(--text-light); margin-left: auto; align-self: center; }

/* Table view */
#dov-table thead th {
  white-space: nowrap;
  user-select: none;
}
#dov-table thead th:hover { background: var(--surface3); }
.dov-bar-cell {
  display: flex;
  height: 12px;
  border-radius: 3px;
  overflow: hidden;
  background: var(--surface3);
  min-width: 120px;
}

/* Chart view */
.dov-chart-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 2px 0;
  border-radius: 6px;
  transition: background .15s;
}
.dov-chart-row:hover { background: var(--surface2); }
.dov-chart-name {
  font-size: 12px;
  color: var(--text-dim);
  width: 80px;
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dov-chart-name:hover { color: var(--accent); }

/* Chart container: scrollable to show all 50 */
#dov-chart-bars {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: none;   /* show all 50, let page scroll */
}

.dov-no-data {
  padding: 40px;
  text-align: center;
  color: var(--text-dim);
  font-size: 14px;
  grid-column: 1 / -1;
}

/* ── District Overview Dashboard ── */
.district-detail{display:none;background:var(--accent-bg);border:1px solid var(--accent-bd);border-radius:14px;padding:20px 24px;margin-bottom:20px;}
.district-detail.show{display:block;}
.dd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.dd-title{font-size:18px;font-weight:700;color:var(--text);}
.dd-subtitle{font-size:13px;color:var(--text-dim);margin-top:2px;}
.dd-close{width:28px;height:28px;border-radius:7px;border:1px solid var(--accent-bd);background:#fff;color:var(--accent);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.dd-close:hover{background:var(--accent);color:#fff;}
.dd-stats{display:flex;gap:12px;flex-wrap:wrap;}
.dd-stat{padding:10px 20px;border-radius:10px;border:1px solid;text-align:center;min-width:100px;}
.dd-stat.t{background:#fff;border-color:var(--accent-bd);}
.dd-stat.g{background:var(--green-bg);border-color:var(--green-bd);}
.dd-stat.y{background:var(--yellow-bg);border-color:var(--yellow-bd);}
.dd-stat.r{background:var(--red-bg);border-color:var(--red-bd);}
.dd-stat-val{font-size:24px;font-weight:800;font-family:'IBM Plex Sans Thai',sans-serif;}
.dd-stat.t .dd-stat-val{color:var(--accent);}
.dd-stat.g .dd-stat-val{color:var(--green);}
.dd-stat.y .dd-stat-val{color:var(--yellow);}
.dd-stat.r .dd-stat-val{color:var(--red);}
.dd-stat-lbl{font-size:11px;color:var(--text-dim);margin-top:2px;}

/* ── Filter Bar ── */
.filter-bar{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap;box-shadow:var(--sh-sm);}
.filter-label{font-size:12px;color:var(--text-dim);font-weight:500;white-space:nowrap;}
.filter-select,.filter-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:8px;font-family:inherit;font-size:13px;outline:none;transition:border-color .2s;}
.filter-select:focus,.filter-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.filter-input{min-width:220px;}
.filter-input::placeholder{color:var(--text-light);}
.status-filter{display:flex;gap:6px;}
.status-btn{padding:6px 12px;border-radius:8px;border:1px solid var(--border);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;background:#fff;color:var(--text-dim);}
.status-btn:hover{background:var(--surface2);}
.status-btn.s-all{background:var(--accent-bg);border-color:var(--accent-bd);color:var(--accent);}
.status-btn.s-green{background:var(--green-bg);border-color:var(--green-bd);color:var(--green);}
.status-btn.s-yellow{background:var(--yellow-bg);border-color:var(--yellow-bd);color:var(--yellow);}
.status-btn.s-red{background:var(--red-bg);border-color:var(--red-bd);color:var(--red);}
.status-btn.s-pending{background:var(--pending-bg);border-color:var(--pending-bd);color:var(--pending);}

/* ── Table ── */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.section-title{font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;}
.section-title::before{content:'';width:4px;height:16px;border-radius:2px;background:var(--accent);display:inline-block;}
.table-wrap{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--sh-sm);}
.table-header{padding:14px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);}
.table-title{font-size:14px;font-weight:600;}
.table-count{font-size:12px;color:var(--accent);background:var(--accent-bg);padding:4px 12px;border-radius:12px;border:1px solid var(--accent-bd);font-weight:500;}
.data-table{width:100%;border-collapse:collapse;}
.data-table th{padding:10px 16px;text-align:left;font-size:11px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#fafbfc;border-bottom:1px solid var(--border);}
.data-table td{padding:11px 16px;font-size:13px;border-bottom:1px solid #f0f4f8;vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tbody tr:hover td{background:#f8faff;cursor:pointer;}
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;}
.status-badge .dot{width:5px;height:5px;border-radius:50%;}
.status-badge.green{background:var(--green-bg);color:var(--green);border-color:var(--green-bd);}
.status-badge.green .dot{background:var(--green-l);}
.status-badge.yellow{background:var(--yellow-bg);color:var(--yellow);border-color:var(--yellow-bd);}
.status-badge.yellow .dot{background:var(--yellow-l);}
.status-badge.red{background:var(--red-bg);color:var(--red);border-color:var(--red-bd);}
.status-badge.red .dot{background:var(--red-l);}
.status-badge.pending{background:var(--pending-bg);color:var(--pending);border-color:var(--pending-bd);}
.status-badge.pending .dot{background:var(--pending-l);}
.type-badge{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-bd);}
.type-badge.gas{background:#faf5ff;color:#7c3aed;border-color:#e9d5ff;}
.type-badge.both{background:var(--yellow-bg);color:var(--yellow);border-color:var(--yellow-bd);}

/* ── Pagination ── */
.pagination{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-top:1px solid var(--border);background:#fafbfc;}
.pagination-info{font-size:12px;color:var(--text-dim);}
.page-btns{display:flex;gap:4px;align-items:center;}
.page-btn{min-width:30px;height:30px;padding:0 6px;border-radius:7px;border:1px solid var(--border);background:#fff;color:var(--text-dim);cursor:pointer;font-family:inherit;font-size:12px;transition:all .15s;display:flex;align-items:center;justify-content:center;}
.page-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);}
.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700;}
.page-btn:disabled{opacity:.35;cursor:not-allowed;}

/* ── Map ── */
#map-view{padding:0;}
.map-container{position:relative;}
#map{height:calc(100vh - 165px);width:100%;}
.map-overlay{position:absolute;top:14px;left:14px;z-index:10;display:flex;gap:8px;flex-wrap:wrap;}
.map-search-input{background:#fff;border:1px solid var(--border);border-radius:10px;color:var(--text);padding:9px 14px;font-family:inherit;font-size:13px;outline:none;width:220px;box-shadow:var(--sh);transition:border-color .2s;}
.map-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.map-filter-select{background:#fff;border:1px solid var(--border);border-radius:10px;color:var(--text);padding:9px 12px;font-family:inherit;font-size:13px;outline:none;box-shadow:var(--sh);cursor:pointer;}
.map-stats{position:absolute;top:14px;right:14px;display:flex;flex-direction:column;gap:6px;z-index:10;}
.map-stat-pill{background:#fff;border:1px solid;border-radius:20px;padding:7px 14px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;box-shadow:var(--sh-sm);}
.map-stat-pill.green{border-color:var(--green-bd);color:var(--green);}
.map-stat-pill.yellow{border-color:var(--yellow-bd);color:var(--yellow);}
.map-stat-pill.red{border-color:var(--red-bd);color:var(--red);}
.map-stat-pill.pending{border-color:var(--pending-bd);color:var(--pending);}
.map-legend{position:absolute;bottom:28px;left:14px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 16px;z-index:10;box-shadow:var(--sh);}
.map-legend h4{font-size:11px;color:var(--text-dim);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;}
.map-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:6px;color:var(--text);}
.map-legend-item:last-child{margin-bottom:0;}
.map-legend-dot{width:10px;height:10px;border-radius:50%;}

/* ── Popup ── */
.info-popup{position:fixed;top:50%;right:-420px;transform:translateY(-50%);width:370px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px;z-index:200;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-lg);}
.info-popup.open{right:22px;}
.popup-close{position:absolute;top:14px;right:14px;width:26px;height:26px;border-radius:7px;background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.popup-close:hover{background:var(--surface3);}
.popup-name{font-size:15px;font-weight:700;margin:8px 0 3px;line-height:1.4;}
.popup-detail{display:flex;gap:10px;align-items:flex-start;margin-bottom:8px;}
.popup-detail-label{font-size:11px;color:var(--text-dim);width:72px;flex-shrink:0;padding-top:1px;font-weight:500;}
.popup-detail-value{font-size:13px;line-height:1.4;}
.popup-divider{height:1px;background:var(--border);margin:12px 0;}

/* ── Map Link Button (from table rows) ── */
.map-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid var(--accent-bd);
  background: var(--accent-bg);
  color: var(--accent);
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
  white-space: nowrap;
}
.map-link-btn:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(37,99,235,.25);
}

/* Popup map button */
.popup-map-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  margin-top: 14px;
  padding: 9px 16px;
  border-radius: 10px;
  border: 1px solid var(--accent-bd);
  background: var(--accent-bg);
  color: var(--accent);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
}
.popup-map-btn:hover {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 3px 10px rgba(37,99,235,.3);
}

/* Highlighted row when returning from map focus */
@keyframes rowHighlight {
  0%   { background: rgba(37,99,235,.15); }
  100% { background: transparent; }
}
tr.row-focused td {
  animation: rowHighlight 2s ease-out forwards;
}
.loading{display:flex;align-items:center;justify-content:center;height:160px;color:var(--text-dim);font-size:14px;gap:10px;}
.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ── Responsive ── */
@media(max-width:1300px){.stat-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:1100px){.stat-grid{grid-template-columns:repeat(3,1fr);}.charts-grid{grid-template-columns:1fr;}}
@media(max-width:700px){
  .stat-grid{grid-template-columns:1fr 1fr;}
  .filter-bar{flex-direction:column;align-items:stretch;}
  .ds-stat-pills{display:none;}
  .header-inner{height:auto;padding:12px 0;flex-direction:column;align-items:flex-start;gap:8px;}
}
