/* GeoQuest Admin Dashboard — Mission Control Styles */

:root{
  --bg:#070a0f;--surface:#0d1117;--panel:#111820;--border:#1c2433;
  --border2:#243040;--accent:#00d4ff;--gold:#f5c842;--red:#ff4455;
  --green:#00e87a;--orange:#ff8c00;--text:#8ba0b8;--bright:#ddeeff;
  --mono:'Space Mono',monospace;--sans:'Syne',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--mono);background:var(--bg);color:var(--text);min-height:100vh;overflow:hidden;display:flex;flex-direction:column}
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,212,255,0.012) 2px,rgba(0,212,255,0.012) 4px);pointer-events:none;z-index:9999}

/* LOGIN */
#login-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:8000;flex-direction:column}
.login-box{border:1px solid var(--border2);background:var(--surface);padding:3rem;width:380px;position:relative;animation:glitch .5s ease both}
@keyframes glitch{0%{opacity:0;clip-path:inset(50% 0 50% 0)}50%{clip-path:inset(0);opacity:1}100%{clip-path:inset(0);opacity:1}}
.login-box::before{content:'';position:absolute;top:-1px;left:-1px;right:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:scan 3s linear infinite}
@keyframes scan{0%,100%{opacity:.3}50%{opacity:1}}
.login-title{font-family:var(--sans);font-size:1.6rem;font-weight:800;color:var(--bright);margin-bottom:.25rem}
.login-sub{font-size:.65rem;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;margin-bottom:2rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin-bottom:.4rem}
.field input{width:100%;background:var(--bg);border:1px solid var(--border2);color:var(--bright);font-family:var(--mono);font-size:.9rem;padding:.6rem .75rem;outline:none;transition:border-color .2s}
.field input:focus{border-color:var(--accent)}
.btn-login{width:100%;padding:.75rem;background:var(--accent);border:none;color:var(--bg);font-family:var(--sans);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn-login:hover{background:#00b8d9}
.login-err{color:var(--red);font-size:.7rem;margin-top:.5rem;display:none}

/* TOPBAR */
.topbar{height:48px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.25rem;gap:1.5rem;flex-shrink:0;z-index:100}
.logo{font-family:var(--sans);font-size:.95rem;font-weight:800;color:var(--bright);display:flex;align-items:center;gap:.5rem}
.logo span{color:var(--accent)}
.sep{width:1px;height:24px;background:var(--border)}
.tab{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text);cursor:pointer;padding:.3rem .6rem;border:1px solid transparent;transition:all .15s}
.tab:hover{color:var(--bright)}
.tab.active{color:var(--accent);border-color:var(--border2);background:var(--panel)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}
.status-pill{display:flex;align-items:center;gap:.4rem;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .6rem;border:1px solid var(--border2);background:var(--panel)}
.dot{width:6px;height:6px;border-radius:50%;animation:pulse 1.5s infinite}
.dot-green{background:var(--green)}.dot-orange{background:var(--orange)}.dot-red{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.btn-top{padding:.4rem .9rem;border:1px solid;font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn-launch{background:var(--green);border-color:var(--green);color:var(--bg)}
.btn-launch:hover{background:#00c068}
.btn-launch:disabled{opacity:.4;cursor:not-allowed}
.btn-stop{background:transparent;border-color:var(--red);color:var(--red);display:none}
.btn-stop.visible{display:block}

/* MAIN */
.main{flex:1;display:flex;overflow:hidden;min-height:0}

/* LEFT PANEL */
.left{width:300px;min-width:300px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-height:0}
.ph{padding:.85rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.pt{font-family:var(--sans);font-size:.8rem;font-weight:700;color:var(--bright)}
.pc{font-size:.6rem;letter-spacing:.15em;color:var(--accent);text-transform:uppercase}

/* Form */
.room-form{padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}
.lbl{display:block;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin-bottom:.3rem}
.inp{width:100%;background:var(--bg);border:1px solid var(--border2);color:var(--bright);font-family:var(--mono);font-size:.8rem;padding:.5rem .65rem;outline:none;margin-bottom:.5rem;transition:border-color .2s}
.inp:focus{border-color:var(--accent)}
.inp::placeholder{color:var(--border2)}
.row{display:flex;gap:.5rem}
.btn-sm{flex:1;padding:.5rem;border:1px solid var(--border2);background:var(--panel);color:var(--text);font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn-sm:hover{border-color:var(--accent);color:var(--accent)}
.btn-sm.acc{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}
.btn-sm.acc:hover{background:#00b8d9}
.btn-sm.del{border-color:rgba(255,68,85,.35);color:var(--red)}
.btn-sm.del:hover{border-color:var(--red);color:var(--red);background:rgba(255,68,85,.08)}

/* Room code */
.room-banner{padding:.75rem 1.25rem;border-bottom:1px solid var(--border);background:var(--panel);text-align:center;display:none}
.room-banner.show{display:block}
.room-code-big{font-family:var(--sans);font-size:1.8rem;font-weight:800;color:var(--gold);letter-spacing:.3em}
.room-hint{font-size:.6rem;letter-spacing:.15em;color:var(--text);text-transform:uppercase;margin-top:.2rem}

/* Clue list */
.clue-list{flex:1;overflow-y:auto;padding:.75rem 1.25rem}
.clue-item{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--border2);margin-bottom:.5rem;cursor:pointer;transition:all .2s;animation:sli .2s ease both}
@keyframes sli{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
.clue-item:hover{border-left-color:var(--accent)}
.clue-item.sel{border-left-color:var(--accent);background:rgba(0,212,255,.05)}
.ci-head{padding:.55rem .75rem;display:flex;align-items:center;gap:.6rem}
.ci-num{font-family:var(--sans);font-size:.7rem;font-weight:800;color:var(--accent);width:18px}
.ci-txt{flex:1;font-size:.7rem;color:var(--bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-acts{display:flex;border-top:1px solid var(--border)}
.ci-btn{flex:1;padding:.3rem;background:transparent;border:none;border-right:1px solid var(--border);color:var(--text);font-size:.6rem;cursor:pointer;transition:all .15s;font-family:var(--mono)}
.ci-btn:last-child{border-right:none}
.ci-btn:hover{background:var(--border);color:var(--bright)}
.ci-btn.del:hover{background:rgba(255,68,85,.1);color:var(--red)}
.add-clue{width:100%;padding:.55rem;background:transparent;border:1px dashed var(--border2);color:var(--text);font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s;margin-top:.5rem}
.add-clue:hover{border-color:var(--accent);color:var(--accent)}

/* MAP */
.map-area{flex:1;position:relative;overflow:hidden;min-height:0}
#map{width:100%;height:100%}
.mode-bar{position:absolute;top:1rem;left:50%;transform:translateX(-50%);background:rgba(13,17,23,.95);border:1px solid var(--border2);display:flex;z-index:1000;backdrop-filter:blur(8px)}
.mbt{padding:.45rem .9rem;font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text);cursor:pointer;border:none;background:transparent;border-right:1px solid var(--border);transition:all .15s}
.mbt:last-child{border-right:none}
.mbt:hover{color:var(--bright);background:var(--border)}
.mbt.active{color:var(--accent);background:rgba(0,212,255,.08)}

/* Clue popup */
.cp-form{position:absolute;top:1rem;right:1rem;width:290px;background:rgba(13,17,23,.97);border:1px solid var(--border2);z-index:1000;backdrop-filter:blur(12px);display:none;animation:fup .2s ease both}
@keyframes fup{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.cp-form.show{display:block}
.cp-head{padding:.7rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cp-title{font-family:var(--sans);font-size:.75rem;font-weight:700;color:var(--bright)}
.cp-close{background:none;border:none;color:var(--text);cursor:pointer;font-size:1rem}
.cp-close:hover{color:var(--red)}
.cp-body{padding:.85rem;display:flex;flex-direction:column;gap:.55rem}
textarea.inp{resize:vertical;min-height:60px;line-height:1.5}
.rad-row{display:flex;align-items:center;justify-content:space-between;font-size:.7rem}
.rad-val{color:var(--accent);font-weight:700}
input[type=range]{width:100%;accent-color:var(--accent)}
.photo-toggle{display:flex;align-items:center;gap:.5rem;font-size:.7rem;cursor:pointer}
.photo-toggle input{accent-color:var(--accent)}

/* RIGHT PANEL */
.right{width:240px;min-width:240px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-height:0}
.players-list{flex:1;overflow-y:auto;padding:.4rem 0}
.pr{padding:.55rem 1.25rem;display:flex;align-items:center;gap:.65rem;transition:background .15s;cursor:pointer}
.pr:hover{background:var(--panel)}
.pav{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}
.pi{flex:1;min-width:0}
.pn{font-size:.72rem;color:var(--bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--sans);font-weight:600}
.ps{font-size:.6rem;color:var(--text);margin-top:.1rem}
.pb{font-size:.6rem;color:var(--accent);font-family:var(--mono);flex-shrink:0}
.kick{background:none;border:none;color:transparent;cursor:pointer;font-size:.75rem;transition:color .15s;flex-shrink:0}
.pr:hover .kick{color:var(--red)}
.stats-bar{padding:.65rem 1.25rem;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.sv{font-family:var(--sans);font-size:1rem;font-weight:800;color:var(--bright);text-align:center}
.sl{font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin-top:.1rem;text-align:center}

/* Account */
.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}
.account-card{border:1px solid var(--border2);background:var(--panel);border-radius:10px;padding:.75rem}
.account-label{font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}
.account-value{margin-top:.4rem;color:var(--bright);font-family:var(--sans);font-weight:700;font-size:.9rem}
.account-card.stat{background:linear-gradient(140deg,rgba(0,212,255,.08),rgba(14,19,24,.2));border-color:#1f2a39}
.account-hero{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;justify-content:space-between;margin-bottom:1rem;padding:1rem;border:1px solid #1f2a39;border-radius:12px;background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(14,19,24,.6))}
.account-hero-label{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:#9db0c6}
.account-hero-name{font-family:var(--sans);font-size:1.4rem;color:var(--bright);font-weight:800;margin-top:.3rem}
.account-hero-sub{margin-top:.2rem;font-size:.75rem;color:#9db0c6}
.account-hero-meta{display:flex;gap:1.5rem}

/* Bounds styling */
.bounds-handle{width:14px;height:14px;border-radius:50%;background:#00d4ff;border:2px solid #0b1118;box-shadow:0 0 10px rgba(0,212,255,.35)}
.bounds-center{width:16px;height:16px;border-radius:4px;background:#f5c842;border:2px solid #0b1118;box-shadow:0 0 10px rgba(245,200,66,.35)}

/* Admin location marker */
.admin-location-marker{width:18px;height:18px;border-radius:50%;background:#3dcf8c;border:2px solid #0b1118;box-shadow:0 0 18px rgba(61,207,140,.5)}

/* Toast */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(60px);background:var(--panel);border:1px solid var(--border2);border-left:3px solid var(--accent);padding:.55rem 1.1rem;font-size:.7rem;color:var(--bright);transition:transform .3s ease;z-index:9000;white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.err{border-left-color:var(--red)}

::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}
.leaflet-popup-content-wrapper{background:var(--panel);border:1px solid var(--border2);border-radius:2px;color:var(--bright);font-family:var(--mono);font-size:.75rem;box-shadow:0 4px 20px rgba(0,0,0,.5)}
.leaflet-popup-tip{background:var(--panel)}
