:root{
  --page:#f5f5f3;--content:#fff;--bd:#e7e5e4;--tp:#1c1917;--ts:#78716c;--tm:#a8a29e;
  --accent:#6b7f6b;--accentS:#eef1ee;--accentL:#cfd8cf;--warn:#a3956b;--danger:#9e6b6b;--info:#6b7a8f;
  --font:'Inter',system-ui,sans-serif;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:var(--font);color:var(--tp);background:var(--page)}
button{font-family:var(--font)}

#hud{position:fixed;top:0;left:0;right:0;height:52px;background:var(--content);border-bottom:1px solid var(--bd);
  display:flex;align-items:center;gap:16px;padding:0 18px;z-index:1000}
.brand{font-weight:700;font-size:18px;letter-spacing:-.02em}.brand .x{color:var(--accent)}
.eyebrow{font-size:11px;letter-spacing:.16em;color:var(--tm);font-weight:600;border-left:1px solid var(--bd);padding-left:16px}
#hudtxt{margin-left:auto;font-size:12px;color:var(--ts)}

#panel{position:fixed;top:52px;left:0;bottom:0;width:300px;background:var(--content);border-right:1px solid var(--bd);overflow-y:auto;z-index:900}
.sect{border-bottom:1px solid var(--bd)}
.secth{display:flex;align-items:center;padding:12px 16px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--tm);font-weight:600;cursor:pointer;user-select:none}
.secth .chev{margin-left:auto;font-size:9px;transition:transform .15s}
.sect.collapsed .chev{transform:rotate(-90deg)}
.sect.collapsed .sbody{display:none}
.sbody{padding:0 16px 14px}

