@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Rajdhani:wght@300;400;500;600;700&family=Orbitron:wght@400;500;600;700;800;900&display=swap');
*{margin:0;padding:0;box-sizing:border-box;}
:root{--bg:#06080e;--panel:rgba(2,14,8,0.94);--border:rgba(1,168,52,0.25);--text:#6ad88c;--text-dim:#2a7a3a;--accent:#01a834;--accent2:#e88030;--danger:#cc2200;--warning:#01a834;--highlight:rgba(1,168,52,0.08);--fm:'Share Tech Mono',monospace;--fu:'Rajdhani',sans-serif;--ft:'Orbitron',sans-serif;}
body{background:var(--bg);color:var(--text);font-family:var(--fu);overflow:hidden;height:100vh;width:100vw;cursor:crosshair;}
#map{position:fixed;transition:opacity 0.5s;inset:0;z-index:1;}
.maplibregl-ctrl{display:none!important;}
#scanlines{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:0;transition:opacity 0.5s;}
body.nerv #scanlines{background:repeating-linear-gradient(0deg,rgba(220,120,30,0.04) 0px,rgba(220,120,30,0.04) 1px,transparent 1px,transparent 3px);opacity:1;}
#vignette{position:fixed;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,0.6) 100%);}

.panel{position:fixed;z-index:100;background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:all 0.5s ease;}
.panel-title{font-family:var(--ft);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);padding:10px 14px 6px;border-bottom:1px solid var(--border);font-weight:600;display:flex;align-items:center;justify-content:space-between;}
.panel-title .live-dot{width:6px;height:6px;border-radius:50%;background:var(--danger);animation:pr 1.5s infinite;}
@keyframes pr{0%,100%{opacity:1}50%{opacity:0.4}}

