/* Lights Out & Toe Away — Styles */


:root{--red:#E10600;--rg:rgba(225,6,0,.4);--gold:#FFD700;--blue:#00BFFF;--bg:rgba(0,191,255,.4);--green:#00e676;--purple:#b388ff;--orange:#ff9100;--dark:#0a0a0f;--s1:#16161f;--s2:#1e1e2a;--bd:#2a2a3a;--t1:#f0f0f8;--t2:#888899;}
*{margin:0;padding:0;box-sizing:border-box;}
body{
  background:#0a0a0f;
  color:var(--t1);font-family:"Teko",sans-serif;font-weight:500;min-height:100vh;
  overflow-x:hidden;
}
#app{
  position:relative;
  overflow-x:hidden;
  background:transparent;
}
header{display:flex;align-items:center;justify-content:center;padding:12px 20px;border-bottom:1px solid var(--bd);background:linear-gradient(180deg,rgba(225,6,0,.07) 0,transparent);gap:12px;}
.logo{font-family:Orbitron,"Teko",monospace;font-size:clamp(24px,5vw,34px);font-weight:900;letter-spacing:2px;text-align:center;}
.logo span:first-child{color:var(--red);text-shadow:0 0 20px var(--rg);}
.tag{font-size:25px;font-family:"Teko",sans-serif;font-weight:600;letter-spacing:2px;color:var(--t2);border:1px solid var(--bd);padding:2px 7px;border-radius:2px;text-transform:uppercase;}
.scr{display:none;} .scr.on{display:block;}

/* HOME */
#home{flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 60px);padding:24px 16px;gap:18px;text-align:center;position:relative;}
#home.on{display:flex;}
#home > *{position:relative;z-index:1;}
.ht{font-family:"Teko",sans-serif;font-size:clamp(15px,2.5vw,19px);letter-spacing:2px;color:#c9a84c;text-transform:uppercase;}
.hd{font-size:21px;color:var(--t2);max-width:440px;line-height:1.6;}
.hd strong{color:var(--t1);}
.pills{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;max-width:540px;}
.pill{display:inline-flex;align-items:center;gap:4px;background:var(--s1);border:1px solid var(--bd);padding:3px 9px;font-size:21px;font-weight:600;color:#6a5520;}

/* BTNS */
.bgrp{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.btn{font-family:"Teko",sans-serif;font-size:25px;font-weight:700;letter-spacing:2px;padding:11px 24px;border:none;cursor:pointer;text-transform:uppercase;transition:all .2s;clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);}
.btn-p{background:var(--red);color:#fff;box-shadow:0 4px 18px var(--rg);}
.btn-p:hover{background:#ff1500;transform:translateY(-1px);}
.btn-s{background:transparent;color:var(--t1);border:1px solid var(--bd);}
.btn-s:hover{border-color:var(--red);color:var(--red);}
.btn-sm{font-size:19px;padding:8px 14px;}
.back{background:none;border:none;cursor:pointer;font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;color:var(--t2);text-transform:uppercase;display:flex;align-items:center;gap:5px;}
.back:hover{color:var(--t1);}

/* GAME */
#game{max-width:900px;margin:0 auto;padding:12px 10px 40px;}
.gh{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.sb{display:flex;align-items:center;gap:12px;background:var(--s1);border:1px solid var(--bd);padding:7px 16px;clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);}
.ps{display:flex;align-items:center;gap:7px;font-size:19px;font-weight:600;letter-spacing:1px;}
.mk{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:"Teko",sans-serif;font-size:17px;font-weight:900;}
.mk-x{background:var(--red);box-shadow:0 0 10px var(--rg);}
.mk-o{background:var(--blue);box-shadow:0 0 10px var(--bg);}
.sn{font-family:"Teko",sans-serif;font-size:23px;font-weight:900;}
.ti{font-family:"Teko",sans-serif;font-size:25px;letter-spacing:2px;padding:4px 10px;border-radius:2px;transition:all .3s;}
.ti-x{background:rgba(225,6,0,.15);color:var(--red);border:1px solid var(--red);}
.ti-o{background:rgba(0,191,255,.15);color:var(--blue);border:1px solid var(--blue);}

/* GRID */
.gw{display:grid;grid-template-columns:1fr repeat(3,1fr);grid-template-rows:auto repeat(3,1fr);gap:3px;max-width:780px;margin:0 auto;}
.corner{display:flex;align-items:center;justify-content:center;min-height:88px;width:100%;}
.corner svg{opacity:.1;}
.cl{background:var(--s1);border:1px solid var(--bd);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5px 4px;min-height:88px;gap:3px;}
.cl.row-cl{}
.cl-pt{width:40px;height:40px;border-radius:50%;object-fit:cover;object-position:top center;border:2px solid var(--bd);flex-shrink:0;}
.cl-flag{width:62px;height:38px;object-fit:cover;border-radius:4px;border:2px solid rgba(255,255,255,0.15);flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,0.5);}
.cl-car{width:72px;height:36px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.6));}
.cl-ic{font-size:clamp(20px,3vw,26px);line-height:1;}
.cl-tx{font-size:clamp(13px,1.8vw,16px);font-weight:700;letter-spacing:.3px;color:var(--t2);text-transform:uppercase;line-height:1.25;text-align:center;}
.badge{display:inline-block;font-size:17px;padding:1px 5px;border-radius:2px;letter-spacing:.8px;font-family:"Teko",sans-serif;font-weight:700;margin-top:2px;white-space:nowrap;}
.b-team{background:rgba(225,6,0,.15);border:1px solid rgba(225,6,0,.35);color:var(--red);}
.b-nat{background:rgba(0,191,255,.12);border:1px solid rgba(0,191,255,.3);color:var(--blue);}
.b-troph{background:rgba(255,215,0,.12);border:1px solid rgba(255,215,0,.35);color:var(--gold);}
.b-circ{background:rgba(0,230,118,.1);border:1px solid rgba(0,230,118,.3);color:var(--green);}
.b-tp{background:rgba(179,136,255,.12);border:1px solid rgba(179,136,255,.3);color:var(--purple);}
.b-wild{background:rgba(255,145,0,.12);border:1px solid rgba(255,145,0,.3);color:var(--orange);}
.b-tm{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);color:var(--t2);}