.searchbox{width:100%;padding:8px 11px;border:1px solid var(--bd);border-radius:8px;font:13px var(--font);color:var(--tp);background:var(--content)}
.searchbox:focus{outline:none;border-color:var(--accent)}
#searchresults{margin-top:7px;max-height:260px;overflow:auto}
.sritem{padding:6px 8px;border-radius:6px;cursor:pointer;border:1px solid transparent}
.sritem:hover{background:var(--accentS);border-color:var(--accentL)}
.srtitle{font-weight:600;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.srsub{font-size:11px;color:var(--ts);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.srmuted{color:var(--tm);font-size:12px;padding:6px 2px}

.lrow{display:flex;align-items:center;gap:9px;padding:6px 0;cursor:pointer;font-size:13px}
.lname{flex:1}.hint{color:var(--tm);font-size:10px}.lcount{color:var(--tm);font-size:11px;margin-right:4px}
.dot{width:11px;height:11px;border-radius:50%;flex:none}
/* iOS toggle */
.tgl{position:relative;display:inline-flex;width:34px;height:20px;flex:none}
.tgl input{opacity:0;width:0;height:0;position:absolute}
.tgl>span{position:absolute;inset:0;background:#d6d3d1;border-radius:999px;transition:.15s}
.tgl>span::before{content:"";position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.15s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.tgl input:checked+span{background:var(--accent)}
.tgl input:checked+span::before{transform:translateX(14px)}
.tgl.tsm{width:26px;height:15px}.tgl.tsm>span::before{width:11px;height:11px}.tgl.tsm input:checked+span::before{transform:translateX(11px)}
.subrow{display:block;font-size:11px;color:var(--ts);padding:2px 0 2px 0;cursor:pointer}

.frow{display:flex;align-items:center;gap:9px;margin-top:9px}.flbl{font-size:12px;color:var(--ts)}.runit{color:var(--tm);font-size:11px}
.rangerow{display:flex;align-items:center;gap:7px;margin:5px 0 2px;padding-left:34px}
.rangerow input{width:74px;padding:5px 8px;border:1px solid var(--bd);border-radius:6px;font:12px var(--font);color:var(--tp);background:var(--content)}
.rangerow input:focus{outline:none;border-color:var(--accent)}
.rangerow.off input{opacity:.4;pointer-events:none}.rangerow .rdash{color:var(--tm)}

.aoi-box{background:var(--accentS);border:1px solid var(--accentL);border-radius:8px;padding:9px}
.aoi-box #selbtn{width:100%;border:1px solid var(--bd);background:var(--content);color:var(--tp);border-radius:999px;padding:7px 13px;cursor:pointer;font:12px var(--font)}
.aoi-box #selbtn:hover{background:#fff}
.aoi-box #selbtn.active{background:var(--danger);color:#fff;border-color:var(--danger)}

#addlayer{margin-top:6px;border:none;background:var(--pill,#1c1917);color:#fff;border-radius:999px;padding:6px 13px;cursor:pointer;font:12px var(--font)}
.lbtns{margin-top:6px}
#customlist{margin-top:6px;font-size:12px}
#customlist .crow{display:flex;align-items:center;gap:8px;padding:3px 0}
#customlist .crm{margin-left:auto;color:var(--tm);cursor:pointer}

/* ioGAS selection panel */
#selpanel{position:fixed;left:316px;bottom:18px;width:250px;background:var(--content);border:1px solid var(--bd);border-radius:10px;box-shadow:var(--shadow);padding:13px;z-index:1100;display:none;font-size:12px}
#selpanel.show{display:block}
#selhead{display:flex;align-items:center;margin-bottom:7px}#selhead b{font-size:13px}
#selclose{margin-left:auto;border:none;background:none;font-size:18px;color:var(--tm);cursor:pointer;line-height:1}
#seltop{color:var(--ts);margin-bottom:7px}
#selpanel select{width:100%;padding:5px 7px;border:1px solid var(--bd);border-radius:6px;font:12px var(--font);color:var(--tp);margin:2px 0 7px}
.sl{font-size:11px;color:var(--ts)}
.cl{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ts);margin-top:4px}
.cl.szl{gap:8px}.cl input[type=range]{flex:1;accent-color:var(--accent)}
.ramp{height:11px;border-radius:3px;margin:8px 0 2px;
  background:linear-gradient(90deg,rgb(1,1,255) 0%,rgb(1,128,255) 30%,rgb(1,255,255) 50%,rgb(1,255,1) 70%,rgb(255,255,1) 85%,rgb(255,1,1) 94%,rgb(255,1,255) 100%)}
.lends{display:flex;justify-content:space-between;font-size:10px;color:var(--tm)}
#selstats{margin-top:8px}
.srowr{display:flex;justify-content:space-between;padding:1px 0;color:var(--ts)}.srowr span:last-child{font-weight:600;color:var(--tp)}
.selbtns{display:flex;gap:6px;margin-top:9px}
.selbtns button{flex:1;border:1px solid var(--bd);background:var(--content);color:var(--ts);border-radius:999px;padding:5px 8px;cursor:pointer;font:11px var(--font)}
.selbtns button:hover{background:var(--accentS)}

#legend{position:fixed;right:14px;bottom:14px;background:var(--content);border:1px solid var(--bd);border-radius:8px;box-shadow:var(--shadow);padding:9px 12px;font-size:11px;color:var(--ts);z-index:800;max-width:230px}
#legend b{color:var(--tp)}#legend i{display:inline-block;width:11px;height:11px;border-radius:2px;vertical-align:-1px;margin-right:3px}

.maplibregl-popup-content{font:12px var(--font);border-radius:8px;box-shadow:var(--shadow);padding:10px 12px}
.pop b{font-size:13px}.pop table{border-collapse:collapse;margin-top:5px;font-size:11px}
.pop td{padding:1px 8px 1px 0}.pop td:nth-child(2){text-align:right;font-weight:600}
.pop td.srcc{text-align:right;font-weight:400;padding-left:8px}.pop td.srcc a{color:var(--info);text-decoration:none;font-size:10px}
.pop .muted{color:var(--tm)}.pop a{color:var(--accent);text-decoration:none;font-weight:600}
.pickitem{padding:5px 0;border-top:1px solid var(--bd)}.pickitem a{color:var(--accent);text-decoration:none;font-weight:600}.pickitem small{color:var(--ts)}

#map{position:fixed;top:52px;left:300px;right:0;bottom:0}
#reportpanel{position:fixed;top:52px;right:0;bottom:0;width:660px;max-width:72vw;background:var(--content);border-left:1px solid var(--bd);box-shadow:-4px 0 16px rgba(0,0,0,.06);z-index:950;transform:translateX(100%);transition:transform .2s;display:flex;flex-direction:column}
#reportpanel.open{transform:none}
#rp_head{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--bd)}
#rp_title{font-weight:600;font-size:13px;flex:1;line-height:1.3}#rp_title small{color:var(--ts);font-weight:400}
#rp_close{border:none;background:none;font-size:22px;color:var(--tm);cursor:pointer;line-height:1}#rp_close:hover{color:var(--tp)}
#ptabs{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--bd)}
.ptab{border:none;background:none;padding:6px 14px;border-radius:999px;font:12px var(--font);color:var(--ts);cursor:pointer}
.ptab.active{background:var(--pill,#1c1917);color:#fff}
#pbody{flex:1;overflow:hidden;position:relative}
.ppane{position:absolute;inset:0;overflow:auto;display:none}.ppane.active{display:block}
#filetree{padding:10px 12px;font:12px var(--font)}
#filetree details{margin:2px 0}
#filetree summary{cursor:pointer;font-weight:600;padding:3px 4px;border-radius:4px;color:var(--tp)}
#filetree summary:hover{background:var(--accentS)}
.fentry{padding:4px 6px 4px 18px;cursor:pointer;border-radius:4px;color:var(--info);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fentry:hover{background:var(--accentS)}
.fentry.pdf{color:var(--danger)}.fentry.sheet{color:var(--accent)}.fentry.md{color:var(--warn)}
#docsub{display:flex;gap:5px;padding:8px 12px;border-bottom:1px solid var(--bd)}
.dsub{border:1px solid var(--bd);background:var(--content);padding:4px 11px;border-radius:999px;font:11px var(--font);color:var(--ts);cursor:pointer}
.dsub.active{background:var(--pill,#1c1917);color:#fff;border-color:var(--pill,#1c1917)}
#docwrap{position:absolute;top:39px;left:0;right:0;bottom:0}
.docview{position:absolute;inset:0;display:none;overflow:auto}.docview.show{display:block}
iframe#docpdf{width:100%;height:100%;border:none}
#docmd{padding:14px 18px;font-size:13px;line-height:1.6;max-width:820px}
#docmd table{border-collapse:collapse;font-size:11px;margin:6px 0}#docmd td,#docmd th{border:1px solid var(--bd);padding:2px 6px}
#docdetail{padding:14px 18px;font-size:13px;line-height:1.55}
#docdetail h4{margin:14px 0 5px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tm)}#docdetail p{margin:0 0 8px;color:var(--ts)}
.metatable{border:1px solid var(--bd);border-radius:8px;overflow:hidden;margin-bottom:6px}
.mrow{display:flex;justify-content:space-between;gap:12px;padding:6px 10px;border-bottom:1px solid var(--bd);font-size:12.5px}
.mrow:last-child{border-bottom:none}.mrow span:first-child{color:var(--tm)}.mrow span:last-child{color:var(--tp);text-align:right}
.srclinks{display:flex;flex-direction:column;gap:5px;margin-top:4px}
.srclinks a{color:var(--info);text-decoration:none;font-size:13px}.srclinks a:hover{text-decoration:underline}
#docsplit{display:none;flex-direction:row}#docsplit.show{display:flex}
#splitpdf,#splitmd{flex:1;height:100%;overflow:auto}
#splitpdf{background:#4a4a4a;border-right:1px solid var(--bd)}
#splitpdf .pg{margin:0 auto 6px;display:block;text-align:center}#splitpdf canvas{max-width:100%;box-shadow:0 1px 4px rgba(0,0,0,.4)}
#splitmd{padding:0 12px}#splitmd .pg{padding:10px 4px;border-bottom:1px solid var(--bd);font-size:12px;line-height:1.5}
#datawrap{padding:14px 18px;font-size:13px}
