:root{
  --ink:#0E1430; --panel:#19224A; --panel-2:#212c5c; --line:#2c3768;
  --text:#EDF0FB; --muted:#8E97C2;
  --teamA:#3DE1C6; --teamB:#FF5D73; --teamC:#C792FF; --accent:#7C8CFF;
  --redtrack:#D9544C; --p1:#F2994A; --p2:#F2C94C; --p3:#2FBF6E;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:radial-gradient(900px 600px at 50% -10%, #1a2350 0%, transparent 60%), var(--ink);color:var(--text);font-family:"Inter",system-ui,sans-serif;-webkit-font-smoothing:antialiased;min-height:100%;padding:18px}
.wrap{max-width:860px;margin:0 auto}
h1{font-family:"Space Grotesk";font-weight:700;font-size:24px;letter-spacing:-.5px;margin:0}
.sub{font-family:"Space Mono";font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}

.btn{font-weight:600;font-size:14px;cursor:pointer;border-radius:12px;padding:12px 16px;border:1px solid var(--line);background:var(--panel);color:var(--text);transition:transform .06s,background .15s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn:hover{background:var(--panel-2)} .btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent);color:#0c1024;border-color:transparent} .btn.primary:hover{background:#93a0ff}
.btn.wide{flex:1;min-width:130px} .btn:disabled{opacity:.4;cursor:not-allowed}
.btn.big{font-size:16px;padding:16px}

/* landing / join / team-pick */
.landing{max-width:520px;margin:8vh auto 0;text-align:center}
.landing .card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px}
.landing p{color:var(--muted);font-size:14px;line-height:1.5}
.rolegrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.rolegrid .btn{padding:18px}
.rolegrid .admin{grid-column:1/3;background:var(--accent);color:#0c1024;border-color:transparent;font-size:16px}
.ta{border-color:var(--teamA);color:var(--teamA)} .tb{border-color:var(--teamB);color:var(--teamB)} .tc{border-color:var(--teamC);color:var(--teamC)}
.codeinput{width:100%;margin-top:14px;background:var(--panel-2);border:1px solid var(--line);color:var(--text);font-family:"Space Mono";font-weight:700;font-size:22px;letter-spacing:6px;text-align:center;text-transform:uppercase;padding:12px;border-radius:12px}
.codeinput:focus{outline:2px solid var(--accent)}
.muted-link{display:inline-block;margin-top:16px;color:var(--muted);font-size:13px}

.bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.bar .right{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pill{font-family:"Space Mono";font-size:12px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:5px 11px}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--muted);margin-right:5px;vertical-align:middle}
.dot.live{background:var(--p3)}

/* host share strip */
.share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-bottom:12px}
.share .k{font-size:12px;color:var(--muted);font-weight:600}
.roomcode{font-family:"Space Mono";font-weight:700;font-size:22px;letter-spacing:4px;color:var(--accent)}
.joinlink{font-family:"Space Mono";font-size:12px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:6px 10px;flex:1;min-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.share .copy{margin-left:auto}

.toggle{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:3px}
.toggle button{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12px;padding:6px 11px;border-radius:8px;cursor:pointer}
.toggle button[aria-pressed="true"]{background:var(--accent);color:#0c1024}

.scores{display:flex;gap:8px;flex-wrap:wrap;width:100%;margin-bottom:12px}
.scorechip{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px 11px;flex:1;min-width:90px}
.scorechip .nm{font-size:12px;color:var(--muted)} .scorechip .val{font-family:"Space Mono";font-weight:700;font-size:18px;margin-left:auto}

.stage{background:linear-gradient(180deg,var(--panel) 0%, #141c40 100%);border:1px solid var(--line);border-radius:22px;padding:10px 10px 4px;box-shadow:0 24px 60px -30px rgba(0,0,0,.8)}
.dialhost svg{display:block}

.poles{display:flex;justify-content:space-between;gap:10px;margin:2px 12px 12px;align-items:center}
.pole{flex:1}
.pole input,.pole .lbl{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--text);font-family:"Space Grotesk";font-weight:500;font-size:17px;padding:10px 12px;border-radius:12px;min-height:44px;display:flex;align-items:center}
.pole.left input,.pole.left .lbl{border-left:4px solid var(--p1)}
.pole.right input,.pole.right .lbl{text-align:right;border-right:4px solid var(--redtrack);justify-content:flex-end}
.pole input:focus{outline:2px solid var(--accent)}
.shuffle{background:var(--panel);border:1px solid var(--line);color:var(--muted);border-radius:10px;width:42px;height:42px;font-size:17px;cursor:pointer;flex:none}
.shuffle:hover{background:var(--panel-2);color:var(--text)}

.cluebar{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px 12px;margin-top:12px}
.cluebar label{font-size:12px;color:var(--muted);font-weight:600;white-space:nowrap}
.cluebar input{flex:1;background:var(--panel-2);border:1px solid var(--line);color:var(--text);font-family:"Space Grotesk";font-weight:500;font-size:16px;padding:9px 12px;border-radius:9px}
.cluebar input:focus{outline:2px solid var(--accent)}

.cluebig{text-align:center;margin:14px 0 2px}
.cluebig .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.cluebig .v{font-family:"Space Grotesk";font-weight:700;font-size:30px;margin-top:4px;min-height:38px}

.controls{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.targetbox{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px 12px}
.targetbox label{font-size:12px;color:var(--muted);font-weight:600}
.roll{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:9px;padding:6px 9px;cursor:pointer;font-size:15px;display:inline-flex;align-items:center}
.roll:hover{color:var(--text);background:var(--panel-2)}
.tgtbox{display:inline-flex;align-items:center;justify-content:center;min-width:58px;height:38px;border-radius:9px;font-family:"Space Mono";font-weight:700;font-size:20px}
.tgtbox.hidden{background:repeating-linear-gradient(45deg,#2a3360,#2a3360 6px,#222a52 6px,#222a52 12px);border:1px solid var(--line);color:transparent}
.tgtbox.shown{background:#1c3326;border:1px solid var(--p3);color:var(--p3)}

.feed{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.teamcard{flex:1;min-width:120px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.teamcard .nm{font-size:12px;font-weight:700} .teamcard .st{font-family:"Space Mono";font-size:15px;color:var(--muted);margin-top:3px}
.teamcard.in{border-color:var(--p3)}

.result{margin-top:12px;border-radius:14px;padding:14px 16px;display:none;gap:12px;background:var(--panel);border:1px solid var(--line);flex-wrap:wrap}
.result.show{display:flex}
.result .head{font-family:"Space Grotesk";font-weight:700;font-size:16px;width:100%}
.scoreline{display:flex;align-items:center;gap:10px;font-size:15px;width:100%}
.scoreline .pts{font-family:"Space Mono";font-weight:700;margin-left:auto}
.winner{color:var(--p2);font-weight:700;width:100%;font-size:14px;margin-top:2px}

.status{text-align:center;color:var(--muted);font-size:15px;padding:18px;line-height:1.5}
.lockbtn{margin-top:14px}
.hidden-el{display:none!important}
.warn{background:#3a2330;border:1px solid var(--redtrack);color:#ffd9d4;border-radius:12px;padding:12px 14px;font-size:13px;margin-bottom:12px;line-height:1.5}