/* CELLS */
.cell{background:var(--s1);border:1px solid var(--bd);cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:100px;position:relative;transition:all .2s;overflow:hidden;}
.gw.turn-x .cell:hover:not(.taken){border-color:var(--red);background:var(--s2);box-shadow:inset 0 0 20px rgba(225,6,0,.07);}
.gw.turn-o .cell:hover:not(.taken){border-color:var(--blue);background:var(--s2);box-shadow:inset 0 0 20px rgba(0,191,255,.07);}
.cell.taken{cursor:default;}
.ci{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;width:100%;height:100%;padding:7px;}
.ce{width:28px;height:28px;border:2px dashed var(--bd);border-radius:50%;transition:border-color .2s;}
.gw.turn-x .cell:hover:not(.taken) .ce{border-color:var(--red);}
.gw.turn-o .cell:hover:not(.taken) .ce{border-color:var(--blue);}
.cm{font-family:"Teko",sans-serif;font-size:34px;font-weight:900;animation:pop .3s cubic-bezier(.175,.885,.32,1.275);}
.cm-x{color:var(--red);text-shadow:0 0 14px var(--rg);}
.cm-o{color:var(--blue);text-shadow:0 0 14px var(--bg);}
.cd{font-size:clamp(12px,1.6vw,15px);font-weight:700;letter-spacing:.3px;text-align:center;color:var(--t2);text-transform:uppercase;line-height:1.2;max-width:85px;}
.cell.wx{background:rgba(225,6,0,.13);border-color:var(--red);}
.cell.wo{background:rgba(0,191,255,.13);border-color:var(--blue);}
@keyframes pop{0%{transform:scale(0) rotate(-15deg);opacity:0}100%{transform:scale(1) rotate(0);opacity:1}}

/* USED BAR - hidden, kept for JS compatibility */
.ub{display:none !important;}
.ut{display:none !important;}

