:root{
  --bg:#06080f; --bg2:#0c1422; --panel:#101a2e; --panel2:#152b40;
  --panel-b:#1d2c46; --line:#22344f; --text:#dce8ff; --muted:#7e93b5;
  --accent:#33d6ff; --accent2:#c44dff; --good:#51e898; --bad:#ff6b6b; --warn:#ffd93d;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:
    radial-gradient(1200px 600px at 70% -10%, #122 0%, transparent 60%),
    radial-gradient(900px 500px at 10% 110%, #1a1030 0%, transparent 60%),
    var(--bg);
  color:var(--text);overflow:hidden;
  height:100dvh;display:flex;flex-direction:column;
}
.hidden{display:none !important}

/* galaxy / starfield behind everything */
#galaxy{
  position:fixed; inset:0; z-index:-1; background-color:#05060d;
  background-image:
    radial-gradient(1100px 620px at 72% -12%, rgba(72,52,125,.55), transparent 60%),
    radial-gradient(900px 520px at 8% 112%, rgba(36,42,105,.6), transparent 60%),
    radial-gradient(820px 600px at 50% 48%, rgba(28,60,100,.32), transparent 70%),
    radial-gradient(2px 2px at 40px 60px, #ffffff, transparent),
    radial-gradient(2px 2px at 180px 120px, #d6e6ff, transparent),
    radial-gradient(2.5px 2.5px at 260px 220px, #ffffff, transparent),
    radial-gradient(1.5px 1.5px at 90px 200px, #ead6ff, transparent),
    radial-gradient(2px 2px at 320px 90px, #ffffff, transparent),
    radial-gradient(2px 2px at 140px 300px, #c6dcff, transparent),
    radial-gradient(1.5px 1.5px at 30px 330px, #ffffff, transparent),
    radial-gradient(2.5px 2.5px at 300px 350px, #ffffff, transparent),
    radial-gradient(1.5px 1.5px at 225px 30px, #ffffff, transparent);
  background-repeat:no-repeat,no-repeat,no-repeat,repeat,repeat,repeat,repeat,repeat,repeat,repeat,repeat,repeat;
  background-size:auto,auto,auto,300px 300px,300px 300px,340px 340px,300px 300px,360px 360px,320px 320px,300px 300px,380px 380px,300px 300px;
}
#galaxy::after{
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(2px 2px at 60px 80px, rgba(255,255,255,.95), transparent),
    radial-gradient(2.5px 2.5px at 210px 180px, rgba(190,225,255,.95), transparent),
    radial-gradient(2px 2px at 130px 250px, rgba(255,255,255,.9), transparent);
  background-size:260px 260px,300px 300px,280px 280px;
  animation:twinkle 4.5s ease-in-out infinite alternate;
}
@keyframes twinkle{from{opacity:.3}to{opacity:.95}}
.muted{color:var(--muted)}
.error{color:var(--bad);min-height:18px;font-size:13px;margin-top:8px}

#topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid var(--line);background:rgba(8,12,22,.7);backdrop-filter:blur(6px);flex:0 0 auto}
.brand{font-weight:800;letter-spacing:2px;color:var(--accent);text-shadow:0 0 12px rgba(51,214,255,.5)}
.brand span{color:var(--accent2);text-shadow:0 0 12px rgba(196,77,255,.5)}
#userArea{display:flex;gap:10px;align-items:center;font-size:14px}
.brand-logo{height:34px;width:auto;max-width:62vw;object-fit:contain;display:block;filter:drop-shadow(0 0 10px rgba(51,214,255,.25))}
.tb-left{display:flex;align-items:center;gap:10px}
.acct{position:relative}
.acct-glyph{font-size:15px;color:var(--accent)}
.alert-wrap{position:relative}
.alert-btn{position:relative;background:#0a1220;border:1px solid var(--line);color:#3a4a66;width:38px;height:38px;border-radius:10px;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.alert-btn:hover{border-color:var(--accent)}
.alert-btn.active{color:var(--accent);border-color:var(--accent);animation:alertpulse 1.6s ease-in-out infinite}
@keyframes alertpulse{0%,100%{box-shadow:0 0 6px rgba(51,214,255,.25)}50%{box-shadow:0 0 18px rgba(51,214,255,.6)}}
.alert-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;border-radius:10px;background:var(--bad);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 0 8px var(--bad)}
.dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--panel);border:1px solid var(--line);border-radius:10px;min-width:185px;box-shadow:0 10px 30px rgba(0,0,0,.55);z-index:60;overflow:hidden;display:flex;flex-direction:column}
.dropdown.left{left:0;right:auto}
.dropdown button{background:transparent;border:none;border-radius:0;color:var(--text);text-align:left;padding:12px 14px;font-size:14px;white-space:nowrap}
.dropdown button:hover:not(:disabled){background:rgba(51,214,255,.12)}
.dropdown button:disabled{color:var(--muted);cursor:default}

.screen{flex:1 1 auto;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 0 30px rgba(0,0,0,.4)}
h1,h2,h3{margin:0 0 10px}
h1{font-size:26px} h2{font-size:18px} h3{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

.field{margin:10px 0}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
input,select{width:100%;padding:10px;border-radius:9px;border:1px solid var(--line);background:#0a1220;color:var(--text);font-size:14px}
input:focus,select:focus{outline:none;border-color:var(--accent)}
.check{display:flex;align-items:center;gap:8px;font-size:13px;margin:8px 0}
.check input{width:auto}
.row{display:flex;gap:8px}
.row input,.row select{flex:1}

/* custom choice groups (race / board) */
.choice-group{display:flex;gap:8px;flex-wrap:wrap}
.choice{flex:1 1 0;min-width:78px;background:#0a1220;border:1px solid var(--line);color:var(--muted);padding:11px 8px;border-radius:9px;display:flex;align-items:center;justify-content:center;gap:7px;font-weight:600;font-size:13px}
.choice:hover{border-color:var(--accent)}
.choice.active{color:var(--text);border-color:var(--accent);background:linear-gradient(180deg,rgba(51,214,255,.18),rgba(51,214,255,.05));box-shadow:0 0 12px rgba(51,214,255,.22)}
.choice-dot{width:10px;height:10px;border-radius:50%;background:#7e93b5;flex:0 0 auto}
.race-protoss .choice-dot{background:#33d6ff}
.race-terran .choice-dot{background:#ff9f1c}
.race-zerg .choice-dot{background:#c44dff}
.choice.race-protoss.active{border-color:#33d6ff;background:linear-gradient(180deg,rgba(51,214,255,.2),transparent);box-shadow:0 0 12px rgba(51,214,255,.3)}
.choice.race-terran.active{border-color:#ff9f1c;background:linear-gradient(180deg,rgba(255,159,28,.2),transparent);box-shadow:0 0 12px rgba(255,159,28,.3)}
.choice.race-zerg.active{border-color:#c44dff;background:linear-gradient(180deg,rgba(196,77,255,.2),transparent);box-shadow:0 0 12px rgba(196,77,255,.3)}

.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.opt-grid .field{margin:6px 0}

/* styled toggle switches */
.toggles{display:flex;flex-direction:column;gap:2px;margin-top:10px}
.toggle{display:flex;align-items:center;gap:11px;font-size:13px;padding:8px 4px;cursor:pointer;border-radius:8px}
.toggle:hover{background:rgba(255,255,255,.03)}
.toggle input{display:none}
.toggle .switch{position:relative;width:40px;height:22px;border-radius:20px;background:#1a2740;border:1px solid var(--line);flex:0 0 auto;transition:.15s}
.toggle .switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#7e93b5;transition:.15s}
.toggle input:checked + .switch{background:linear-gradient(180deg,#1f9fd6,#1577b0);border-color:var(--accent)}
.toggle input:checked + .switch::after{transform:translateX(18px);background:#fff}
.toggle em{color:var(--muted);font-style:normal;font-size:11px}

/* colonies list remove button */
.game-item .gi-actions{display:flex;gap:8px;align-items:center}
.gi-del{background:transparent;border:1px solid var(--line);color:var(--muted);width:30px;height:30px;padding:0;border-radius:8px;font-size:13px;line-height:1}
.gi-del:hover{border-color:var(--bad);color:var(--bad)}

button{cursor:pointer;font-family:inherit;border:none;border-radius:9px;padding:10px 14px;font-size:14px;font-weight:600;transition:.15s}
button:active{transform:translateY(1px)}
.primary{position:relative;overflow:hidden;background:linear-gradient(180deg,#0c1828,#05080f);color:#fff;border:1px solid rgba(120,200,255,.4);box-shadow:0 0 14px rgba(51,214,255,.12),inset 0 1px 0 rgba(255,255,255,.05);text-shadow:0 0 8px rgba(120,200,255,.35)}
.primary::before{content:'';position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:radial-gradient(1px 1px at 18% 35%,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 68% 60%,rgba(180,220,255,.7),transparent),radial-gradient(1px 1px at 42% 80%,rgba(255,255,255,.55),transparent),radial-gradient(1.5px 1.5px at 85% 30%,rgba(200,225,255,.6),transparent)}
.primary:hover{border-color:var(--accent);box-shadow:0 0 20px rgba(51,214,255,.4),inset 0 1px 0 rgba(255,255,255,.08)}
.primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}
.primary:disabled::before{opacity:.2}
.ghost{background:transparent;border:1px solid var(--line);color:var(--text)}
.ghost:hover{border-color:var(--accent)}
.block{width:100%;margin-top:8px}
.small{padding:6px 10px;font-size:12px}

.auth-card{max-width:460px;margin:5vh auto 0;background:linear-gradient(180deg,rgba(16,26,46,.92),rgba(12,20,34,.92))}
.auth-logo{display:block;width:100%;max-width:420px;height:auto;margin:2px auto 18px;filter:drop-shadow(0 0 22px rgba(51,214,255,.25))}
.auth-foot{text-align:center;font-size:11px;color:var(--muted);margin:16px auto 24px;opacity:.8}
.auth-foot a{color:var(--muted);text-decoration:underline}
.auth-foot a:hover{color:var(--accent)}
.auth-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:14px}
.link{color:var(--accent);cursor:pointer;text-decoration:underline}
.link:hover{filter:brightness(1.2)}
.quick-login{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.ql-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.ql-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.ql-buttons button{padding:12px 6px;font-size:13px}
@media (max-width:380px){.ql-buttons{grid-template-columns:1fr 1fr}}
.tabs{display:flex;gap:6px;margin:12px 0}
.tab{flex:1;background:#0a1220;border:1px solid var(--line);color:var(--muted)}
.tab.active{color:var(--accent);border-color:var(--accent)}
.opts{margin:10px 0;border:1px solid var(--line);border-radius:9px;padding:8px 12px}
.opts summary{cursor:pointer;color:var(--accent);font-size:13px}
hr{border:none;border-top:1px solid var(--line);margin:14px 0}

.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px;max-width:1100px;margin:0 auto}
.lobby-tabs{display:flex;gap:24px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.ltab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:6px 2px 12px;border-radius:0;font-weight:800;font-size:18px;letter-spacing:.5px}
.ltab.active{color:var(--accent);border-bottom-color:var(--accent);text-shadow:0 0 10px rgba(51,214,255,.35)}
.ltab:hover{color:var(--text)}

/* in-game lobby waiting room */
.lobby-room{flex:1 1 auto;min-height:0;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:18px;-webkit-overflow-scrolling:touch}
.lobby-card{width:100%;max-width:540px}
.lr-code{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin:8px 0 18px}
.lr-code-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.code-pill.big{font-size:24px;padding:8px 16px;letter-spacing:5px}
.lr-share{display:flex;gap:8px;flex-wrap:wrap}
.lr-players-head{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px}
.lr-players{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.lr-player{display:flex;align-items:center;gap:10px;padding:9px 11px;background:#0a1220;border:1px solid var(--line);border-radius:9px;font-size:14px}
.lr-player .pname{flex:1;font-weight:600}
.lr-player .ptag{font-size:12px;color:var(--muted)}
.lr-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.lr-actions .primary{flex:1;min-width:120px}
.lr-wait{flex:1;text-align:center;font-size:13px}
.lr-hint{margin-top:14px;font-size:12px}

.games-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.game-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#0a1220;cursor:pointer}
.game-item:hover{border-color:var(--accent)}
.game-item.yourturn{border-color:var(--good);box-shadow:0 0 12px rgba(81,232,152,.25)}
.game-item .gi-meta{font-size:12px;color:var(--muted)}
.badge{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:700}
.badge.turn{background:var(--good);color:#022}
.badge.lobby{background:var(--warn);color:#220}
.badge.ended{background:#444;color:#ccc}
.badge.play{background:#1577b0;color:#fff}
.dots{display:flex;gap:3px}
.dot{width:10px;height:10px;border-radius:50%}

/* GAME */
#screen-game{display:flex;flex-direction:column;min-height:0;overflow:hidden}
#gameTopbar{display:flex;align-items:center;gap:10px;padding:6px 12px;border-bottom:1px solid var(--line);background:rgba(8,12,22,.7);flex:0 0 auto}
#gameHeader{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#gameHeader b{color:var(--text)}
.code-pill{display:inline-block;background:#0a1220;border:1px solid var(--accent);color:var(--accent);padding:2px 8px;border-radius:6px;font-family:monospace;letter-spacing:2px}

.top-hand{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;justify-content:center;padding:8px 12px;border-bottom:1px solid var(--line);background:var(--bg2);flex:0 0 auto;-webkit-overflow-scrolling:touch}
.status-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--line);background:rgba(8,12,22,.55);flex:0 0 auto}
#turnStatus{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#metaInfo{font-size:12px;color:var(--muted);white-space:nowrap;flex:0 0 auto}
.res-chip{display:flex;align-items:center;gap:5px;background:#0a1220;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:14px;font-weight:700;flex:0 0 auto}
.res-chip .ic{font-size:15px}

.game-body{display:grid;grid-template-columns:1fr 360px;flex:1 1 auto;min-height:0}
.board-wrap{position:relative;background:radial-gradient(circle at 50% 42%, rgba(40,70,120,.18), transparent 65%);overflow:hidden;min-height:0}
#board{width:100%;height:100%;display:block;touch-action:none}
.board-banner{position:absolute;top:10px;left:50%;transform:translateX(-50%);background:rgba(8,14,26,.9);border:1px solid var(--line);padding:7px 14px;border-radius:30px;font-size:13px;font-weight:600;text-align:center;max-width:88%;pointer-events:none}
.board-controls{position:absolute;right:10px;bottom:10px;display:flex;flex-direction:column;gap:6px}
.board-controls button{width:40px;height:40px;padding:0;font-size:20px;background:rgba(10,18,32,.85);border:1px solid var(--line);color:var(--text);border-radius:10px}
.board-controls button:hover{border-color:var(--accent)}
.sidebar{border-left:1px solid var(--line);background:var(--bg2);display:flex;flex-direction:column;overflow:auto;padding:10px;gap:8px;-webkit-overflow-scrolling:touch}
.panel{border:1px solid var(--line);border-radius:9px;background:#0a1220}
.panel>summary{cursor:pointer;padding:8px 10px;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);list-style:none}
.panel>summary::-webkit-details-marker{display:none}
.panel>summary::before{content:'▸ ';color:var(--accent)}
.panel[open]>summary::before{content:'▾ '}
.panel>*:not(summary){margin:0 8px 8px}

.action-bar{display:flex;flex-wrap:wrap;gap:6px}
.action-bar button{flex:1 1 auto;padding:11px 10px;font-size:13px;min-height:42px}

.players-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}
.ptile{background:#0a1220;border:1px solid var(--line);border-radius:10px;padding:9px 10px}
.ptile.active{border-color:var(--good);box-shadow:0 0 10px rgba(81,232,152,.2)}
.ptile.offline{opacity:.5}
.pt-top{display:flex;align-items:center;gap:7px;margin-bottom:3px}
.pt-top .pcolor{width:12px;height:12px;border-radius:50%;flex:0 0 auto}
.pt-name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-sub{font-size:11px;color:var(--muted);margin-bottom:7px;min-height:13px}
.pt-stats{display:flex;justify-content:space-between;gap:6px;font-size:13px;font-weight:700}
.pt-stats span{display:flex;align-items:center;gap:3px}
.pt-stats .vp{color:var(--warn)}
.mini-ping{margin-top:8px;width:100%;font-size:11px;padding:5px}

.side-tabs{display:flex;gap:6px}
.stab{flex:1;background:#0a1220;border:1px solid var(--line);color:var(--muted);font-size:12px;padding:6px}
.stab.active{color:var(--accent);border-color:var(--accent)}
.feed{height:200px;overflow:auto;background:#080e18;border:1px solid var(--line);border-radius:8px;padding:8px;font-size:12.5px;display:flex;flex-direction:column;gap:4px;-webkit-overflow-scrolling:touch}
.feed .l-row{color:var(--muted)}
.feed .c-row b{color:var(--text)}
.chat-box{display:flex;gap:6px;margin-top:6px}
.chat-box input{flex:1}
.badge-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--bad);box-shadow:0 0 8px var(--bad);margin-left:2px}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--panel);border:1px solid var(--accent);padding:12px 20px;border-radius:30px;z-index:50;box-shadow:0 0 20px rgba(51,214,255,.4);font-size:14px}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:60;backdrop-filter:blur(3px)}
.modal{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--accent);border-radius:14px;padding:20px;max-width:440px;width:92%;max-height:85dvh;overflow:auto;-webkit-overflow-scrolling:touch;box-shadow:0 0 40px rgba(51,214,255,.25)}
.modal h3{color:var(--accent)}
.res-pick{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.res-pick button{background:#0a1220;border:1px solid var(--line)}
.res-pick button.sel{border-color:var(--accent);color:var(--accent)}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}
.cost-tag{font-size:11px;color:var(--muted)}

/* settings modal */
.set-section{margin:14px 0;padding-top:12px;border-top:1px solid var(--line)}
.set-section:first-of-type{border-top:none;padding-top:0}
.set-h{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:8px}
.set-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;font-size:14px}
.set-row b{color:var(--text)}
.set-quiet{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:8px}
.set-quiet label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.set-quiet select{width:auto;padding:8px}

@media (max-width:820px){
  /* center the logo on phones, keep account controls compact on the right */
  #topbar{justify-content:center;position:relative}
  #userArea{position:absolute;right:8px;top:50%;transform:translateY(-50%);gap:6px}
  #userName{display:none}
  .brand-logo{height:30px;max-width:46vw}
  .alert-wrap{position:absolute;left:8px;top:50%;transform:translateY(-50%)}
  .tb-left{position:static}
  .lobby-grid{grid-template-columns:1fr}
  .game-body{grid-template-columns:1fr;grid-template-rows:42dvh 1fr}
  .board-wrap{min-height:0}
  .sidebar{border-left:none;border-top:1px solid var(--line)}
  .action-bar button{flex:1 1 40%}
  .feed{height:34dvh}
  .board-controls button{width:44px;height:44px}
  .top-hand{justify-content:space-between;gap:4px}
  .players-panel{grid-template-columns:repeat(auto-fit,minmax(104px,1fr))}
}
