:root{
  --bg:#17120c; --bg2:#1e1710; --panel:#251c12; --panel2:#2f2417; --line:#3f3121;
  --gold:#d99a4e; --gold-bright:#f0bd6a; --palm:#7bab5c; --palm-bright:#9cc879;
  --maroon:#cf5b40; --cream:#efe6d4; --muted:#ac9c82; --muted-solid:#786c56;
  --mono:'IBM Plex Mono',ui-monospace,Menlo,Consolas,monospace;
  --disp:'Archivo','Arial Narrow',system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
  --ar-disp:'Reem Kufi','Cairo',serif; --ar-body:'Cairo','Reem Kufi',sans-serif;
  --star:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'><g fill='none' stroke='%23d99a4e' stroke-width='1' opacity='0.5'><rect x='16' y='16' width='32' height='32'/><rect x='16' y='16' width='32' height='32' transform='rotate(45 32 32)'/><circle cx='32' cy='32' r='6'/></g></svg>");
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:radial-gradient(1100px 620px at 82% -12%,#2a2116 0,transparent 60%),
  radial-gradient(900px 520px at -12% 112%,#201914 0,transparent 55%),var(--bg);
  color:var(--cream);font-family:var(--body);-webkit-font-smoothing:antialiased;min-height:100vh;position:relative}
body::before{content:"";position:fixed;inset:0;background-image:var(--star);background-size:64px 64px;opacity:.045;pointer-events:none;z-index:0}
.wrap{max-width:560px;margin:0 auto;padding:18px 16px 48px;position:relative;z-index:1}
.wrap.wide{max-width:1180px}

.brand{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:18px}
.brand .ar{font-family:var(--ar-disp);font-weight:700;font-size:clamp(22px,6vw,30px);color:var(--gold);line-height:1}
.brand .en{font-family:var(--disp);font-weight:900;font-size:clamp(15px,4vw,20px);letter-spacing:.02em;text-transform:uppercase;line-height:1}
.brand .sub{font-family:var(--mono);font-size:10px;color:var(--muted-solid);letter-spacing:.12em;text-transform:uppercase}

.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:16px}
.card h2{font-family:var(--disp);font-weight:800;font-size:15px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 4px;color:var(--cream)}
.card h2 .ar{font-family:var(--ar-body);text-transform:none;letter-spacing:0;color:var(--gold);font-size:16px;margin-inline-start:8px}
.card p.hint{color:var(--muted);font-size:13px;line-height:1.5;margin:0 0 14px}

label.q{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:14px 0 7px}
input,select{width:100%;background:#120d07;border:1px solid var(--line);color:var(--cream);border-radius:10px;
  padding:13px 14px;font-family:var(--body);font-size:16px}
input:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(217,154,78,.16)}
input.code{font-family:var(--mono);font-size:26px;font-weight:600;letter-spacing:.28em;text-align:center;text-transform:uppercase;color:var(--gold-bright)}

.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{border:1px solid var(--line);background:var(--panel2);color:var(--cream);padding:10px 14px;border-radius:10px;
  cursor:pointer;font-size:14px;transition:all .13s;user-select:none;line-height:1.3}
.opt .oar{font-family:var(--ar-body);font-size:12px;color:var(--muted);margin-inline-start:5px}
.opt[aria-pressed="true"]{background:linear-gradient(180deg,#3a2c17,#2c2214);border-color:var(--gold);color:var(--gold-bright)}
.opt[aria-pressed="true"] .oar{color:var(--gold)}

.btn{display:block;width:100%;font-family:var(--disp);font-weight:800;font-size:16px;letter-spacing:.05em;text-transform:uppercase;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#2a1c08;border:none;border-radius:12px;
  padding:16px;cursor:pointer;box-shadow:0 10px 24px rgba(217,154,78,.22);margin-top:16px;transition:transform .12s}
.btn:hover{transform:translateY(-1px)} .btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--muted);box-shadow:none}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

.big-num{font-family:var(--mono);font-size:44px;font-weight:600;text-align:center;color:var(--gold-bright);line-height:1}
.muted{color:var(--muted);font-size:13px;line-height:1.5}
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--ar-body);font-size:13px;background:rgba(123,171,92,.12);
  border:1px solid rgba(123,171,92,.3);color:var(--palm-bright);padding:3px 11px;border-radius:20px}
.err{color:var(--maroon);font-size:13px;min-height:18px;margin-top:8px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row>*{flex:1}

/* seat grid */
.teamblock{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:12px;background:var(--bg2)}
.teamblock h3{font-family:var(--disp);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px;color:var(--gold)}
.seat{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:10px;
  padding:11px 13px;margin-bottom:8px;background:var(--panel)}
.seat .who{font-family:var(--ar-disp);font-size:15px;color:var(--cream)}
.seat .who small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-solid)}
.seat .take{font-family:var(--disp);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em;
  border:1px solid var(--gold);color:var(--gold-bright);background:transparent;border-radius:8px;padding:7px 12px;cursor:pointer}
.seat.taken{opacity:.7}
.seat.taken .take{border-color:var(--line);color:var(--muted-solid);cursor:default}
.seat.mine{border-color:var(--gold);box-shadow:0 0 0 1px rgba(217,154,78,.3)}
.tag{font-family:var(--mono);font-size:10px;color:var(--palm-bright)}