/* MODAL */
.ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:100;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.ov.on{display:flex;}
.modal{background:#111118;border:1px solid var(--bd);width:92%;max-width:480px;clip-path:polygon(12px 0,100% 0,calc(100% - 12px) 100%,0 100%);animation:mi .18s ease-out;overflow:visible;}
@keyframes mi{from{transform:translateY(-16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.mh{background:linear-gradient(90deg,rgba(154,4,0,.6),transparent);padding:10px 18px;font-family:"Teko",sans-serif;font-size:18px;letter-spacing:2px;font-weight:700;color:var(--red);border-bottom:1px solid var(--bd);}
.mb{padding:14px 16px;}
.mc{font-size:15px;color:var(--t2);margin-bottom:11px;display:flex;gap:5px;align-items:center;flex-wrap:wrap;}
.ct{background:var(--s2);border:1px solid var(--bd);padding:3px 8px;font-size:15px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--t1);}
.ct-x{background:rgba(225,6,0,.1);border-color:var(--red);color:var(--red);}
.ct-o{background:rgba(0,191,255,.1);border-color:var(--blue);color:var(--blue);}
.sw{position:relative;}
.di{width:100%;background:var(--s1);border:1px solid var(--bd);color:var(--t1);font-family:"Teko",sans-serif;font-size:16px;font-weight:500;padding:10px 13px;outline:none;transition:border-color .2s;letter-spacing:.4px;}
.di:focus{border-color:var(--player-color,var(--gold));}
.di::placeholder{color:var(--t2);font-weight:400;}
.sugg{display:none;width:100%;max-height:160px;overflow-y:auto;background:#1c1c26;border:1px solid rgba(255,255,255,.12);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px rgba(0,0,0,.4);}
.sugg:not(:empty){display:block;}
.si{padding:9px 16px;cursor:pointer;font-size:17px;font-weight:400;color:#aaa;display:block;border-bottom:1px solid rgba(255,255,255,.06);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .1s,color .1s;}
.si strong{font-weight:700;color:#fff;}
.si:hover{background:rgba(255,255,255,.07);color:#fff;}
.si:last-child{border-bottom:none;}
.driver-updated{font-size:13px;color:var(--t2);margin-top:6px;letter-spacing:.3px;opacity:.7;}
.sm{display:flex;gap:3px;}
.stag{font-size:19px;padding:1px 5px;background:var(--s1);border:1px solid var(--bd);color:var(--t2);}
.ma{display:flex;gap:9px;margin-top:11px;justify-content:flex-end;}
.err{color:var(--red);font-size:21px;font-weight:600;margin-top:7px;min-height:15px;}

/* RESULT */
#res{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(6px);flex-direction:column;gap:16px;}
#res.on{display:flex;}
.rt{font-size:80px;animation:tb .5s cubic-bezier(.175,.885,.32,1.275);}
@keyframes tb{0%{transform:scale(0) rotate(-10deg)}100%{transform:scale(1) rotate(0)}}
.rtt{font-family:"Teko",sans-serif;font-size:clamp(30px,7vw,54px);font-weight:900;text-align:center;letter-spacing:2px;}
.rtt.xw{color:var(--red);text-shadow:0 0 28px var(--rg);}
.rtt.ow{color:var(--blue);text-shadow:0 0 28px var(--bg);}
.rtt.dr{color:var(--gold);}
.rs{font-size:19px;color:var(--t2);letter-spacing:2px;text-transform:uppercase;}

/* HOWTO */
#howto{max-width:640px;margin:0 auto;padding:28px 18px;}
.hwt{font-family:"Teko",sans-serif;font-size:25px;font-weight:900;margin-bottom:16px;color:var(--red);letter-spacing:2px;}
.hs{display:flex;gap:13px;margin-bottom:14px;}
.sn2{font-family:"Teko",sans-serif;font-size:25px;font-weight:900;color:var(--red);min-width:28px;line-height:1;}
.st{font-size:19px;color:var(--t2);line-height:1.6;}
.st strong{color:var(--t1);}
.csec{margin-top:18px;}
.csect{font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;color:var(--t2);margin-bottom:7px;text-transform:uppercase;}
.cchips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px;}
.cc{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;font-size:21px;font-weight:600;}

/* 580px block removed - consolidated below */
::-webkit-scrollbar{width:4px;} ::-webkit-scrollbar-thumb{background:var(--bd);}

/* TIMER */
.timer-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;}
.timer-ring{position:relative;width:52px;height:52px;}
.timer-ring svg{transform:rotate(-90deg);}
.timer-ring .ring-bg{fill:none;stroke:var(--bd);stroke-width:4;}
.timer-ring .ring-fg{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .3s;}
.timer-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:"Teko",sans-serif;font-size:19px;font-weight:900;}
.timer-lbl{font-size:23px;letter-spacing:2px;color:var(--t2);text-transform:uppercase;font-family:"Teko",sans-serif;}

/* SCORE TABLE */
.score-table{display:flex;align-items:stretch;gap:0;background:var(--s1);border:1px solid var(--bd);overflow:hidden;clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);}
.st-player{display:flex;flex-direction:column;align-items:center;padding:8px 16px;gap:4px;min-width:80px;}
.st-player.x-side{border-right:1px solid var(--bd);}
.st-player.o-side{border-left:1px solid var(--bd);}
.st-name{font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;font-weight:700;text-transform:uppercase;}
.st-name.x-col{color:var(--red);}
.st-name.o-col{color:var(--blue);}
.st-pips{display:flex;gap:4px;align-items:center;}
.pip{width:14px;height:14px;border-radius:50%;border:2px solid var(--bd);transition:all .3s;}
.pip.x-pip.won{background:var(--red);border-color:var(--red);box-shadow:0 0 6px var(--rg);}
.pip.o-pip.won{background:var(--blue);border-color:var(--blue);box-shadow:0 0 6px var(--bg);}
.st-middle{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 14px;gap:2px;}
.st-vs{font-family:"Teko",sans-serif;font-size:21px;font-weight:900;color:var(--t2);}
.st-round{font-size:19px;color:var(--t2);letter-spacing:1px;text-transform:uppercase;}

/* GAME HEADER reworked */
.gh{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:10px;}
.gh-left{display:flex;align-items:center;gap:10px;}
.gh-right{display:flex;align-items:center;gap:8px;}

/* ACTION BUTTONS under grid */
.action-bar{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap;}

/* TURN FLASH */
@keyframes turnFlash{0%{opacity:.4}50%{opacity:1}100%{opacity:.4}}
.ti.flash{animation:turnFlash .5s ease;}

/* MISTAKE FLASH */
.cell.mistake{animation:mistakeFlash .5s ease;}
@keyframes mistakeFlash{0%{background:rgba(225,6,0,.35)}100%{background:var(--s1)}}

/* SERIES WIN banner extra */
.series-won{font-size:23px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-top:-8px;}


/* ── GAME MODE SELECTION ─────────────────────────────────────────────── */
.mode-grid{display:flex;gap:14px;flex-wrap:nowrap;justify-content:center;max-width:800px;}
.mode-card{
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  gap:8px;padding:18px 14px 18px;width:140px;min-height:130px;
  background:var(--s1);border:1px solid var(--bd);
  font-family:"Teko",sans-serif;cursor:pointer;
  transition:border-color .2s,transform .15s,background .2s;
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
.mode-card:hover{transform:translateY(-3px);background:var(--s2);}
.mode-same:hover{border-color:var(--blue);}
.mode-friend:hover{border-color:var(--gold);}
.mode-online:hover{border-color:var(--green);}
.mode-img-wrap{width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.mode-img{width:52px;height:52px;object-fit:contain;display:block;border:none;outline:none;background:transparent;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));}
.mode-name{font-family:"Teko",sans-serif;font-size:25px;font-weight:700;letter-spacing:2px;color:var(--t1);text-align:center;line-height:1.1;}
.mode-desc{font-size:19px;color:var(--t2);text-align:center;line-height:1.3;}
.mode-same .mode-name{color:var(--blue);}
.mode-friend .mode-name{color:var(--gold);}
.mode-online .mode-name{color:var(--green);}

/* ── ROOM LOBBY ──────────────────────────────────────────────────────── */
#roomlobby,#roomcreated{
  flex-direction:column;align-items:center;
  min-height:calc(100vh - 60px);padding:24px 16px;
}
#roomlobby.on,#roomcreated.on{display:flex;}
.lobby-wrap{width:100%;max-width:520px;display:flex;flex-direction:column;align-items:center;gap:20px;margin-top:12px;}
.lobby-title{font-family:"Teko",sans-serif;font-size:clamp(20px,3.5vw,26px);font-weight:900;letter-spacing:2px;color:var(--gold);text-shadow:0 0 18px rgba(255,215,0,.3);}
.lobby-section{width:100%;background:var(--s1);border:1px solid var(--bd);padding:24px;display:flex;flex-direction:column;gap:14px;}
.lobby-section-label{font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;color:var(--gold);font-weight:700;}
.lobby-desc{font-size:19px;color:var(--t2);line-height:1.6;max-width:400px;}
.lobby-btn{width:100%;font-size:21px;padding:14px;display:flex;align-items:center;justify-content:center;}
.lobby-or{font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;color:var(--t2);display:flex;align-items:center;gap:12px;width:100%;}
.lobby-or::before,.lobby-or::after{content:'';flex:1;height:1px;background:var(--bd);}
.lobby-join-row{display:flex;gap:10px;}
.lobby-input{
  flex:1;background:var(--s2);border:1px solid var(--bd);color:var(--t1);
  font-family:"Teko",sans-serif;font-size:19px;letter-spacing:2px;
  padding:12px 16px;outline:none;text-transform:uppercase;
  transition:border-color .2s;
}
.lobby-input:focus{border-color:var(--gold);}
.lobby-join-btn{padding:12px 20px;font-size:21px;white-space:nowrap;}
.lobby-error{font-size:17px;color:var(--red);min-height:16px;letter-spacing:1px;}

/* ── ROOM CREATED CARD ───────────────────────────────────────────────── */
.roomcard{
  width:100%;background:var(--s1);border:1px solid rgba(255,215,0,.25);
  padding:24px;display:flex;gap:20px;align-items:flex-start;
}
.roomcard-qr{width:120px;height:120px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.roomcard-qr canvas,.roomcard-qr img{width:100%;height:100%;}
.roomcard-info{flex:1;display:flex;flex-direction:column;gap:4px;}
.roomcard-label{font-family:"Teko",sans-serif;font-size:23px;letter-spacing:2px;color:var(--gold);font-weight:700;}
.roomcard-code{font-family:"Teko",sans-serif;font-size:clamp(28px,6vw,38px);font-weight:900;letter-spacing:2px;color:var(--t1);}
.roomcard-linkrow{display:flex;gap:8px;margin-top:4px;}
.roomcard-linkinput{flex:1;background:var(--s2);border:1px solid var(--bd);color:var(--t2);font-size:21px;padding:7px 10px;outline:none;min-width:0;}
.lobby-waiting{display:flex;align-items:center;gap:8px;font-size:17px;color:var(--t2);letter-spacing:2px;margin-top:4px;}
.waiting-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:wdot 1.2s infinite;display:inline-block;}
.waiting-dot:nth-child(2){animation-delay:.2s;}
.waiting-dot:nth-child(3){animation-delay:.4s;}
@keyframes wdot{0%,80%,100%{opacity:.2;transform:scale(.8);}40%{opacity:1;transform:scale(1.1);}}

/* ── BOT INDICATOR IN GAME ───────────────────────────────────────────── */
.bot-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:"Teko",sans-serif;font-size:25px;letter-spacing:2px;font-weight:700;
  color:var(--green);background:rgba(0,230,118,.08);border:1px solid rgba(0,230,118,.25);
  padding:2px 7px;
}
@media(max-width:500px){
  .mode-card{width:calc(50% - 7px);min-height:110px;padding:16px 10px;}
  .roomcard{flex-direction:column;align-items:center;}
  .roomcard-qr{width:140px;height:140px;}
}

/* ── MOBILE / TABLET GAME GRID ───────────────────────────────────────── */
@media(max-width:768px){
  /* Tighten game screen padding */
  #game-same,#game-bot,#game-room,#custompicker{padding:6px 4px 32px;overflow-x:hidden;}

  /* Game header */
  .gh{margin-bottom:8px;gap:6px;flex-wrap:nowrap;align-items:center;}
  .gh-left,.gh-right{gap:6px;}
  .st-player{padding:5px 8px;min-width:60px;}
  .st-name{font-size:15px;letter-spacing:1px;}
  .st-middle{padding:5px 8px;}
  .st-vs{font-size:17px;}
  .st-round{font-size:15px;}
  .pip{width:10px;height:10px;}
  .ti{font-size:19px;padding:3px 7px;}
  .timer-wrap{gap:2px;}
  .timer-num{font-size:15px;}
  .timer-lbl{font-size:13px;letter-spacing:1px;}

  /* Grid — narrower column for row labels */
  .gw{grid-template-columns:72px repeat(3,1fr);gap:2px;}

  /* Category label cells */
  .cl{min-height:72px;padding:3px 2px;gap:2px;}
  .corner{min-height:72px;}
  .cl-pt{width:28px;height:28px;}
  .cl-flag{width:44px;height:27px;}
  .cl-car{width:52px;height:26px;}
  .cl-ic{font-size:18px;}
  .cl-tx{font-size:11px;letter-spacing:0;line-height:1.2;}
  .badge{font-size:13px;padding:1px 3px;letter-spacing:.3px;}

  /* Play cells */
  .cell{min-height:72px;}
  .cm{font-size:24px;}
  .cd{font-size:11px;max-width:60px;}
  .ce{width:20px;height:20px;}

  /* Used bar */
  .ub{font-size:19px;}
  .ut{padding:1px 4px;margin:1px;}

  /* Action buttons */
  .action-bar{gap:5px;margin-top:6px;}
  .btn-sm{font-size:15px;padding:6px 10px;}
}

/* ── SMALL PHONES (≤420px) — main mobile fix ─────────────────────────── */
/* 420px block moved to consolidated section below */

.res-countdown{font-family:"Teko",sans-serif;font-size:25px;letter-spacing:2px;color:var(--t2);margin-top:8px;text-align:center;}

/* ── OVERFLOW-X FIX — prevent horizontal scroll on all devices ─────── */
html {
  overflow-x: hidden;
}
body {
  overflow-x: hidden;
  width: 100%;
}
#app, #app > * {
  overflow-x: hidden;
  max-width: 100vw;
}
#info-footer, #info-footer > * {
  overflow-x: hidden;
  max-width: 100%;
  box-sizing: border-box;
}
/* Ensure grid never overflows on small screens */
@media (max-width: 600px) {
  .gw {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }
  .gw > * {
    min-width: 0;
    overflow: hidden;
  }
  .gh, .score-table {
    max-width: 100%;
    overflow-x: hidden;
  }
  .action-bar {
    max-width: 100%;
    overflow-x: hidden;
  }
  .ub {
    max-width: 100%;
    word-break: break-word;
    overflow-x: hidden;
  }
  #info-footer > div {
    max-width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* ── INFO FOOTER MOBILE FIX ────────────────────────────────────────── */
#info-footer { background: transparent !important; position: relative; }
#info-footer > div {
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 600px) {
  #footer-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  #info-footer {
    padding: 24px 14px 32px !important;
  }
  #info-footer h2 {
    margin-bottom: 20px !important;
  }
  #info-footer > div {
    max-width: 100% !important;
    padding: 0 !important;
  }
}