#header{top:0;left:0;right:0;height:42px;transition:opacity 0.5s;display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-family:var(--fm);font-size:12px;border-bottom:1px solid var(--border);z-index:300;background:linear-gradient(180deg,rgba(8,14,28,0.96),rgba(8,14,28,0.85));}
#header .logo{font-family:var(--ft);font-size:14px;font-weight:700;letter-spacing:5px;color:var(--accent);text-shadow:0 0 10px rgba(1,168,52,0.4);}
#header .logo span{color:var(--text-dim);font-weight:400;font-size:10px;letter-spacing:2px;margin-left:10px;}
.sys-info{display:flex;gap:20px;align-items:center;font-family:var(--fm);}
.sys-info div{display:flex;align-items:center;gap:6px;}
.sd{width:6px;height:6px;border-radius:50%;display:inline-block;}
.sd.g{background:#00ff88;box-shadow:0 0 6px #00ff88;}
.sd.a{background:#ffaa00;box-shadow:0 0 6px #ffaa00;}

#search-box{position:fixed;top:52px;left:50%;transform:translateX(-50%);z-index:400;width:380px;}
#si{width:100%;background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:var(--fm);font-size:12px;padding:8px 14px 8px 30px;outline:none;transition:all 0.3s;backdrop-filter:blur(14px);}
#si:focus{border-color:var(--accent);box-shadow:0 0 12px rgba(1,168,52,0.15);}
#si::placeholder{color:var(--text-dim);}
#sr{background:var(--panel);border:1px solid var(--border);border-top:none;max-height:300px;overflow-y:auto;display:none;backdrop-filter:blur(14px);}
.sri{padding:8px 14px;font-family:var(--fm);font-size:11px;cursor:pointer;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(40,80,140,0.1);}
.sri:hover{background:var(--highlight);}
.stag{font-size:8px;padding:2px 5px;border-radius:2px;font-family:var(--ft);letter-spacing:1px;flex-shrink:0;}
.stag.fl{background:rgba(0,220,255,0.15);color:#00ddff;}
.stag.ml{background:rgba(255,50,50,0.15);color:#ff3a3a;}
.stag.st{background:rgba(80,120,220,0.15);color:#5588dd;}
.stag.cn{background:rgba(255,80,0,0.15);color:#ff5500;}
.stag.cm{background:rgba(0,255,136,0.15);color:#00ff88;}

#pl{top:52px;left:10px;width:210px;bottom:50px;overflow-y:auto;overflow-x:hidden;font-size:12px;z-index:200;}
#pl::-webkit-scrollbar{width:3px;}#pl::-webkit-scrollbar-thumb{background:var(--border);}
.lt{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;transition:background 0.2s;font-family:var(--fm);font-size:11px;user-select:none;}
.lt:hover{background:var(--highlight);}
.lt .ind{width:9px;height:9px;border:1px solid var(--text-dim);border-radius:2px;transition:all 0.2s;flex-shrink:0;}
.lt.on .ind{background:var(--accent);border-color:var(--accent);box-shadow:0 0 5px var(--accent);}
.lt .cnt{margin-left:auto;color:var(--text-dim);font-size:10px;}
.str{display:flex;justify-content:space-between;padding:5px 12px;font-family:var(--fm);font-size:11px;}
.str .v{color:var(--accent);}
.dvd{height:1px;background:var(--border);margin:5px 0;}

#pr{top:52px;right:10px;width:290px;bottom:50px;display:flex;flex-direction:column;z-index:200;}
#of{flex:1;overflow-y:auto;padding:4px 0;}
#of::-webkit-scrollbar{width:3px;}#of::-webkit-scrollbar-thumb{background:var(--border);}
.fi{padding:7px 11px;border-bottom:1px solid var(--border);font-size:11px;line-height:1.4;animation:fin 0.3s ease;cursor:default;transition:background 0.2s;}
.fi:hover{background:var(--highlight);}
.fi.clickable:hover{background:var(--highlight);cursor:pointer;}
.fi .fi-zone{color:var(--text-dim);font-size:9px;font-family:var(--fm);}
@keyframes fin{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.fi .fs{font-family:var(--fm);color:var(--accent);font-size:10px;margin-bottom:2px;}
.fi .ft{color:var(--text-dim);font-size:9px;font-family:var(--fm);margin-top:3px;}
.fi.al{border-left:2px solid var(--danger);}.fi.wa{border-left:2px solid var(--warning);}.fi.in{border-left:2px solid var(--accent);}

#dp{position:fixed;z-index:500;bottom:50px;left:50%;transform:translateX(-50%);width:520px;max-height:55vh;background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(14px);display:none;flex-direction:column;overflow:hidden;}
#dp.show{display:flex;}
#dph{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);}
.tt{font-family:var(--ft);font-size:11px;letter-spacing:2px;}
.dtype{font-size:9px;padding:2px 8px;border-radius:2px;font-family:var(--ft);letter-spacing:1px;margin-right:8px;}
#dpc{background:none;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;padding:0 4px;font-family:var(--fm);}
#dpc:hover{color:var(--text);}
#dpb{flex:1;overflow-y:auto;padding:10px 14px;font-family:var(--fm);font-size:11px;line-height:1.8;}
#dpb::-webkit-scrollbar{width:3px;}#dpb::-webkit-scrollbar-thumb{background:var(--border);}
.dr{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid rgba(40,80,140,0.08);}
.dr .dl{color:var(--text-dim);}.dr .dv2{color:var(--accent);text-align:right;}

.cam-feed{position:relative;background:#000;border:1px solid rgba(0,255,136,0.2);margin:8px 0;aspect-ratio:16/9;overflow:hidden;}
.cam-feed iframe{width:100%;height:100%;border:none;}
.cam-feed .cf-rec{position:absolute;top:6px;right:8px;display:flex;align-items:center;gap:4px;font-family:var(--fm);font-size:9px;color:#ff3a3a;pointer-events:none;}
.cam-feed .cf-rec::before{content:'';width:6px;height:6px;border-radius:50%;background:#ff3a3a;animation:pr 1s infinite;}
.cam-feed .cf-ts{position:absolute;bottom:6px;left:8px;font-family:var(--fm);font-size:9px;color:rgba(255,255,255,0.5);pointer-events:none;}
.cam-feed .cf-id{position:absolute;top:6px;left:8px;font-family:var(--fm);font-size:9px;color:rgba(0,255,136,0.6);pointer-events:none;}
.cam-feed .cf-offline{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;font-family:var(--ft);font-size:10px;letter-spacing:2px;color:#00ff88;}
.cam-feed .cf-noise{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,136,0.02) 2px,rgba(0,255,136,0.02) 4px);pointer-events:none;}
.track-btn{background:rgba(0,180,255,0.1);border:1px solid var(--accent);color:var(--accent);font-family:var(--ft);font-size:9px;letter-spacing:2px;padding:6px 16px;cursor:pointer;margin-top:10px;transition:all 0.2s;text-transform:uppercase;display:block;width:100%;text-align:center;}
.track-btn:hover{background:rgba(0,180,255,0.25);}

#cto{position:fixed;inset:0;z-index:600;background:var(--panel);display:none;flex-direction:column;}
#cto.show{display:flex;}
#cto-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);background:rgba(4,8,16,0.5);}
#cto-header .cto-title{font-family:var(--ft);font-size:13px;letter-spacing:3px;}
#cto-close{background:none;border:1px solid var(--text-dim);color:var(--text-dim);font-family:var(--ft);font-size:9px;letter-spacing:2px;padding:4px 14px;cursor:pointer;}
#cto-close:hover{border-color:var(--text);color:var(--text);}
#cto-body{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:1px;background:var(--border);overflow:hidden;}
.cto-s{background:var(--panel);padding:14px;overflow-y:auto;}
.cto-s::-webkit-scrollbar{width:3px;}.cto-s::-webkit-scrollbar-thumb{background:var(--border);}
.cto-s h3{font-family:var(--ft);font-size:10px;letter-spacing:2px;color:var(--accent);margin-bottom:10px;text-transform:uppercase;}
.cto-stat{display:flex;justify-content:space-between;padding:4px 0;font-family:var(--fm);font-size:11px;border-bottom:1px solid rgba(40,80,140,0.06);}
.cto-stat .csv{color:var(--accent);}
.cto-ev{padding:7px 0;border-bottom:1px solid var(--border);font-size:11px;line-height:1.4;}
.cto-ev .ces{font-family:var(--fm);color:var(--accent);font-size:9px;}
.cto-ev .cet{font-family:var(--fm);color:var(--text-dim);font-size:9px;margin-top:2px;}
.cto-ev.gov .ces{color:var(--warning);}
.tli{display:flex;gap:10px;padding:5px 0;border-bottom:1px solid rgba(40,80,140,0.06);font-size:11px;}
.tli .tld{font-family:var(--fm);color:var(--text-dim);font-size:10px;min-width:60px;flex-shrink:0;}

#bb{bottom:0;left:0;right:0;height:40px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-family:var(--fm);font-size:10px;border-top:1px solid var(--border);color:var(--text-dim);z-index:300;}
.nerv-btn{background:transparent;border:1px solid var(--text-dim);color:var(--text-dim);font-family:var(--ft);font-size:9px;letter-spacing:2px;padding:4px 14px;cursor:pointer;transition:all 0.3s;}
.nerv-btn:hover{border-color:#e07020;color:#e07020;}

#header{background:linear-gradient(180deg,rgba(2,14,8,0.96),rgba(2,14,8,0.85));}
.lt.on .ind{background:#01a834;border-color:#01a834;box-shadow:0 0 5px rgba(1,168,52,0.6);}
.fi.in{border-left-color:#01a834;}
.sd.g{background:#e88030;box-shadow:0 0 6px #e88030;}
.sd.a{background:#01a834;box-shadow:0 0 6px #01a834;}
.track-btn{background:rgba(1,168,52,0.1);border-color:#01a834;color:#01a834;}
.nerv-btn{border-color:#01a834;color:#01a834;background:rgba(1,168,52,0.12);}
body.nerv .nerv-btn{border-color:#e07020;color:#e07020;background:rgba(224,112,32,0.12);}

#no{position:fixed;inset:0;z-index:150;pointer-events:none;opacity:1;transition:opacity 0.6s;}
body.nerv #no{opacity:1;}
body.nerv #no .nc{color:rgba(224,112,32,0.4);text-shadow:0 0 8px rgba(224,112,32,0.15);}
body.nerv #no .nt{color:rgba(224,112,32,0.09);text-shadow:0 0 60px rgba(224,112,32,0.06);}
body.nerv #no .ns{color:rgba(224,112,32,0.18);}

.nc{position:absolute;font-family:var(--ft);color:rgba(1,168,52,0.4);font-size:9px;letter-spacing:3px;text-shadow:0 0 8px rgba(1,168,52,0.15);}
.nc.tl{top:92px;left:230px;}.nc.tr{top:92px;right:310px;}.nc.bl{bottom:50px;left:230px;}.nc.br{bottom:50px;right:310px;}
.nt{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--ft);font-size:72px;font-weight:900;color:rgba(1,168,52,0.09);letter-spacing:25px;text-shadow:0 0 60px rgba(1,168,52,0.06);}
.ns{position:absolute;top:calc(50% + 48px);left:50%;transform:translateX(-50%);font-family:var(--ft);font-size:9px;color:rgba(1,168,52,0.18);letter-spacing:8px;white-space:nowrap;}

body.nerv{--accent:#e88030;--accent2:#40b030;--text:#daa060;--text-dim:#8a6a30;--border:rgba(230,130,40,0.35);--panel:rgba(14,8,2,0.94);--highlight:rgba(230,130,40,0.1);--danger:#cc2200;--warning:#e88030;}
body.nerv #header{background:linear-gradient(180deg,rgba(14,8,2,0.96),rgba(14,8,2,0.85));}
body.nerv #header .logo{color:#e07020;text-shadow:0 0 12px rgba(224,112,32,0.5);}
body.nerv .lt.on .ind{background:#e07020;border-color:#e07020;box-shadow:0 0 5px rgba(224,112,32,0.6);}
body.nerv .fi.in{border-left-color:#e07020;}
body.nerv .sd.g{background:#40b030;box-shadow:0 0 6px #40b030;}
body.nerv .sd.a{background:#e07020;box-shadow:0 0 6px #e07020;}
body.nerv #si:focus{border-color:#e07020;box-shadow:0 0 12px rgba(224,112,32,0.15);}
body.nerv .track-btn{background:rgba(224,112,32,0.1);border-color:#e07020;color:#e07020;}

@media(max-width:900px){#pl{display:none;}#pr{width:220px;}#dp{width:90vw;}#search-box{width:280px;}}
@media(max-width:600px){#pr{display:none;}}

/* FRONTLINE HOVER TOOLTIP */
#fz-tip{position:fixed;z-index:800;pointer-events:none;display:none;min-width:220px;max-width:280px;background:rgba(2,10,6,0.96);border:1px solid rgba(220,40,0,0.45);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 0 18px rgba(200,30,0,0.12),0 2px 24px rgba(0,0,0,0.6);}
#fz-tip.show{display:block;}
#fz-tip .fzt-head{padding:8px 11px 6px;border-bottom:1px solid rgba(220,40,0,0.22);display:flex;align-items:center;justify-content:space-between;gap:8px;}
#fz-tip .fzt-name{font-family:var(--ft);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:#ee2200;line-height:1.3;flex:1;}
#fz-tip .fzt-badge{font-family:var(--ft);font-size:8px;letter-spacing:1px;padding:2px 6px;border-radius:2px;flex-shrink:0;}
#fz-tip .fzt-body{padding:7px 11px 9px;font-family:var(--fm);font-size:10px;line-height:1.5;}
#fz-tip .fzr{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid rgba(40,80,140,0.08);}
#fz-tip .fzl{color:var(--text-dim);font-size:9px;}
#fz-tip .fzv{color:var(--accent);font-size:9px;text-align:right;}
#fz-tip .fzt-sum{margin-top:6px;padding-top:5px;border-top:1px solid rgba(40,80,140,0.1);font-size:9px;color:var(--text);line-height:1.5;font-family:var(--fu);}
#fz-tip .fzt-src{margin-top:5px;display:flex;align-items:center;justify-content:space-between;gap:6px;}
#fz-tip .fzt-src-lbl{font-family:var(--fm);font-size:8px;color:var(--text-dim);letter-spacing:1px;}
#fz-tip .fzt-src-lbl.live{color:var(--accent2);}
#fz-tip .fzt-wiki{font-family:var(--fm);font-size:8px;color:var(--accent);text-decoration:none;letter-spacing:0.5px;opacity:0.7;}
#fz-tip .fzt-wiki:hover{opacity:1;}
body.nerv #fz-tip{border-color:rgba(220,110,0,0.5);box-shadow:0 0 18px rgba(200,90,0,0.14);}
body.nerv #fz-tip .fzt-name{color:#e87020;}
body.nerv #fz-tip .fzv{color:#e07020;}

/* SOLAR SYSTEM ORRERY */
#orrery-overlay{position:fixed;top:42px;left:0;right:0;bottom:0;z-index:200;background:#06080e;display:none;overflow:hidden;cursor:crosshair;}
#orrery-overlay.active{display:block;}
#orrery-canvas{position:absolute;inset:0;width:100%;height:100%;}


#orrery-info{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:210;font-family:var(--fm);font-size:10px;color:rgba(255,170,0,0.3);letter-spacing:1px;opacity:0;transition:opacity 0.5s;}
#orrery-info.visible{opacity:1;}
/* Transition elements */
#transition-circle{position:fixed;z-index:250;border:1.5px solid var(--warning);border-radius:50%;pointer-events:none;display:none;}
/* Planet detail panel — orange/amber theme */
/* ── MUSIC PLAYER ── */
#mp-sidebar{position:relative;display:flex;align-items:stretch;overflow:visible;}
#mp-sidebar .mp-inner{flex:1;min-width:0;padding:8px 10px 10px 14px;}
#mp-float{position:fixed;top:52px;right:10px;width:320px;z-index:305;background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(14px);opacity:0;transform:translateY(-10px);transition:opacity 0.6s ease, transform 0.6s ease;display:flex;align-items:stretch;overflow:visible;}
#mp-float .mp-inner{flex:1;min-width:0;padding:10px 14px 12px;}
#mp-float.visible{display:flex!important;opacity:1;transform:translateY(0);}
#mp-float.visible + #planet-detail.open{top:auto;margin-top:0;}
.mp-track-info{margin-bottom:6px;}
.mp-title-wrap,.mp-artist-wrap{overflow:hidden;white-space:nowrap;position:relative;height:14px;}
.mp-title-wrap{height:16px;}
.mp-title{font-family:var(--ft);font-size:11px;letter-spacing:1px;color:var(--accent);display:inline-block;position:relative;}
.mp-artist{font-family:var(--fm);font-size:10px;color:var(--text-dim);display:inline-block;position:relative;}
.mp-title.scrolling,.mp-artist.scrolling{animation:mpScroll var(--scroll-dur,10s) linear infinite;}
@keyframes mpScroll{0%,12%{transform:translateX(0)}88%,100%{transform:translateX(var(--scroll-dist,-100px))}}
.mp-progress-row{margin:4px 0 2px;}
.mp-bar-wrap{width:100%;height:4px;background:rgba(255,255,255,0.06);cursor:pointer;position:relative;border:1px solid var(--border);}
.mp-bar-fill{height:100%;background:var(--accent);width:0%;transition:width 0.3s linear;}
.mp-time-row{display:flex;justify-content:space-between;margin-bottom:6px;}
.mp-time{font-family:var(--ft);font-size:8px;letter-spacing:1px;color:var(--text-dim);}
.mp-controls{display:flex;justify-content:center;gap:10px;}
.mp-btn{width:36px;height:28px;background:transparent;border:1.5px solid var(--accent);color:var(--accent);font-size:12px;cursor:pointer;font-family:var(--ft);position:relative;overflow:hidden;transition:border-color 0.2s;display:flex;align-items:center;justify-content:center;z-index:1;}
.mp-btn::before{content:'';position:absolute;bottom:0;left:0;right:0;height:0%;background:var(--accent);transition:height 0.35s cubic-bezier(0.25,0.46,0.45,0.94);z-index:-1;}
.mp-btn:hover::before{height:100%;}
.mp-btn:hover{border-color:var(--accent);}
.mp-btn span{position:relative;z-index:2;mix-blend-mode:difference;transition:color 0.2s;}
.mp-btn-play{width:42px;}
/* Volume strip — thin integrated edge of the player section */
.mp-vol-strip{width:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0;border-left:1px solid var(--border);transition:background 0.2s;}
.mp-vol-strip span{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--ft);font-size:7px;letter-spacing:2px;color:var(--accent);position:relative;z-index:2;mix-blend-mode:difference;pointer-events:none;user-select:none;}
.mp-vol-strip-fill{position:absolute;bottom:0;left:0;right:0;height:0%;background:var(--accent);transition:height 0.35s cubic-bezier(0.25,0.46,0.45,0.94);z-index:1;}
.mp-vol-strip:hover .mp-vol-strip-fill{height:100%;}
/* Float player: vol strip on left side */
.mp-vol-strip-left{border-left:none;border-right:1px solid var(--border);}
/* Volume tray — fixed position, placed by JS next to the strip */
.mp-vol-tray{width:32px;background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;padding:6px 2px;z-index:400;opacity:0;pointer-events:none;transition:opacity 0.25s ease;}
.mp-vol-tray.open{opacity:1;pointer-events:auto;}
/* Vertical range slider */
.mp-vol-slider{-webkit-appearance:none;appearance:none;width:4px;height:100%;background:rgba(255,255,255,0.06);border:1px solid var(--border);outline:none;cursor:pointer;writing-mode:vertical-lr;direction:rtl;}
.mp-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:6px;background:var(--accent);border:none;cursor:pointer;}
.mp-vol-slider::-moz-range-thumb{width:12px;height:6px;background:var(--accent);border:none;cursor:pointer;border-radius:0;}
#planet-detail{position:fixed;top:52px;right:10px;width:320px;max-height:calc(100vh - 70px);z-index:310;background:var(--panel);border:1px solid rgba(255,170,0,0.2);backdrop-filter:blur(14px);overflow-y:auto;display:none;font-family:var(--fm);font-size:11px;}
#planet-detail.open{display:block;}
#planet-detail::-webkit-scrollbar{width:3px;}#planet-detail::-webkit-scrollbar-thumb{background:rgba(255,170,0,0.2);}
.pd-header{font-family:var(--ft);font-size:13px;letter-spacing:3px;color:var(--warning);padding:12px 14px 8px;border-bottom:1px solid rgba(255,170,0,0.15);display:flex;justify-content:space-between;align-items:center;}
.pd-close{background:none;border:none;color:var(--warning);font-size:16px;cursor:pointer;padding:0 4px;}
.pd-section{padding:10px 14px;border-bottom:1px solid rgba(255,170,0,0.08);}
.pd-label{font-size:9px;letter-spacing:2px;color:rgba(255,170,0,0.4);font-family:var(--ft);margin-bottom:6px;}
.pd-row{display:flex;justify-content:space-between;padding:3px 0;}
.pd-row .k{color:var(--text-dim);font-size:10px;}
.pd-row .v{color:var(--text);font-size:11px;}
.pd-img{width:100%;border-radius:4px;margin:6px 0;border:1px solid rgba(255,170,0,0.1);}
.pd-news{padding:6px 8px;margin:4px 0;background:rgba(255,170,0,0.04);border-radius:3px;border-left:2px solid rgba(255,170,0,0.25);}
.pd-news .nt{color:var(--warning);font-size:10px;position:static;top:auto;left:auto;transform:none;letter-spacing:0;font-weight:normal;text-shadow:none;}
.pd-news .ns{color:var(--text-dim);font-size:9px;margin-top:2px;position:static;top:auto;left:auto;transform:none;letter-spacing:1px;white-space:normal;}
.sp-alert{padding:8px 10px;margin:6px 0;border-radius:3px;font-size:10px;border-left:3px solid;}
.sp-alert.storm{background:rgba(255,60,0,0.12);border-color:#ff3c00;color:#ff8844;}
.sp-alert.watch{background:rgba(255,170,0,0.12);border-color:var(--warning);color:#ffcc44;}
.sp-alert.info{background:rgba(0,180,255,0.08);border-color:var(--accent);color:#66ccff;}
.kp-bar{display:inline-block;width:18px;height:14px;margin:1px;border-radius:2px;text-align:center;font-size:8px;line-height:14px;font-family:var(--ft);color:#fff;}
/* Sidebar/header transition classes */
#pl.slide-out{transform:translateX(-230px);opacity:0;transition:all 0.6s ease;}
#pr.slide-out{transform:translateX(420px);opacity:0;transition:all 0.6s ease;}
#search-box.slide-out{opacity:0;transform:translateX(-50%) translateY(-60px);transition:all 0.5s ease;}
#bb.slide-out{opacity:0;transform:translateY(40px);transition:all 0.4s ease;}
#header .sys-info .disco{color:var(--danger)!important;animation:disco-blink 0.15s 6 alternate;}
@keyframes disco-blink{0%{opacity:1}100%{opacity:0.2}}
.kp-bar{display:inline-block;width:18px;height:14px;margin:1px;border-radius:2px;text-align:center;font-size:8px;line-height:14px;font-family:var(--ft);color:#fff;}
.sp-status{display:inline-block;font-size:9px;letter-spacing:1px;padding:1px 6px;border-radius:2px;font-family:var(--ft);}
/* Earthquake popup — override MapLibre defaults */
.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:var(--border);}
.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:var(--border);}
.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:var(--border);}
.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:var(--border);}
.eq-popup .maplibregl-popup-content{background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(14px);border-radius:0;padding:0;box-shadow:0 0 20px rgba(0,0,0,0.5);}
.eq-popup .maplibregl-popup-close-button{color:var(--text-dim);font-size:16px;font-family:var(--fm);padding:4px 8px;right:0;top:0;}
.eq-popup .maplibregl-popup-close-button:hover{color:var(--text);background:transparent;}
.eq-popup .maplibregl-popup-tip{border-width:6px;}
.eq-hdr{padding:8px 12px 6px;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:8px;}
.eq-hdr .eq-mag{font-family:var(--ft);font-size:14px;letter-spacing:2px;font-weight:bold;}
.eq-hdr .eq-type{font-family:var(--ft);font-size:8px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;}
.eq-body{padding:8px 12px;font-family:var(--fm);font-size:10px;line-height:1.7;color:var(--text);}
.eq-body .eq-place{color:var(--text);margin-bottom:4px;}
.eq-body .eq-row{display:flex;justify-content:space-between;color:var(--text-dim);border-bottom:1px solid rgba(128,128,128,0.08);padding:1px 0;}
.eq-body .eq-row span:last-child{color:var(--accent);}
.eq-body .eq-link{display:block;margin-top:6px;font-family:var(--ft);font-size:8px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;}

/* ── WEATHER LAYER TOGGLES ─────────────────────────────────────────────────── */
.wx-group{display:flex;flex-wrap:wrap;gap:4px;padding:6px 12px 8px;}
.wx-btn{
  font-family:var(--ft);font-size:8px;letter-spacing:2px;
  padding:4px 8px;border:1px solid var(--border);
  color:var(--text-dim);cursor:pointer;border-radius:2px;
  transition:all 0.2s;user-select:none;background:transparent;
}
.wx-btn:hover{border-color:var(--text-dim);color:var(--text);}
.wx-btn.on{
  border-color:#4da6ff;color:#4da6ff;
  background:rgba(77,166,255,0.1);
  box-shadow:0 0 6px rgba(77,166,255,0.2);
}

/* Disaster pin indicator colours in layer panel */
.lt [style*="ff4400"]{color:#ff8800;}
.lt [style*="00aaff"]{color:#00ccff;}
.lt [style*="ff3300"]{color:#ff6600;}
.lt [style*="00ddff"]{color:#00ddff;}