/* play facts */
.facts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0}
.fact{background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:12px;text-align:center}
.fact .n{font-family:var(--mono);font-size:26px;font-weight:600}
.fact .n.inv{color:var(--gold-bright)} .fact .n.back{color:var(--maroon)} .fact .n.dem{color:var(--cream)} .fact .n.pos{color:var(--palm-bright)}
.fact .t{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-solid);margin-top:4px}

/* host dashboard */
.chain{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}
.node{flex:1;min-width:130px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px}
.node.human{border-color:var(--gold)}
.node .role{font-family:var(--ar-disp);font-size:15px;color:var(--cream)}
.node .role small{display:block;font-family:var(--mono);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-solid)}
.node .who{font-family:var(--mono);font-size:10px;color:var(--palm-bright);margin:4px 0 8px;min-height:12px}
.node .who.ai{color:var(--muted-solid)}
.node .mrow{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--muted);margin:2px 0}
.node .mrow b{color:var(--cream)} .node .mrow b.back{color:var(--maroon)} .node .mrow b.inv{color:var(--gold-bright)}
.node .sub{margin-top:7px;font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase}
.node .sub.yes{color:var(--palm-bright)} .node .sub.no{color:var(--maroon)}

.charts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 14px 8px}
.chart-card h4{font-family:var(--disp);font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 8px;color:var(--cream)}
.legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;font-family:var(--mono);font-size:10px;color:var(--muted)}
.legend .li{display:flex;align-items:center;gap:5px} .legend .sw{width:13px;height:3px;border-radius:2px}
canvas{width:100%;display:block}

table.scores{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:13px;margin-top:8px}
table.scores th,table.scores td{text-align:right;padding:9px 10px;border-bottom:1px solid var(--line)}
table.scores th{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-solid);font-weight:500}
table.scores td:first-child,table.scores th:first-child{text-align:left;color:var(--cream)}
table.scores tr.win td{color:var(--gold-bright);font-weight:600}

.qrbox{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.qrbox .qr{width:150px;height:150px;background:#fff;border-radius:12px;padding:8px}
.qrbox .qr svg{width:100%;height:100%}
.codebig{font-family:var(--mono);font-size:40px;font-weight:600;letter-spacing:.2em;color:var(--gold-bright)}
.hidden{display:none!important}
.support-wrap{text-align:center;margin-top:14px}
.support{display:inline-flex;align-items:center;gap:7px;font-family:var(--body);font-size:13px;color:var(--muted);
  text-decoration:none;border:1px solid var(--line);background:var(--panel);border-radius:20px;padding:8px 16px;
  transition:all .15s}
.support:hover{color:var(--gold-bright);border-color:var(--gold);background:var(--panel2)}
.support .hz{color:var(--maroon);font-size:14px}
.support .ar{font-family:var(--ar-body);color:var(--muted-solid);font-size:12px}
.support:hover .ar{color:var(--gold)}
.foot{margin-top:24px;font-family:var(--mono);font-size:10px;color:var(--muted-solid);text-align:center;line-height:1.6}
@media(max-width:620px){.charts{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){.btn{transition:none}}

/* ---- help modal (host + player) ---- */
.helpbtn{border:1px solid var(--line);background:var(--panel2);color:var(--gold);border-radius:50%;
  width:30px;height:30px;font-family:var(--disp);font-weight:800;font-size:15px;cursor:pointer;line-height:1;
  margin-inline-start:auto;flex:none}
.helpbtn:hover{border-color:var(--gold)}
.modal-overlay{position:fixed;inset:0;background:rgba(10,7,4,.75);z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--panel);border:1px solid var(--gold);border-radius:14px;max-width:640px;width:100%;
  max-height:85vh;overflow-y:auto;padding:20px;position:relative}
.modal h3{font-family:var(--disp);font-weight:800;font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gold-bright);margin:16px 0 6px}
.modal h3:first-child{margin-top:0}
.modal p,.modal li{color:var(--muted);font-size:13px;line-height:1.6}
.modal ul,.modal ol{padding-inline-start:20px;margin:6px 0}
.modal .ar{font-family:var(--ar-body);color:var(--gold)}
.modal .x{position:absolute;top:10px;inset-inline-end:12px;border:none;background:none;color:var(--muted);
  font-size:22px;cursor:pointer;line-height:1}
.modal .x:hover{color:var(--cream)}
.modal b{color:var(--cream)}

/* ---- player hint box ---- */
.hintbox{background:var(--bg2);border:1px dashed var(--gold);border-radius:10px;padding:10px 12px;
  font-size:13px;color:var(--muted);line-height:1.55;margin-top:10px}
.hintbox b{color:var(--gold-bright)}

/* ---- transparent-mode chain strip on the player view ---- */
.peek{margin-top:14px}
.peek h4{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-solid);margin:0 0 8px}
.peek .chain .node.you{border-color:var(--gold);box-shadow:0 0 0 1px rgba(217,154,78,.3)}

/* ---- host: release-to-robot button on a seat card ---- */
.robotize{margin-top:7px;width:100%;font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid var(--line);background:none;color:var(--muted-solid);border-radius:7px;padding:4px 6px;cursor:pointer}
.robotize:hover{border-color:var(--maroon);color:var(--maroon)}
.vispill{display:inline-block;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:999px;padding:3px 9px;color:var(--gold);margin-inline-start:8px}