/* ── BACKGROUND: static dark + red corners, fixed so it covers everything ── */
/* ── BACKGROUND — solid base on html/body prevents black flash on scroll ── */
html {
  min-height: 100%;
  background: #0a0a0f; /* solid fallback — no fixed attachment on mobile */
}
body {
  background: #0a0a0f;
  min-height: 100%;
}

/* ── STATIC BACKGROUND LAYER (fixed div — reliable on iOS/Android) ───── */
#bg-layer {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(140,0,0,0.55) 0%, rgba(80,0,0,0.30) 30%, transparent 62%),
    radial-gradient(ellipse at 0% 85%, rgba(120,0,0,0.35) 0%, transparent 45%),
    radial-gradient(ellipse at 100% 85%, rgba(120,0,0,0.35) 0%, transparent 45%),
    repeating-linear-gradient(-45deg,transparent,transparent 60px,rgba(225,6,0,.015) 60px,rgba(225,6,0,.015) 62px),
    #0a0a0f;
}
/* Everything above the bg-layer */
header, #app > .scr, #app > * {
  position: relative;
  z-index: 1;
}

/* ── GAME SCREEN CENTERING ──────────────────────────────────────────── */
#game-same, #game-bot, #game-room {
  max-width: 900px;
  margin: 0 auto;
  padding: 12px 16px 40px;
  box-sizing: border-box;
}
/* Action bar centrat si vizibil */
.action-bar {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 12px;
  flex-wrap: wrap;
  padding: 0 8px;
}
/* .ub removed - no used bar */

