:root{
  --bg:#080b16;
  --panel:rgba(255,255,255,.045);
  --panel-strong:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.09);
  --border-bright:rgba(255,255,255,.16);
  --text:#e8edf9;
  --muted:#93a0bd;
  --faint:#5f6b86;
  --red:#ff5a60;
  --red-2:#e02a37;
  --blue:#54a0ff;
  --blue-2:#2f6fed;
  --teal:#33e0c0;
  --white-tok:#eef2fb;
  --radius:18px;
  --radius-sm:11px;
  --shadow:0 20px 60px -18px rgba(0,0,0,.75);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;font-family:var(--font);color:var(--text);
  background:var(--bg);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh;
}
.aurora{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 15% -10%, rgba(84,160,255,.16), transparent 60%),
    radial-gradient(55vw 55vw at 100% 10%, rgba(255,90,96,.13), transparent 55%),
    radial-gradient(70vw 70vw at 50% 120%, rgba(51,224,192,.10), transparent 60%),
    linear-gradient(180deg,#0a0e1c,#070a13);
}

/* ---------- top bar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;
}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:19px;letter-spacing:-.02em}
.brand-mark{width:26px;height:26px}
.brand-mark polygon{fill:none;stroke:url(#g);stroke-width:6;stroke:var(--blue)}
.brand-mark{filter:drop-shadow(0 0 10px rgba(84,160,255,.5))}
.topbar-right{display:flex;align-items:center;gap:10px}
.icon-btn{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--border);
  background:var(--panel);color:var(--muted);cursor:pointer;font-size:15px;
  display:grid;place-items:center;transition:.18s;backdrop-filter:blur(8px);
}
.icon-btn:hover{color:var(--text);border-color:var(--border-bright);background:var(--panel-strong)}
.conn{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);padding:6px 11px;border-radius:20px;border:1px solid var(--border);background:var(--panel)}
.conn i{width:8px;height:8px;border-radius:50%;background:var(--faint);box-shadow:0 0 0 0 rgba(0,0,0,0)}
.conn-on i{background:var(--teal);box-shadow:0 0 10px var(--teal)}
.conn-off i{background:#ffb020;box-shadow:0 0 10px #ffb020}

/* ---------- layout / screens ---------- */
main{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:8px 22px 40px}
.screen{animation:fade .4s ease}
.hidden{display:none !important}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- panels ---------- */
.panel{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow);
}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.panel-head h2,.scoreboard h2{margin:0;font-size:15px;font-weight:700;letter-spacing:.01em}

