:root{--bg:#0a0e12;--bg2:#11161c;--card:#141b22;--bd:#22303a;--tx:#dbe6ee;--tx2:#8aa0b0;
--ac:#3fb6a8;--ac2:#7fd1b9;--warn:#e0a23a;--red:#fb4d4d;--grn:#27c08a;--mono:'Fira Code',ui-monospace,monospace}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--tx);font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:14px}
a{color:var(--ac2);text-decoration:none;cursor:pointer}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--bd);flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:13px}
.logo{color:var(--ac);font-weight:800;letter-spacing:1px}.sep{color:var(--tx2)}.sec{color:var(--tx);font-weight:700;letter-spacing:1px}
.tag{color:var(--tx2);font-size:10px;border:1px solid var(--bd);border-radius:3px;padding:2px 6px;margin-left:6px}
.topright{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.who{font-size:11px;color:var(--tx2)}
select{background:var(--card);color:var(--tx);border:1px solid var(--bd);border-radius:4px;padding:4px 6px}
button{background:var(--ac);color:#04120e;border:0;border-radius:5px;padding:7px 14px;font-weight:700;cursor:pointer}
button:hover{background:var(--ac2)}.logout button{background:transparent;color:var(--tx2);border:1px solid var(--bd)}
.foot{padding:10px 16px;border-top:1px solid var(--bd);color:var(--tx2);font-size:11px;line-height:1.5}
/* login */
.loginwrap{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:30px}
.loginbox{background:var(--card);border:1px solid var(--bd);border-radius:10px;padding:28px;max-width:420px;width:100%}
.loginbox h1{font-size:18px;margin:0 0 6px}.loginbox .sub{color:var(--tx2);font-size:12px;margin:0 0 14px}
.loginbox .private{color:var(--warn);font-size:12px}.loginbox label{display:block;margin:10px 0;font-size:12px;color:var(--tx2)}
.loginbox input{width:100%;margin-top:4px;background:var(--bg);color:var(--tx);border:1px solid var(--bd);border-radius:5px;padding:9px}
.loginbox .err{color:var(--red);font-size:12px;background:rgba(251,77,77,.1);border:1px solid var(--red);padding:6px 10px;border-radius:5px}
.loginbox .disc{color:var(--tx2);font-size:10px;margin-top:14px;line-height:1.5}
/* layout */
.layout{display:flex;min-height:78vh}
.side{width:230px;background:var(--bg2);border-right:1px solid var(--bd);padding:10px 8px;display:flex;flex-direction:column;gap:2px}
.side .nav{padding:9px 12px;border-radius:6px;color:var(--tx2);font-size:13px;display:flex;justify-content:space-between;align-items:center}
.side .nav:hover{background:var(--card);color:var(--tx)}.side .nav.active{background:var(--card);color:var(--ac2);border-left:3px solid var(--ac)}
.content{flex:1;padding:18px 22px;overflow:auto}.content h2{font-size:16px;margin:4px 0 14px;border-bottom:1px solid var(--bd);padding-bottom:8px}
.tab{display:none}.tab.show{display:block}
.disclaimer-banner{background:rgba(224,162,58,.1);border:1px solid var(--warn);color:var(--warn);padding:8px 12px;border-radius:6px;font-size:12px;margin-bottom:16px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.kpi{background:var(--card);border:1px solid var(--bd);border-radius:8px;padding:12px}
.kpi .l{color:var(--tx2);font-size:10px;text-transform:uppercase;letter-spacing:1px}.kpi .v{font-size:18px;font-weight:700;margin-top:4px;font-family:var(--mono)}
.card{background:var(--card);border:1px solid var(--bd);border-radius:8px;padding:14px;margin:10px 0}
.card h3{margin:0 0 8px;font-size:14px}
table{width:100%;border-collapse:collapse;font-size:12.5px}td{padding:5px 4px;border-bottom:1px solid var(--bd);vertical-align:top}
td.k{color:var(--tx2);white-space:nowrap;width:34%}code{font-family:var(--mono);word-break:break-all;color:var(--ac2)}
.badge{font-size:9px;font-weight:800;letter-spacing:.5px;padding:2px 6px;border-radius:3px;margin-left:6px}
.badge.dry{background:rgba(224,162,58,.18);color:var(--warn)}.badge.pend{background:rgba(138,160,176,.18);color:var(--tx2)}
.badge.real{background:rgba(39,192,138,.18);color:var(--grn)}.badge.sealed{background:rgba(63,182,168,.18);color:var(--ac2)}
.badge.blocked{background:rgba(251,77,77,.14);color:var(--red)}.badge.onchain{background:rgba(39,192,138,.18);color:var(--grn)}
.ph{background:var(--card);border:1px dashed var(--bd);border-radius:8px;padding:22px;color:var(--tx2);font-size:13px}.ph.small{padding:10px 14px;margin-bottom:10px}
.muted{color:var(--tx2);font-size:11px}
.bar-row{display:flex;align-items:center;gap:8px;margin:5px 0;font-size:12px}
.bar-l{width:34%;color:var(--tx2)}.bar-v{width:32px;text-align:right;font-family:var(--mono)}
.bar{flex:1;height:10px;background:rgba(138,160,176,.14);border-radius:5px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--ac2)}
button.copy{font-size:9px;padding:1px 6px;margin-left:6px;border:1px solid var(--bd);background:transparent;color:var(--tx2);border-radius:3px;cursor:pointer}
button.copy:hover{color:var(--ac2);border-color:var(--ac2)}
[dir="rtl"] .bar-v{text-align:left}[dir="rtl"] td.k{text-align:right}
@media(max-width:720px){.layout{flex-direction:column}.side{width:auto;flex-direction:row;overflow-x:auto}}
/* ---- Depth Fusion Lab (experimental) ---- */
.badge.exp{background:rgba(224,162,58,.20);color:var(--warn);border:1px solid rgba(224,162,58,.4)}
.df-subnav{display:flex;flex-wrap:wrap;gap:4px;margin:10px 0 6px;border-bottom:1px solid var(--bd);padding-bottom:6px}
.dfsub{font-size:11px;padding:5px 10px;border:1px solid var(--bd);border-radius:5px;color:var(--tx2)}
.dfsub:hover{color:var(--tx);background:var(--card)}.dfsub.active{color:#04120e;background:var(--ac);font-weight:700}
.dfpanel{display:none}.dfpanel.show{display:block}
.df-warn{margin-top:8px;border-left:3px solid var(--warn);padding-left:8px}
.df-bar{position:relative;overflow:visible}.df-bar i.df-bar-na{background:var(--warn);opacity:.7}
.df-chance{position:absolute;top:-2px;height:14px;width:2px;background:var(--red);display:block}
.df-bar-row .bar-v,.bar-row .bar-v{min-width:auto}
.df-matrix th{color:var(--tx2);font-size:10px;text-transform:uppercase;text-align:left;border-bottom:1px solid var(--bd);padding:5px 4px}
.df-matrix td{font-size:11.5px}
.df-filter{width:100%;margin:6px 0 10px;background:var(--bg);color:var(--tx);border:1px solid var(--bd);border-radius:5px;padding:7px}
.df-btn{margin-top:10px;background:transparent;color:var(--ac2);border:1px solid var(--ac2)}
.df-modal{display:none;margin-top:10px;border:1px dashed var(--bd);border-radius:6px;padding:10px;background:var(--bg)}
.df-modal.show{display:block}
.df-pipeline{margin:10px 0}.df-step{background:var(--bg);border:1px solid var(--bd);border-radius:6px;padding:8px 12px;text-align:center;font-family:var(--mono);font-size:12px}
.df-arrow{text-align:center;color:var(--tx2);font-size:14px;margin:2px 0}
[dir="rtl"] .df-warn{border-left:0;border-right:3px solid var(--warn);padding-left:0;padding-right:8px}
/* GeaSpirit logo button — glow + pulse, returns to the public geaspirit.com menu */
a.home-link{display:inline-block;border-radius:4px;padding:1px 6px;text-decoration:none;animation:gs-pulse 2.2s ease-in-out infinite;transition:transform .15s ease,text-shadow .15s ease}
a.home-link:hover{transform:scale(1.06);text-shadow:0 0 12px rgba(127,209,185,.95),0 0 22px rgba(63,182,168,.6)}
@keyframes gs-pulse{0%,100%{text-shadow:0 0 5px rgba(63,182,168,.45),0 0 10px rgba(63,182,168,.25)}50%{text-shadow:0 0 12px rgba(127,209,185,.95),0 0 22px rgba(63,182,168,.55)}}
@media(prefers-reduced-motion:reduce){a.home-link{animation:none}}
/* Password show/hide eye toggle */
.pwwrap{position:relative;display:block}
.pwwrap input{padding-right:40px}
.pwtoggle{position:absolute;right:6px;top:50%;margin-top:2px;transform:translateY(-50%);background:transparent;border:0;padding:2px 4px;font-size:16px;line-height:1;color:var(--tx2);cursor:pointer}
.pwtoggle:hover{background:transparent;color:var(--ac2)}
[dir="rtl"] .pwwrap input{padding-right:9px;padding-left:40px}
[dir="rtl"] .pwtoggle{right:auto;left:6px}
/* ---- Data Quality / Coordinate Integrity (reuses Depth Fusion lab styling) ---- */
.cqsub{font-size:11px;padding:5px 10px;border:1px solid var(--bd);border-radius:5px;color:var(--tx2)}
.cqsub:hover{color:var(--tx);background:var(--card)}.cqsub.active{color:#04120e;background:var(--ac);font-weight:700}
.cqpanel{display:none}.cqpanel.show{display:block}
/* official GeaSpirit logo in the console header */
.logo-img{height:26px;width:auto;display:block;vertical-align:middle}
.home-link{display:inline-flex;align-items:center}
/* ---- Terrain Report form ---- */
.tr-form{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.tr-form label{display:flex;flex-direction:column;font-size:11px;color:var(--tx2);gap:3px}
.tr-form input{background:var(--bg);color:var(--tx);border:1px solid var(--bd);border-radius:5px;padding:7px;width:120px;font-family:var(--mono)}
.tr-form button{align-self:flex-end}