/* duplicate 768px block removed - consolidated below */

/* ── CUSTOM GAME PICKER ──────────────────────────────────────────────── */
.mode-custom:hover{border-color:var(--purple);}
.mode-custom .mode-name{color:var(--purple);}

#custompicker{position:relative;}
#custompicker.on{display:block;}
#custompicker > .gw{margin-top:16px;}

.cpick-wrap{max-width:560px;margin:0 auto;padding:16px 14px;}

/* ── Slot add button inside .cl cells ── */
.cpick-slot-add{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:4px;}
.cpick-plus{font-size:28px;color:var(--t2);line-height:1;}
.cpick-add-label{font-size:16px;letter-spacing:2px;color:var(--t2);font-weight:700;font-family:"Teko",sans-serif;}

/* col/row cells clickable & hoverable */
.cpick-col-cell,.cpick-row-cell{cursor:pointer;transition:background .18s,border-color .18s;}
.cpick-col-cell:hover,.cpick-row-cell:hover{background:var(--s2)!important;}
.cpick-col-cell.filled,.cpick-row-cell.filled{cursor:pointer;}
.cpick-col-cell.filled:hover,.cpick-row-cell.filled:hover{opacity:.85;}

/* Active slot — all empty slots pulse to show they're clickable */
.cpick-active-slot{border:2px solid var(--bd)!important;cursor:pointer;}
.cpick-active-slot:hover{border-color:var(--red)!important;background:var(--s2)!important;}
.cpick-active-slot .cpick-plus{color:var(--t2);}
.cpick-active-slot .cpick-add-label{color:var(--t2);}

