:root{
  --bg:#f4f1ea; --panel:#fbfaf6; --ink:#2a2620; --muted:#6b6356;
  --line:#ddd6c8; --accent:#7a5a3a; --accent2:#2e7d4f; --shadow:0 2px 14px rgba(60,50,35,.10);
  --serif:"Spectral",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:var(--sans);color:var(--ink);background:var(--bg)}
body{display:flex;flex-direction:column;overflow:hidden}

/* Header */
header{background:linear-gradient(180deg,#2a241d,#3a3127);color:#f4efe6;padding:14px 22px;
  border-bottom:3px solid var(--accent);box-shadow:var(--shadow);z-index:1200}
.h-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px}
header h1{font-family:var(--serif);font-weight:600;font-size:22px;margin:0;letter-spacing:.2px}
header .sub{font-size:12.5px;color:#c9bfae;margin-top:3px}
.stats{display:flex;gap:18px;flex-wrap:wrap}
.stat{font-size:11px;color:#bdae97;text-transform:uppercase;letter-spacing:.6px}
.stat b{display:block;font-size:14px;color:#f0e7d6;font-weight:600;letter-spacing:0;text-transform:none}

/* Layout */
main{flex:1;display:flex;min-height:0}
#sidebar{width:340px;background:var(--panel);border-right:1px solid var(--line);
  overflow-y:auto;padding:16px;flex-shrink:0}
#content{flex:1;display:flex;flex-direction:column;min-width:0}
#map{flex:1;min-height:240px}
#table-wrap{height:42%;min-height:160px;border-top:1px solid var(--line);background:var(--panel);
  display:flex;flex-direction:column}

/* Sidebar controls */
.grp{margin-bottom:18px}
.grp h3{font-family:var(--serif);font-size:13px;text-transform:uppercase;letter-spacing:.8px;
  color:var(--accent);margin:0 0 9px;border-bottom:1px solid var(--line);padding-bottom:5px}
label.cb{display:flex;align-items:center;gap:8px;font-size:13px;margin:5px 0;cursor:pointer}
.radio-row{display:flex;gap:14px;flex-wrap:wrap;font-size:13px}
.radio-row label{display:flex;align-items:center;gap:5px;cursor:pointer}
select,input[type=text]{width:100%;padding:7px 9px;border:1px solid var(--line);border-radius:6px;
  font-size:13px;font-family:var(--sans);background:#fff;color:var(--ink);margin-bottom:8px}
input[type=range]{width:100%;accent-color:var(--accent)}
.range-wrap{display:flex;flex-direction:column;gap:2px}
#dew-label{font-size:12px;color:var(--muted);text-align:center}
.btn-row{display:flex;gap:8px;margin-top:6px}
button{font-family:var(--sans);font-size:12.5px;padding:8px 12px;border:1px solid var(--line);
  background:#fff;border-radius:6px;cursor:pointer;color:var(--ink);transition:.15s}
button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Legend */
#legend{display:flex;flex-wrap:wrap;gap:6px 12px}
.leg{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--ink)}
.leg i{width:12px;height:12px;border-radius:50%;display:inline-block;border:1px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.15)}

/* Table */
.tbl-head{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;
  border-bottom:1px solid var(--line);background:#f0ece2}
.tbl-head .ttl{font-family:var(--serif);font-size:14px;font-weight:600}
#count{font-size:12px;color:var(--muted)}
.tbl-scroll{flex:1;overflow:auto}
table#tbl{width:100%;border-collapse:collapse;font-size:12.5px}
#tbl th{position:sticky;top:0;background:#e9e3d6;text-align:left;padding:8px 10px;
  font-weight:600;color:#4a4136;cursor:pointer;white-space:nowrap;border-bottom:2px solid var(--line);user-select:none}
#tbl th:hover{background:#e0d8c7}
#tbl th .arr{margin-left:4px;opacity:.4;font-size:10px}
#tbl th.sorted .arr::after{content:"▲";opacity:1}
#tbl th.sorted.desc .arr::after{content:"▼"}
#tbl td{padding:7px 10px;border-bottom:1px solid #ece7db;vertical-align:top}
#tbl tbody tr{cursor:pointer}
#tbl tbody tr:hover{background:#f6f2e7}
#tbl tbody tr.hi{background:#fbeede;box-shadow:inset 3px 0 0 var(--accent)}
#tbl td.nm{font-weight:600}
#tbl td.sm{color:var(--muted);font-size:11.5px;max-width:200px}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}
.pill{color:#fff;padding:2px 8px;border-radius:11px;font-size:11px;white-space:nowrap}
.dew{padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600}
.dew-0{background:#e3f1e8;color:#256b41}.dew-1{background:#fdf4d6;color:#8a6d0c}
.dew-2{background:#fde7cf;color:#9c5a14}.dew-3{background:#fbdcd0;color:#a5441f}
.dew-4{background:#f6d2cd;color:#9c2620}

/* Popup */
.pp{font-family:var(--sans)}
.pp-title{font-family:var(--serif);font-weight:600;font-size:15px;margin-bottom:6px;color:var(--ink)}
.pp-badges{display:flex;gap:5px;margin-bottom:8px;flex-wrap:wrap}
.pp-badges .badge{color:#fff;padding:2px 8px;border-radius:10px;font-size:10.5px}
.pp-tab{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:7px}
.pp-tab th{text-align:left;color:var(--muted);font-weight:600;padding:2px 8px 2px 0;white-space:nowrap;vertical-align:top}
.pp-tab td{padding:2px 0}
.pp-desc{font-size:12px;color:#4a4236;font-style:italic;border-top:1px solid var(--line);padding-top:6px}

/* Note */
.note{font-size:11px;color:var(--muted);line-height:1.5;background:#f0ece2;border-left:3px solid var(--accent);
  padding:9px 11px;border-radius:0 6px 6px 0}
.note a{color:var(--accent)}

/* Tabs (mobile) */
.tabs{display:none}
@media(max-width:860px){
  #sidebar{width:100%;max-height:none}
  main{flex-direction:column}
  .tabs{display:flex;border-bottom:1px solid var(--line);background:var(--panel)}
  .tab-btn{flex:1;border:none;border-radius:0;border-bottom:3px solid transparent;padding:11px}
  .tab-btn.active{border-bottom-color:var(--accent);color:var(--accent);font-weight:600;background:#fff}
  #content{flex:1}
  body[data-view=map] #table-wrap{display:none}
  body[data-view=table] #map{display:none}
  body[data-view=table] #table-wrap{height:auto;flex:1}
}
