:root{
  --felt:#13302a; --felt2:#0b201b; --card:#1a4136; --card2:#225043;
  --line:rgba(236,229,211,.14); --ink:#ece5d3; --ink-dim:rgba(236,229,211,.62);
  --gold:#d8b25c; --gold2:#b8923c; --red:#d23b2e; --navy:#1d2a4a; --blue:#5a8fb8; --green:#5fae7f;
  --cube:#ece5d3; --cube-ink:#1d2a4a;
  --brandfont:'Gelasio',Georgia,serif;
}
*{box-sizing:border-box; -webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:linear-gradient(180deg, #16382f 0%, var(--felt) 30%, var(--felt2) 100%) fixed;
  color:var(--ink); min-height:100vh;
  padding-bottom:env(safe-area-inset-bottom);
}
.wrap{max-width:1280px;margin:0 auto;padding:14px 14px 40px;}
h1{font-size:24px;margin:6px 0 2px;letter-spacing:.5px;font-family:var(--brandfont);font-weight:400;}
h2{font-size:15px;margin:0 0 10px;letter-spacing:2.2px;text-transform:uppercase;color:var(--gold);font-weight:400;font-family:var(--brandfont);}
.sub{color:var(--ink-dim);font-size:14px;margin:0 0 18px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:16px;}
button{
  font:inherit;border:none;border-radius:6px;padding:13px 16px;cursor:pointer;
  background:var(--card2);color:var(--ink);font-size:15px;font-weight:600;letter-spacing:.2px;
  border:1px solid var(--line); touch-action:manipulation;
}
button:active{transform:scale(.97);}
button.primary{background:var(--gold);color:#23200f;border:1px solid var(--gold2);}
button.danger{background:var(--red);border:none;}
button.ghost{background:transparent;}
button.small{padding:8px 12px;font-size:13.5px;border-radius:6px;}
button.tiny{padding:6px 10px;font-size:12.5px;border-radius:5px;}
button:disabled{opacity:.35;pointer-events:none;}
input[type=text],input[type=number],input[type=email],textarea,select{
  font:inherit;width:100%;padding:12px 13px;border-radius:6px;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--ink);font-size:16px;
}
.row{display:flex;gap:10px;align-items:center;}
.row>.grow{flex:1;}
.stack>*+*{margin-top:10px;}
.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);}
.toggle-row:last-child{border-bottom:none;}
.toggle-row .lbl{font-size:15px;font-weight:600;}
.toggle-row .hint{font-size:12.5px;color:var(--ink-dim);margin-top:2px;max-width:75%;}
.switch{position:relative;width:52px;height:31px;flex:none;}
.switch input{display:none;}
.switch span{position:absolute;inset:0;background:rgba(0,0,0,.4);border-radius:31px;transition:.2s;border:1px solid var(--line);}
.switch span:before{content:"";position:absolute;width:25px;height:25px;border-radius:50%;background:#fff;top:2.5px;left:3px;transition:.2s;}
.switch input:checked+span{background:var(--green);}
.switch input:checked+span:before{left:23px;}
/* compact header */
.hdr{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;}
.hdr .hcard{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:7px 13px;}
.hdr .hcard .k{font-size:9.5px;letter-spacing:1.2px;color:var(--ink-dim);font-weight:800;}
.hdr .hcard .v{font-size:16px;font-weight:800;}
.hdr .hcard.gold{border-color:var(--gold2);} .hdr .hcard.gold .v{color:var(--gold);}
.hdr .spacer{flex:1;}
.codechip{font-weight:800;letter-spacing:2px;background:rgba(0,0,0,.3);padding:9px 13px;border-radius:6px;border:1px solid var(--line);font-size:13.5px;cursor:pointer;}
/* grid */
.grid{display:grid;grid-template-columns:1fr;gap:13px;align-items:start;}
@media(min-width:980px){.grid{grid-template-columns:1fr 360px;}.span2{grid-column:1/-1;}}
/* player rows */
.prow{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:7px;background:rgba(0,0,0,.18);border:1px solid var(--line);margin-bottom:8px;cursor:pointer;}
.prow.boxrow{background:linear-gradient(180deg,#3e3320,#33290f);border-color:var(--gold2);}
.prow.outrow{opacity:.6;}
.pname{font-size:16px;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.badge{font-size:9.5px;font-weight:800;letter-spacing:.7px;padding:2.5px 7px;border-radius:6px;flex:none;vertical-align:middle;}
.badge.box{background:var(--gold);color:#23200f;}
.badge.cap{background:var(--ink);color:var(--navy);}
.badge.sk{background:transparent;border:1px solid var(--ink-dim);color:var(--ink-dim);}
.badge.out{background:var(--red);color:#fff;}
.badge.deck{background:transparent;border:1px solid var(--gold);color:var(--gold);}
.cubechip{
  width:40px;height:40px;border-radius:9px;background:var(--cube);color:var(--cube-ink);
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:17px;flex:none;
  box-shadow:0 2px 5px rgba(0,0,0,.4); position:relative;
}
.cubechip.centered{opacity:.85;}
.cubechip.offered{outline:3px solid var(--gold);animation:pulse 1.1s infinite;}
.cubechip.mini{width:28px;height:28px;font-size:13px;border-radius:7px;}
.cubechip .own{position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);font-size:8.5px;font-weight:800;background:#23200f;color:var(--gold);padding:1px 5px;border-radius:6px;letter-spacing:.4px;white-space:nowrap;}
@keyframes pulse{50%{outline-color:transparent;}}
.avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;flex:none;border:1.5px solid var(--line);background:#0a2c22;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12.5px;color:var(--gold);overflow:hidden;}
img.avatar{display:block;}
.bigscore{font-variant-numeric:tabular-nums;font-weight:900;font-size:23px;text-align:right;flex:none;line-height:1;}
.bigscore small{display:block;font-size:11px;font-weight:600;color:var(--ink-dim);margin-top:2px;}
.pos{color:#8fd6a8;} .neg{color:#e89890;}
.cubestate{font-size:11.5px;color:var(--ink-dim);margin-top:2px;}
.sheet2{width:100%;border-collapse:collapse;font-size:13.5px;}
.sheet2 th,.sheet2 td{padding:7px 5px;border-bottom:1px solid var(--line);text-align:center;}
.sheet2 th.pcol{cursor:pointer;vertical-align:top;min-width:72px;padding-top:10px;}
.sheet2 .gcol{text-align:left;color:var(--ink-dim);font-size:12px;white-space:nowrap;width:42px;}
.sheet2 .num{font-variant-numeric:tabular-nums;}
.sheet2 .outcol{opacity:.5;}
.sheet2 .pname2{font-weight:700;font-size:13.5px;margin:5px auto 3px;overflow:hidden;text-overflow:ellipsis;max-width:110px;white-space:nowrap;text-align:center;}
.sheet2 .avatar{margin:0 auto;width:32px;height:32px;font-size:11px;}
.sheet2 .chiprow{display:flex;gap:4px;justify-content:center;margin-top:6px;}
.sheet2 .chipcap{font-size:9px;letter-spacing:1.5px;color:var(--ink-dim);margin-top:9px;text-transform:uppercase;}
.sheet2 .mecol .avatar{border:2px solid var(--gold);box-shadow:0 0 0 2px rgba(216,178,92,.35);}
/* compact mode for big chouettes (9+ players) */
.sheet2.dense th.pcol{min-width:46px;padding:8px 2px 4px;}
.sheet2.dense th,.sheet2.dense td{padding:6px 3px;font-size:12px;}
.sheet2.dense .avatar{width:26px;height:26px;font-size:9.5px;}
.sheet2.dense .pname2{font-size:11.5px;writing-mode:vertical-rl;transform:rotate(180deg);height:66px;max-width:none;margin:5px auto 3px;text-align:left;overflow:hidden;text-overflow:ellipsis;}
.sheet2.dense .badge{font-size:8px;padding:2px 4px;letter-spacing:.4px;}
.sheet2.dense .chipcap{display:none;}
.sheet2.dense .cubechip.mini{width:22px;height:22px;font-size:11px;border-radius:5px;}
.sheet2.dense .rolemark{font-size:7.5px;padding:0 2px;margin-right:2px;}
.sheet2.dense .loser{padding:0 3px;border-width:1px;}
.sheet2.dense .totrow td{font-size:13px;}
.sheet2 .totrow td{border-top:2px solid var(--gold2);}
@media (orientation:landscape) and (max-height:520px){
  .hdr,.banner,.grid>.card:not(.span2),.wrap>p.note{display:none;}
  .wrap{padding:10px 14px 14px;max-width:none;}
  .grid{display:block;}
  .grid>.span2{background:transparent;border:none;padding:2px;}
  .addrow,.tipnote{display:none;}
  .sheet2{font-size:16px;}
  .sheet2 th,.sheet2 td{padding:9px 8px;}
  .sheet2 .pname2{font-size:15px;max-width:140px;}
  .sheet2 .avatar{width:36px;height:36px;}
}
/* pending decisions */
.pend{background:rgba(0,0,0,.22);border:1px solid var(--gold2);border-radius:7px;padding:11px 12px;margin-bottom:9px;}
.pend .who{font-weight:700;font-size:14.5px;margin-bottom:8px;}
.pend .btns{display:flex;gap:7px;flex-wrap:wrap;}
.pend .btns button{flex:1;min-width:72px;}
/* actions */
.qa{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.qa .full{grid-column:1/-1;}
.seg{display:flex;border:1px solid var(--line);border-radius:6px;overflow:hidden;}
.seg button{flex:1;border:none;border-radius:0;background:transparent;padding:12px 4px;font-size:14px;}
.seg button.on{background:var(--gold);color:#23200f;}
/* history */
.hist{max-height:560px;overflow-y:auto;}
.hitem{padding:9px 2px;border-bottom:1px solid var(--line);font-size:13.5px;}
.hitem .ht{color:var(--ink-dim);font-size:11px;}
.gamehdr{margin:10px 0 3px;font-size:11px;font-weight:800;letter-spacing:1.2px;color:var(--gold);}
.zbadge{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:8px;background:rgba(95,174,127,.2);color:#8fd6a8;border:1px solid rgba(95,174,127,.4);}
.zbadge.bad{background:rgba(192,86,79,.2);color:#e89890;border-color:rgba(192,86,79,.5);}
/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:50;display:flex;align-items:flex-end;justify-content:center;}
@media(min-width:600px){.modal-bg{align-items:center;}}
.modal{background:#10382d;border:1px solid var(--line);border-radius:20px 20px 0 0;width:100%;max-width:560px;padding:20px 18px calc(20px + env(safe-area-inset-bottom));max-height:85vh;overflow-y:auto;}
@media(min-width:600px){.modal{border-radius:20px;}}
.modal .grabber{width:40px;height:4px;border-radius:3px;background:rgba(236,229,211,.3);margin:-8px auto 12px;}
@media(min-width:600px){.modal .grabber{display:none;}}
.modal h3{margin:0 0 4px;font-size:19px;font-family:var(--brandfont);font-weight:400;letter-spacing:.5px;}
.modal .msub{color:var(--ink-dim);font-size:13.5px;margin:0 0 14px;}
.sheet-btn{display:flex;width:100%;justify-content:space-between;align-items:center;text-align:left;margin-bottom:8px;padding:14px 16px;gap:10px;}
.sheet-btn small{color:var(--ink-dim);font-weight:400;text-align:right;}
.codebox{font-size:44px;font-weight:900;letter-spacing:10px;text-align:center;padding:18px 0;background:rgba(0,0,0,.3);border-radius:14px;border:1px solid var(--gold2);margin:12px 0;color:var(--gold);}
.banner{background:#3c3110;border:1px solid var(--gold2);color:var(--gold);padding:10px 14px;border-radius:12px;font-size:13.5px;margin-bottom:12px;}
.note{font-size:12.5px;color:var(--ink-dim);}
details.mhist summary{cursor:pointer;font-weight:700;padding:6px 0;}
.home-word{font-family:var(--brandfont);font-size:clamp(42px,8vw,72px);letter-spacing:clamp(4px,.9vw,9px);line-height:1.16;margin-bottom:6px;}
.home-mark{width:clamp(100px,18vw,170px);margin:clamp(18px,3vw,30px) auto clamp(14px,2.4vw,22px);}
.home-mark svg{width:100%;height:auto;display:block;}
.home-sub{font-family:var(--brandfont);font-size:clamp(15px,2.4vw,23px);letter-spacing:clamp(8px,1.6vw,15px);color:var(--gold);margin-bottom:clamp(28px,5vw,46px);text-indent:clamp(8px,1.6vw,15px);}
.stbl td,.stbl th{padding:8px 6px;border-bottom:1px solid var(--line);text-align:left;}
.stbl td.num,.stbl th.num{text-align:right;font-variant-numeric:tabular-nums;}
.rolemark{display:inline-block;font-size:9.5px;font-weight:800;color:var(--gold);border:1px solid var(--gold2);border-radius:4px;padding:0 3px;margin-right:4px;vertical-align:1px;}
.loser{display:inline-block;border:1.5px solid var(--red);border-radius:999px;padding:0 6px;}