/* game cells in picker — dimmed, not clickable */
.cpick-game-cell{cursor:default;opacity:.45;}

/* Filled slot content (reuse .cl structure) */
.cpick-slot-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:4px;width:100%;height:100%;position:relative;}
.cpick-slot-img{object-fit:contain;}
.cpick-slot-img.portrait{width:42px;height:42px;border-radius:50%;object-fit:cover;object-position:top;}
.cpick-slot-img.flag{width:52px;height:32px;object-fit:cover;border-radius:3px;}
.cpick-slot-img.car{width:56px;height:32px;object-fit:contain;}
.cpick-slot-lbl{font-size:13px;font-weight:700;color:var(--t1);letter-spacing:.3px;line-height:1.15;text-transform:uppercase;text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:90px;}
.cpick-slot-badge{font-size:11px;padding:1px 5px;letter-spacing:.5px;font-weight:700;}
.cpick-slot-x{position:absolute;top:3px;right:5px;font-size:14px;color:var(--t2);line-height:1;z-index:2;cursor:pointer;}
.cpick-slot-x:hover{color:var(--red);}

/* ── PANEL MODAL (small centered popup) ── */
.cpick-panel{
  position:fixed;inset:0;
  display:none;align-items:center;justify-content:center;
  z-index:200;padding:16px;
  background:rgba(0,0,0,.65);
}
.cpick-panel.open{display:flex;}
.cpick-panel-inner{
  background:var(--s1);border:1px solid var(--bd);
  width:100%;max-width:520px;max-height:80vh;
  display:flex;flex-direction:column;
  box-shadow:0 8px 40px rgba(0,0,0,.7);
}
.cpick-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 4px;flex-shrink:0;}
.cpick-panel-title{font-family:"Teko",sans-serif;font-size:22px;font-weight:700;letter-spacing:2px;color:var(--t1);}
.cpick-panel-close{background:transparent;border:1px solid var(--bd);color:var(--t2);font-size:18px;padding:4px 10px;cursor:pointer;font-family:"Teko",sans-serif;}
.cpick-panel-close:hover{color:var(--red);border-color:var(--red);}