/* ---------- home ---------- */
.home-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;align-items:start;margin-top:10px}
.hero{padding:34px}
.hero h1{margin:0 0 10px;font-size:46px;font-weight:800;letter-spacing:-.03em;
  background:linear-gradient(120deg,#fff,#9fc2ff 55%,#ff9aa0);-webkit-background-clip:text;background-clip:text;color:transparent}
.sub{color:var(--muted);line-height:1.55;margin:0 0 22px;font-size:15px}
.field-label{display:block;font-size:12.5px;color:var(--muted);margin:0 0 8px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.field-label.spaced-top{margin-top:26px}
.text-input{
  width:100%;padding:15px 16px;font-size:17px;font-family:inherit;color:var(--text);
  background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:var(--radius-sm);
  outline:none;transition:.18s;margin-bottom:16px;
}
.text-input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(84,160,255,.16)}
.text-input::placeholder{color:var(--faint)}
.hint{color:var(--faint);font-size:12.5px;line-height:1.5;margin:14px 0 0}

.btn{
  font-family:inherit;font-weight:600;font-size:15px;cursor:pointer;border:none;border-radius:var(--radius-sm);
  padding:13px 20px;transition:transform .12s,box-shadow .2s,background .2s,opacity .2s;color:#fff;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-lg{width:100%;padding:16px;font-size:16px}
.btn-primary{background:linear-gradient(120deg,var(--blue-2),var(--blue));box-shadow:0 12px 30px -10px rgba(47,111,237,.7)}
.btn-primary:hover{box-shadow:0 16px 40px -10px rgba(84,160,255,.85)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn-ghost{background:var(--panel-strong);color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text);border-color:var(--border-bright)}
.btn-danger{color:#ff9ba0}
.btn-danger:hover{background:rgba(255,90,96,.12);border-color:rgba(255,90,96,.4);color:#ffc2c5}

/* ---------- scoreboard ---------- */
.scoreboard{padding:22px}
.tag{font-size:11px;color:var(--muted);background:var(--panel-strong);border:1px solid var(--border);padding:4px 10px;border-radius:20px;font-weight:600}
.table-wrap{max-height:430px;overflow-y:auto;margin:0 -6px}
table{width:100%;border-collapse:collapse;font-size:14px}
th{position:sticky;top:0;background:rgba(12,16,28,.9);backdrop-filter:blur(6px);text-align:left;color:var(--faint);
  font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:9px 10px;z-index:1}
td{padding:11px 10px;border-top:1px solid var(--border)}
th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}
th.rank,td.rank{width:38px;text-align:center;color:var(--faint)}
tbody tr{transition:background .15s}
tbody tr:hover{background:rgba(255,255,255,.03)}
.name-cell{font-weight:600;display:flex;align-items:center;gap:8px}
.medal{font-size:14px}
.wins{color:var(--teal);font-weight:700}
.losses{color:var(--muted)}
.empty{color:var(--faint);text-align:center;padding:26px}
tr.me td{background:rgba(84,160,255,.08)}
tr.flash td{animation:rowflash 1.4s ease}
@keyframes rowflash{0%{background:rgba(51,224,192,.28)}100%{background:transparent}}

/* ---------- searching / setup cards ---------- */
.center-card{max-width:460px;margin:6vh auto 0;padding:40px 34px;text-align:center}
.center-card h2{margin:6px 0 8px;font-size:24px}
.radar{position:relative;width:90px;height:90px;margin:0 auto 18px}
.radar.sm{width:56px;height:56px;margin-bottom:12px}
.radar span{position:absolute;inset:0;border-radius:50%;border:2px solid var(--blue);opacity:0;animation:ping 2.1s cubic-bezier(0,.2,.8,1) infinite}
.radar span:nth-child(2){animation-delay:.7s}
.radar span:nth-child(3){animation-delay:1.4s}
@keyframes ping{0%{transform:scale(.35);opacity:.9}80%,100%{transform:scale(1);opacity:0}}
.center-card .btn-ghost{margin-top:22px}

.toggle{display:flex;gap:6px;background:rgba(0,0,0,.28);padding:6px;border-radius:14px;border:1px solid var(--border);margin:6px 0 4px}
.toggle-opt{flex:1;padding:11px;border-radius:9px;border:none;background:transparent;color:var(--muted);font-family:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:.16s}
.toggle-opt:hover{color:var(--text)}
.toggle-opt.active{background:linear-gradient(120deg,var(--blue-2),var(--blue));color:#fff;box-shadow:0 8px 20px -8px rgba(47,111,237,.7)}
#start-btn{margin-top:18px}
#setup-leave{margin-top:18px}

.chip{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:700;vertical-align:middle}
.chip-red{background:rgba(255,90,96,.16);color:#ff9599;border:1px solid rgba(255,90,96,.3)}
.chip-blue{background:rgba(84,160,255,.16);color:#a9cdff;border:1px solid rgba(84,160,255,.3)}
.chip-white{background:rgba(238,242,251,.14);color:#eef2fb;border:1px solid rgba(238,242,251,.3)}

/* ---------- game ---------- */
.game-layout{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:start;margin-top:6px}
.board-stage{min-width:0}
.board-frame{position:relative;border-radius:24px;padding:14px;
  background:radial-gradient(120% 120% at 50% 0,rgba(84,160,255,.06),transparent 60%),var(--panel);
  border:1px solid var(--border);box-shadow:var(--shadow);backdrop-filter:blur(14px)}
#board{width:100%;height:auto;display:block;touch-action:manipulation}

.board-overlay{position:absolute;inset:0;display:grid;place-items:center;
  background:rgba(6,9,18,.55);backdrop-filter:blur(6px);border-radius:24px;animation:fade .35s ease}
.overlay-card{padding:32px 34px;text-align:center;max-width:360px}
.overlay-emblem{font-size:46px;margin-bottom:6px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.5))}
.overlay-card h2{margin:4px 0 8px;font-size:26px}
.overlay-actions{display:flex;gap:10px;margin-top:22px}
.overlay-actions .btn{flex:1}

/* side panel */
.side{display:flex;flex-direction:column;gap:14px}
.players{padding:16px}
.player{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;transition:.2s}
.player .pname{font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.player .ptokens{font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}
.player.turn{background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px var(--border-bright)}
.player.turn.red{box-shadow:inset 0 0 0 1px rgba(255,90,96,.5),0 0 22px -6px rgba(255,90,96,.5)}
.player.turn.blue{box-shadow:inset 0 0 0 1px rgba(84,160,255,.5),0 0 22px -6px rgba(84,160,255,.5)}
.dot{width:14px;height:14px;border-radius:50%;flex:none}
.dot-red{background:radial-gradient(circle at 35% 30%,#ff9497,var(--red-2));box-shadow:0 0 12px rgba(255,90,96,.6)}
.dot-blue{background:radial-gradient(circle at 35% 30%,#9cc6ff,var(--blue-2));box-shadow:0 0 12px rgba(84,160,255,.6)}
.vs{text-align:center;color:var(--faint);font-size:11px;font-weight:600;letter-spacing:.1em;margin:-2px 0}

.status{padding:16px}
.status-phase{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.progress-text{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.turn-banner{font-size:16px;font-weight:700;padding:12px 14px;border-radius:12px;background:rgba(0,0,0,.22);text-align:center;transition:.25s}
.turn-banner.you{background:linear-gradient(120deg,rgba(51,224,192,.16),rgba(84,160,255,.14));box-shadow:inset 0 0 0 1px rgba(51,224,192,.3)}
.prompt{margin-top:10px;font-size:13.5px;color:var(--muted);line-height:1.5;min-height:1px}
.prompt.act{color:var(--teal);font-weight:600}

/* current-rules readout (between the status and the moves log) */
.rules{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.rules-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.rules-value{font-size:13px;font-weight:700;color:var(--text);background:var(--panel-strong);border:1px solid var(--border);padding:3px 10px;border-radius:20px;white-space:nowrap}

.log-panel{padding:16px;flex:1}
.log{list-style:none;margin:0;padding:0;max-height:230px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
.log li{font-size:13px;color:var(--muted);padding:7px 10px;border-radius:9px;background:rgba(255,255,255,.02);border-left:2px solid var(--border);animation:fade .3s ease}
.log li.red{border-left-color:var(--red)}
.log li.blue{border-left-color:var(--blue)}
.log li b{color:var(--text)}
.log li .mill{color:var(--teal);font-weight:600}

/* ---------- in-game chat ---------- */
.chat{padding:16px;display:flex;flex-direction:column}
.chat .panel-head{margin-bottom:10px}
.chat-log{list-style:none;margin:0 0 10px;padding:0;max-height:190px;min-height:52px;overflow-y:auto;display:flex;flex-direction:column;gap:7px}
.chat-log:empty::before{content:"Say hello 👋";color:var(--faint);font-size:12.5px;display:block;text-align:center;padding:16px 0}
.chat-msg{max-width:88%;padding:6px 10px;border-radius:12px;font-size:13px;line-height:1.4;background:rgba(255,255,255,.045);border:1px solid var(--border);align-self:flex-start;animation:fade .25s ease;word-break:break-word}
.chat-msg.mine{align-self:flex-end;background:rgba(255,255,255,.09)}
.chat-from{display:block;font-size:10.5px;font-weight:700;letter-spacing:.02em;margin-bottom:1px;color:var(--muted)}
.chat-msg.red .chat-from{color:#ff9599}
.chat-msg.blue .chat-from{color:#a9cdff}
.chat-text{color:var(--text)}
.chat-form{display:flex;gap:8px}
.chat-input{flex:1;min-width:0;padding:10px 12px;font-size:14px;font-family:inherit;color:var(--text);background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:10px;outline:none;transition:.16s}
.chat-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(84,160,255,.14)}
.chat-input::placeholder{color:var(--faint)}
.chat-send{flex:none;padding:10px 15px;font-size:13px}

/* toasts */
.toasts{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:10px;z-index:50;align-items:center;pointer-events:none}
.toast{background:rgba(16,20,34,.92);border:1px solid var(--border-bright);padding:12px 18px;border-radius:12px;font-size:14px;font-weight:500;
  box-shadow:var(--shadow);backdrop-filter:blur(10px);animation:toastin .35s cubic-bezier(.2,.9,.3,1);max-width:90vw}
.toast.mill{border-color:rgba(51,224,192,.5);box-shadow:0 12px 40px -10px rgba(51,224,192,.5)}
.toast.win{border-color:rgba(255,209,102,.6)}
@keyframes toastin{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
.toast.out{animation:toastout .3s ease forwards}
@keyframes toastout{to{opacity:0;transform:translateY(10px)}}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;background:rgba(6,9,18,.66);backdrop-filter:blur(6px);animation:fade .25s ease}
.modal-card{position:relative;max-width:540px;width:calc(100% - 40px);padding:30px 32px;max-height:86vh;overflow-y:auto}
.modal-card h2{margin:0 0 16px;font-size:22px}
.modal-close{position:absolute;top:16px;right:16px}
.help-body p{color:var(--muted);line-height:1.6;font-size:14.5px;margin:0 0 13px}
.help-body strong{color:var(--text)}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .home-grid{grid-template-columns:1fr}
  .game-layout{grid-template-columns:1fr}
  .side{flex-direction:column}
  .hero h1{font-size:38px}
}
@media (max-width:560px){
  main{padding:6px 14px 30px}
  .hero{padding:26px 22px}
}

.btn.pulse{animation:btnpulse 1.1s ease-in-out infinite}
@keyframes btnpulse{0%,100%{box-shadow:0 12px 30px -10px rgba(47,111,237,.7)}50%{box-shadow:0 0 0 4px rgba(84,160,255,.35),0 12px 30px -10px rgba(47,111,237,.9)}}

/* ---------- board svg ---------- */
.token{transition:transform .38s cubic-bezier(.2,.85,.25,1)}
.token.gone{animation:gone .24s ease forwards}
@keyframes gone{to{opacity:0}}
/* pop-in: scale the inner circles (group transform is reserved for position) */
.token.pop > circle{transform-box:fill-box;transform-origin:center;animation:popc .34s cubic-bezier(.2,1.5,.4,1)}
@keyframes popc{from{transform:scale(.2);opacity:.2}to{transform:scale(1);opacity:1}}

.v-dot{transition:r .2s,fill .2s}
.v-dot.avail{fill:#33e0c0;animation:availpulse 1.7s ease-in-out infinite}
@keyframes availpulse{0%,100%{opacity:.55}50%{opacity:1}}
.v-hit{cursor:inherit}

.halo{animation:halopulse 1.5s ease-in-out infinite;pointer-events:none}
@keyframes halopulse{0%,100%{opacity:.6}50%{opacity:1}}
.ring-move{stroke:rgba(51,224,192,.85)}
.ring-sel{stroke:#eafff9;animation:selpulse 1.2s ease-in-out infinite}
@keyframes selpulse{0%,100%{stroke-opacity:.7}50%{stroke-opacity:1}}
.ring-pick{stroke:#ffcf5a;animation:pickpulse 1.1s ease-in-out infinite}
@keyframes pickpulse{0%,100%{stroke-opacity:.55}50%{stroke-opacity:1}}
.mill-flash{animation:millflash 1.3s ease forwards;pointer-events:none}
@keyframes millflash{0%{opacity:0}18%{opacity:1}100%{opacity:0}}

/* scrollbars */
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:9px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}