/* Tabs */
.cpick-tabs{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;margin:4px 0 8px;border-bottom:1px solid var(--bd);padding:0 12px 8px;flex-shrink:0;}
.cpick-tab{font-family:"Teko",sans-serif;font-size:19px;font-weight:700;letter-spacing:1px;padding:3px 10px;background:transparent;border:1px solid transparent;color:var(--t2);cursor:pointer;transition:all .15s;text-transform:uppercase;}
.cpick-tab:hover{color:var(--t1);border-color:var(--bd);}
.cpick-tab.active{color:var(--purple);border-color:var(--purple);background:rgba(179,136,255,.08);}

/* Category grid */
.cpick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;overflow-y:auto;padding:4px 12px 16px;flex:1;}
.cpick-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;padding:10px 6px;background:var(--s1);border:1px solid var(--bd);
  cursor:pointer;transition:all .18s;text-align:center;min-height:96px;
  font-family:"Teko",sans-serif;position:relative;
}
.cpick-card:hover:not(.disabled):not(.selected){border-color:var(--purple);background:var(--s2);transform:translateY(-2px);}
.cpick-card.selected{border-color:var(--gold);background:rgba(255,215,0,.06);}
.cpick-card.selected::after{content:'✓';position:absolute;top:4px;right:6px;font-size:14px;color:var(--gold);}
.cpick-card.disabled{opacity:.3;cursor:not-allowed;}
.cpick-card-img{width:60px;height:38px;object-fit:contain;}
.cpick-card-img.flag{width:58px;height:36px;object-fit:cover;border-radius:3px;border:1px solid rgba(255,255,255,.1);}
.cpick-card-img.portrait{width:44px;height:44px;border-radius:50%;object-fit:cover;object-position:top;}
.cpick-card-label{font-size:15px;font-weight:700;color:var(--t2);letter-spacing:.3px;line-height:1.2;text-transform:uppercase;}

/* panel backdrop - handled by panel itself */

/* 500px cpick block removed - consolidated below */

/* ═══════════════════════════════════════════════════════════════════════
   CONSOLIDATED MOBILE STYLES — ordered largest to smallest so small
   screens always win (each block overrides the one above it)
   ═══════════════════════════════════════════════════════════════════════ */

/* ── ≤768px (tablets & large phones) ─────────────────────────────────── */
/* ── ≤480px (most Android phones) ────────────────────────────────────── */
@media(max-width:480px){
  #game-same,#game-bot,#game-room,#custompicker{padding:4px 3px 22px;}
  /* Single-row header */
  .gh{flex-direction:row;align-items:center;justify-content:space-between;gap:4px;margin-bottom:5px;flex-wrap:nowrap;}
  .gh-left{flex:1;min-width:0;}
  .gh-right{display:flex;flex-direction:row;align-items:center;gap:5px;flex-shrink:0;}
  .score-table{clip-path:none;}
  .st-player{padding:3px 5px;min-width:0;flex:1;}
  .st-name{font-size:12px;letter-spacing:0;}
  .st-middle{padding:3px 5px;}
  .st-vs{font-size:13px;} .st-round{font-size:11px;}
  .pip{width:8px;height:8px;} .st-pips{gap:2px;}
  .timer-wrap{gap:1px;}
  .timer-ring{width:36px;height:36px;} .timer-ring svg{width:36px;height:36px;}
  .timer-num{font-size:12px;} .timer-lbl{font-size:10px;letter-spacing:0;}
  .ti{font-size:13px;padding:2px 6px;white-space:nowrap;}
  .gw{grid-template-columns:60px repeat(3,1fr);gap:2px;}
  .cl{min-height:65px;padding:2px 1px;gap:1px;} .corner{min-height:65px;}
  .cl-flag{width:36px;height:22px;} .cl-car{width:44px;height:22px;} .cl-pt{width:23px;height:23px;}
  .cl-tx{font-size:10px;line-height:1.15;} .badge{font-size:9px;padding:1px 2px;}
  .cell{min-height:65px;} .cm{font-size:20px;} .cd{font-size:10px;max-width:50px;} .ce{width:18px;height:18px;}
  .action-bar{gap:3px;margin-top:4px;}
  .btn-sm{font-size:12px;padding:5px 6px;}
  /* cpick panel */
  .cpick-tabs{gap:3px;padding:0 6px 6px;}
  .cpick-tab{font-size:14px;padding:2px 6px;}
  .cpick-grid{grid-template-columns:repeat(3,1fr);gap:5px;padding:4px 6px 12px;}
  .cpick-card{min-height:75px;padding:6px 3px;}
  .cpick-card-label{font-size:12px;}
  /* mode cards */
  .mode-grid{gap:6px;flex-wrap:wrap;}
  .mode-card{width:calc(50% - 3px);min-height:110px;padding:14px 8px;}
  .mode-img{width:40px;height:40px;}
  .mode-name{font-size:18px;letter-spacing:1px;} .mode-desc{font-size:15px;}
}

/* ── ≤380px (very small phones) ──────────────────────────────────────── */
@media(max-width:380px){
  .ti{font-size:11px;padding:2px 4px;}
  .timer-ring{width:30px;height:30px;} .timer-ring svg{width:30px;height:30px;}
  .timer-num{font-size:10px;} .timer-lbl{font-size:9px;}
  .st-name{font-size:11px;}
  .gw{grid-template-columns:55px repeat(3,1fr);gap:1px;}
  .cl{min-height:60px;} .corner{min-height:60px;}
  .cell{min-height:60px;} .cm{font-size:18px;}
  .btn-sm{font-size:11px;padding:4px 5px;}
}
