:root{
  --bg:#070a12;
  --panel:#101827;
  --panel2:#162033;
  --text:#f8fafc;
  --muted:#94a3b8;
  --line:rgba(255,255,255,.12);
  --accent:#facc15;
  --good:#22c55e;
  --bad:#ef4444;
  --radius:22px;
  --shadow:0 22px 60px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;background:radial-gradient(circle at top left,#1f2937 0,#070a12 42%,#020617 100%);color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{overflow-x:hidden}
button,input,select{font:inherit}
button{border:0;border-radius:16px;padding:12px 16px;background:#26334d;color:var(--text);font-weight:800;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.18);transition:.15s transform,.15s opacity,.15s background}
button:active{transform:scale(.97)}
button:hover{background:#33415f}
button:disabled{opacity:.45;cursor:not-allowed;transform:none}
button.primary{background:linear-gradient(135deg,#facc15,#fb923c);color:#111827}
button.good{background:linear-gradient(135deg,#16a34a,#22c55e);color:#052e16}
button.bad{background:linear-gradient(135deg,#dc2626,#f97316);color:#fff}
button.dark{background:#0f172a;border:1px solid var(--line)}
button.ghost{background:rgba(255,255,255,.06);border:1px solid var(--line)}
button.small{padding:8px 10px;border-radius:12px;font-size:13px}
button.full{width:100%}
input,select{width:100%;border:1px solid var(--line);background:#0b1220;color:var(--text);border-radius:14px;padding:12px 14px;outline:none}
input:focus,select:focus{border-color:rgba(250,204,21,.8);box-shadow:0 0 0 3px rgba(250,204,21,.12)}
label{font-size:12px;font-weight:900;color:#cbd5e1;text-transform:uppercase;letter-spacing:.08em;display:block;margin:0 0 8px}
.wrap{width:min(1480px,calc(100vw - 28px));margin:0 auto;padding:16px 0}
.header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.brand{display:flex;align-items:center;gap:12px}
.logo-dot{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,#facc15,#ef4444,#2563eb);box-shadow:0 0 30px rgba(250,204,21,.25)}
.title{font-size:clamp(24px,4vw,46px);font-weight:1000;letter-spacing:-.04em;line-height:1;margin:0}
.subtitle{color:var(--muted);font-size:14px;margin:4px 0 0;font-weight:700}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;backdrop-filter:blur(10px)}
.card h2,.card h3{margin:0 0 12px;letter-spacing:-.03em}
.card h2{font-size:22px}.card h3{font-size:17px;color:#e2e8f0}
.muted{color:var(--muted)}
.kpi{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:7px 10px;font-weight:900;font-size:13px;color:#e2e8f0}
.badge.big{font-size:18px;padding:10px 14px}
.score-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.team-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:18px;padding:12px;background:rgba(15,23,42,.75)}
.team-card:before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:var(--team,#facc15)}
.team-name{font-size:14px;font-weight:1000;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team-score{font-size:clamp(28px,5vw,54px);font-weight:1000;letter-spacing:-.06em;line-height:.95;margin-top:6px}
.team-card.active{outline:3px solid var(--team,#facc15);box-shadow:0 0 35px rgba(250,204,21,.18)}
.canvas-shell{background:#fff;border-radius:24px;overflow:hidden;border:8px solid rgba(255,255,255,.16);box-shadow:0 20px 70px rgba(0,0,0,.45);position:relative}
.draw-canvas{display:block;width:100%;height:100%;background:#fff;touch-action:none;cursor:crosshair}
.canvas-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;color:#0f172a;font-size:clamp(24px,4vw,52px);font-weight:1000;opacity:.12;pointer-events:none;padding:24px}
.timer{font-size:clamp(42px,9vw,112px);font-weight:1000;letter-spacing:-.08em;line-height:.9;text-align:center}
.timer.danger{color:#f97316;text-shadow:0 0 32px rgba(249,115,22,.35)}
.message{font-size:clamp(20px,3vw,40px);font-weight:1000;text-align:center;line-height:1.05;letter-spacing:-.04em}
.wordbox{border:1px dashed rgba(250,204,21,.6);background:rgba(250,204,21,.12);border-radius:18px;padding:14px;text-align:center}
.secret-word{font-size:clamp(28px,6vw,64px);font-weight:1000;line-height:1;letter-spacing:-.05em;color:#fef3c7}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.actions{display:flex;gap:10px;flex-wrap:wrap}.actions>*{flex:1 1 auto}
.stack{display:flex;flex-direction:column;gap:10px}.compact{gap:8px}
.player-list{display:flex;gap:8px;flex-wrap:wrap}
.player-pill{border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:999px;padding:8px 10px;font-size:13px;font-weight:800;color:#e2e8f0}
.player-pill.active{background:rgba(250,204,21,.18);border-color:rgba(250,204,21,.65);color:#fff}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}.table td{background:rgba(255,255,255,.05);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:9px;font-size:13px}.table td:first-child{border-left:1px solid var(--line);border-radius:12px 0 0 12px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0;text-align:right}
.screen-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:14px;min-height:calc(100vh - 32px)}
.screen-canvas{height:calc(100vh - 32px)}
.side-panel{display:flex;flex-direction:column;gap:14px}.grow{flex:1}.center{text-align:center}.hidden{display:none!important}
.login{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(460px,100%)}
.mobile-main{min-height:100vh;display:flex;flex-direction:column}.mobile-canvas{height:55vh;min-height:360px}.phone-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.phone-actions .wide{grid-column:1/-1}
.admin-layout{display:grid;grid-template-columns:330px minmax(0,1fr) 360px;gap:14px}.admin-main-canvas{height:520px}.log{max-height:220px;overflow:auto;font-size:12px;color:#cbd5e1}.log div{padding:7px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.floating-status{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:#0f172a;border:1px solid var(--line);border-radius:999px;padding:10px 14px;color:#e2e8f0;font-weight:900;box-shadow:var(--shadow);z-index:20;max-width:calc(100vw - 24px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:1100px){.screen-layout{grid-template-columns:1fr}.screen-canvas{height:68vh}.side-panel{display:grid;grid-template-columns:1fr 1fr}.admin-layout{grid-template-columns:1fr}.admin-main-canvas{height:460px}.score-row{grid-template-columns:repeat(2,1fr)}}
@media (max-width:720px){.wrap{width:min(100vw - 16px,680px);padding:8px 0}.header{align-items:flex-start}.title{font-size:28px}.card{padding:12px;border-radius:18px}.form-row{grid-template-columns:1fr}.score-row{grid-template-columns:repeat(2,1fr);gap:8px}.side-panel{display:flex}.screen-canvas{height:58vh}.mobile-canvas{height:52vh;min-height:330px}button{padding:11px 12px}.phone-actions{grid-template-columns:1fr}.phone-actions .wide{grid-column:auto}.timer{font-size:54px}.message{font-size:24px}}


.gear-btn{width:44px;height:44px;display:grid;place-items:center;padding:0;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--line);font-size:20px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.player-options{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:-4px 0 4px;animation:popIn .16s ease-out}
@keyframes popIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@media (display-mode: fullscreen){.mobile-main{min-height:100vh}.wrap{padding-top:max(8px,env(safe-area-inset-top))}.mobile-canvas{height:58vh}}
@media (max-width:720px){.player-options{grid-template-columns:1fr}.gear-btn{width:40px;height:40px;font-size:18px}.mobile-main:fullscreen .mobile-canvas{height:60vh}}

/* Admin compacto Pictionary */
body.admin-page{overflow:hidden}
.admin-wrap{width:min(100vw - 18px,1580px);padding:8px 0}
.admin-header{margin-bottom:6px;min-height:42px}
.admin-brand{gap:9px}
.admin-logo{width:30px;height:30px;border-radius:10px}
.admin-title{font-size:clamp(20px,2.2vw,30px);letter-spacing:-.035em}
.admin-subtitle{font-size:11px;margin-top:1px}
.admin-top-actions{max-width:none;gap:6px;justify-content:flex-end}
.admin-top-actions button{white-space:nowrap}
.window-toolbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:0 0 8px;padding:6px 8px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.045)}
.toolbar-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:1000;color:#cbd5e1;margin-right:2px}
.window-toggle{padding:6px 9px!important;font-size:11px!important;opacity:.62}
.window-toggle.active{opacity:1;background:rgba(250,204,21,.14);border-color:rgba(250,204,21,.42)}
.admin-compact-layout{display:grid;grid-template-columns:285px minmax(0,1fr) 305px;gap:9px;height:calc(100vh - 104px);min-height:560px;overflow:hidden}
.admin-col{min-height:0;overflow:hidden}.admin-left,.admin-right{gap:8px}.admin-center{gap:8px}
.admin-panel{padding:10px;border-radius:16px;box-shadow:0 14px 34px rgba(0,0,0,.24)}
.admin-panel h2{font-size:15px;margin:0 0 7px;letter-spacing:-.025em}.admin-panel h3{font-size:13px;margin-bottom:6px}
.admin-panel label{font-size:9.8px;margin-bottom:4px;letter-spacing:.07em}
.admin-panel input,.admin-panel select{padding:8px 9px;border-radius:10px;font-size:13px}
.admin-panel button.small,.admin-top-actions button.small,.window-toolbar button.small{padding:7px 9px;border-radius:10px;font-size:12px;box-shadow:0 6px 14px rgba(0,0,0,.15)}
.split-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px}.tight-row{gap:7px}
.mini-reset-panel{flex:0 0 auto}.mini-reset-panel h2{margin-bottom:4px}
.panel-headline{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.tiny-text{font-size:11px}
.admin-score-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}
.admin-score-card{padding:8px 8px 7px;border-radius:14px;min-height:88px}.admin-score-card:before{height:4px}
.score-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:4px}.admin-score-card .team-name{font-size:12px;margin-top:2px;min-width:0;max-width:62%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-team-score{font-size:clamp(26px,4.8vw,44px);margin-top:4px}
.score-mini-buttons{display:flex;gap:3px;flex-shrink:0}.score-one{padding:5px 6px!important;font-size:11px!important;border-radius:8px!important;min-width:34px}
.game-control-panel{padding:8px 10px}.game-status-grid{display:grid;grid-template-columns:160px minmax(0,1fr) 285px;align-items:center;gap:8px}.admin-timer{font-size:clamp(32px,5vw,52px);line-height:.85;text-align:left}.admin-message{font-size:clamp(15px,2vw,22px);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-badges{display:flex;gap:5px;flex-wrap:wrap;align-items:center}.game-badges .badge{font-size:11px;padding:5px 8px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-game-buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px}.admin-game-buttons button{width:100%}
.compact-canvas{height:auto;min-height:0;flex:1;border-width:5px;border-radius:18px}.compact-canvas .canvas-placeholder{font-size:clamp(22px,3vw,42px)}
.players-panel{flex:1;min-height:0;display:flex;flex-direction:column}.players-scroll{overflow:auto;min-height:0;padding-right:2px}.players-team-block{padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.07)}.players-team-block:last-child{border-bottom:0}.team-mini-title{font-size:11px;padding:5px 7px;margin-bottom:5px}.admin-player-list{gap:5px}.admin-player-list .player-pill{font-size:11px;padding:5px 7px}.micro-btn{padding:2px 6px!important;min-width:auto;margin-left:4px;border-radius:999px!important;font-size:11px!important}
.log-panel{height:190px;flex:0 0 auto}.admin-log{max-height:138px;font-size:11px}.admin-log div{padding:5px 0}
.admin-panel-hidden{display:none!important}
.admin-page:fullscreen .admin-compact-layout{height:calc(100vh - 104px)}
@media (max-height:780px){
  .admin-wrap{padding:5px 0}.admin-header{margin-bottom:4px}.window-toolbar{margin-bottom:6px;padding:5px 7px}.admin-compact-layout{height:calc(100vh - 91px);min-height:480px;gap:7px}.admin-panel{padding:8px}.admin-panel h2{font-size:14px;margin-bottom:5px}.admin-panel input,.admin-panel select{padding:6px 8px}.admin-panel label{font-size:9px;margin-bottom:3px}.admin-panel button.small,.admin-top-actions button.small,.window-toolbar button.small{padding:6px 8px;font-size:11px}.admin-score-card{min-height:78px}.admin-team-score{font-size:34px}.game-status-grid{grid-template-columns:128px minmax(0,1fr) 245px}.admin-timer{font-size:38px}.admin-message{font-size:16px}.log-panel{height:154px}.admin-log{max-height:106px}.compact-canvas{border-width:4px}
}
@media (max-width:1200px){
  body.admin-page{overflow:auto}.admin-compact-layout{grid-template-columns:1fr;height:auto;min-height:0;overflow:visible}.admin-col{overflow:visible}.admin-score-row{grid-template-columns:repeat(2,1fr)}.game-status-grid{grid-template-columns:1fr}.admin-timer,.admin-message{text-align:center}.log-panel{height:auto}.admin-log{max-height:180px}.compact-canvas{height:430px;flex:none}.admin-right{display:grid;grid-template-columns:1fr 1fr}.players-panel{min-height:260px}
}
@media (max-width:720px){.admin-wrap{width:min(100vw - 12px,680px)}.admin-header{align-items:center}.admin-top-actions{width:100%;display:grid;grid-template-columns:1fr 1fr 1fr}.window-toolbar{gap:5px}.window-toggle{flex:1 1 30%}.admin-score-row{grid-template-columns:1fr 1fr}.admin-right{display:flex}.compact-canvas{height:360px}.admin-title{font-size:22px}.admin-subtitle{display:none}}

/* Ajuste v1.1: lienzo cuadrado sin deformación y vistas rápidas de operación */
.square-board{
  aspect-ratio:1 / 1;
  height:auto;
}
.mobile-canvas.square-board{
  width:min(100%, 64vh, 560px);
  min-height:0;
  align-self:center;
  flex:0 0 auto;
}
.screen-canvas.square-board{
  width:min(100%, calc(100vh - 32px));
  height:auto;
  justify-self:center;
  align-self:start;
}
.compact-canvas.square-board{
  width:min(100%, calc(100vh - 255px));
  height:auto;
  min-height:0;
  flex:0 0 auto;
  align-self:center;
}
body[data-admin-mode="run"] .compact-canvas.square-board,
body[data-admin-mode="score"] .compact-canvas.square-board{
  width:min(100%, calc(100vh - 215px));
}
body[data-admin-mode="config"] .compact-canvas.square-board{
  width:min(100%, calc(100vh - 245px));
}
.toolbar-sep{width:1px;height:24px;background:var(--line);margin:0 2px}
.layout-preset{white-space:nowrap}
.admin-panel-hidden + .canvas-shell{margin-top:0}
@media (max-height:780px){
  .compact-canvas.square-board{width:min(100%, calc(100vh - 205px));}
  body[data-admin-mode="run"] .compact-canvas.square-board,
  body[data-admin-mode="score"] .compact-canvas.square-board{width:min(100%, calc(100vh - 178px));}
}
@media (max-width:1200px){
  .compact-canvas.square-board{width:min(100%, 430px);height:auto;}
  .screen-canvas.square-board{width:min(100%, 74vh);}
}
@media (max-width:720px){
  .mobile-canvas.square-board{width:min(100%, 58vh, 520px);}
  .compact-canvas.square-board{width:min(100%, 360px);height:auto;}
  .toolbar-sep{display:none}
}

/* Ajuste v1.5: admin con dibujo al centro y menús laterales */
.admin-side-layout{
  grid-template-columns: clamp(230px, 18vw, 285px) minmax(420px, 1fr) clamp(250px, 20vw, 330px);
  align-items:stretch;
}
.admin-side-layout .admin-col{
  min-height:0;
}
.admin-center-stage{
  min-height:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:0 2px;
}
.admin-centered-canvas.compact-canvas.square-board{
  width:min(100%, calc(100vh - 176px), calc(100vw - 650px));
  max-width:860px;
  min-width:390px;
  height:auto;
  flex:0 0 auto;
  align-self:center;
  border-width:6px;
  border-radius:20px;
}
.admin-center-hud{
  width:min(100%, 860px);
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(2,6,23,.72);
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.admin-center-hud .admin-timer{
  font-size:clamp(34px,4vw,54px);
  line-height:.86;
  text-align:left;
  min-width:104px;
}
.admin-hud-info{min-width:0}
.admin-center-hud .admin-message{
  font-size:clamp(15px,1.7vw,24px);
  text-align:left;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.admin-hud-badges{margin-top:5px}
.admin-hud-badges .badge{
  font-size:11px;
  padding:5px 8px;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.side-game-buttons{
  grid-template-columns:1fr 1fr;
  gap:7px;
}
.admin-side-layout .score-panel{flex:0 0 auto}
.admin-side-layout .admin-score-row{
  grid-template-columns:1fr;
  gap:7px;
}
.admin-side-layout .admin-score-card{
  min-height:72px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:8px;
}
.admin-side-layout .admin-score-card:before{width:6px;height:auto;inset:0 auto 0 0}
.admin-side-layout .score-card-top{
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
}
.admin-side-layout .admin-score-card .team-name{
  max-width:100%;
  font-size:13px;
}
.admin-side-layout .admin-team-score{
  font-size:38px;
  margin:0;
  line-height:.9;
  text-align:right;
}
.admin-side-layout .score-mini-buttons{gap:5px}
.admin-side-layout .players-panel{flex:1 1 auto}
.admin-side-layout .log-panel{height:150px;flex:0 0 auto}
.admin-side-layout .admin-log{max-height:100px}
body[data-admin-mode="run"] .admin-centered-canvas.compact-canvas.square-board,
body[data-admin-mode="score"] .admin-centered-canvas.compact-canvas.square-board,
body[data-admin-mode="config"] .admin-centered-canvas.compact-canvas.square-board{
  width:min(100%, calc(100vh - 176px), calc(100vw - 650px));
}
body:has(#configPanel.admin-panel-hidden):has(#playersPanel.admin-panel-hidden) .admin-centered-canvas.compact-canvas.square-board,
body:has(#scorePanel.admin-panel-hidden):has(#gamePanel.admin-panel-hidden) .admin-centered-canvas.compact-canvas.square-board{
  width:min(100%, calc(100vh - 176px), calc(100vw - 500px));
}
@media (max-height:780px){
  .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="run"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="score"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="config"] .admin-centered-canvas.compact-canvas.square-board{
    width:min(100%, calc(100vh - 154px), calc(100vw - 620px));
    min-width:340px;
    border-width:4px;
  }
  .admin-center-hud{padding:6px 8px;gap:8px}
  .admin-center-hud .admin-timer{font-size:38px;min-width:76px}
  .admin-center-hud .admin-message{font-size:15px}
  .admin-hud-badges .badge{font-size:10px;padding:4px 7px}
  .admin-side-layout .admin-score-card{min-height:62px}
  .admin-side-layout .admin-team-score{font-size:32px}
  .side-game-buttons{gap:5px}
}
@media (max-width:1280px){
  .admin-side-layout{
    grid-template-columns:230px minmax(360px,1fr) 250px;
  }
  .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="run"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="score"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="config"] .admin-centered-canvas.compact-canvas.square-board{
    width:min(100%, calc(100vh - 180px), calc(100vw - 520px));
    min-width:340px;
  }
}
@media (max-width:1050px){
  body.admin-page{overflow:auto}
  .admin-side-layout{
    grid-template-columns:1fr;
    height:auto;
    min-height:0;
    overflow:visible;
  }
  .admin-center-stage{order:1;overflow:visible;padding:0}
  .admin-left{order:2}
  .admin-right{order:3}
  .admin-col{overflow:visible}
  .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="run"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="score"] .admin-centered-canvas.compact-canvas.square-board,
  body[data-admin-mode="config"] .admin-centered-canvas.compact-canvas.square-board{
    width:min(100%, 560px);
    min-width:0;
  }
  .admin-center-hud{width:min(100%,560px)}
  .admin-side-layout .admin-score-row{grid-template-columns:repeat(2,1fr)}
  .admin-side-layout .admin-score-card{display:block;min-height:82px}.admin-side-layout .admin-score-card:before{width:auto;height:4px;inset:0 0 auto 0}.admin-side-layout .score-card-top{flex-direction:row;align-items:flex-start}.admin-side-layout .admin-team-score{text-align:left;font-size:36px;margin-top:4px}
  .admin-right{display:flex}
}
@media (max-width:720px){
  .admin-center-hud{grid-template-columns:1fr;text-align:center}
  .admin-center-hud .admin-timer,.admin-center-hud .admin-message{text-align:center;min-width:0}
  .admin-hud-badges{justify-content:center}
  .admin-centered-canvas.compact-canvas.square-board{width:min(100%, 380px)}
  .admin-side-layout .admin-score-row{grid-template-columns:1fr 1fr}
}

/* Columnas laterales ocultables desde las ventanas */
body.admin-no-left .admin-side-layout{grid-template-columns:minmax(420px,1fr) clamp(250px,20vw,330px)}
body.admin-no-left .admin-left{display:none}
body.admin-no-left .admin-center-stage{order:0}
body.admin-no-left .admin-right{order:0}
body.admin-no-right .admin-side-layout{grid-template-columns:clamp(230px,18vw,285px) minmax(420px,1fr)}
body.admin-no-right .admin-right{display:none}
body.admin-no-left.admin-no-right .admin-side-layout{grid-template-columns:1fr}
body.admin-no-left.admin-no-right .admin-centered-canvas.compact-canvas.square-board{width:min(100%, calc(100vh - 176px), 900px)}
body.admin-no-left .admin-centered-canvas.compact-canvas.square-board{width:min(100%, calc(100vh - 176px), calc(100vw - 380px), 900px)}
body.admin-no-right .admin-centered-canvas.compact-canvas.square-board{width:min(100%, calc(100vh - 176px), calc(100vw - 330px), 900px)}
@media (max-width:1050px){
  body.admin-no-left .admin-side-layout,body.admin-no-right .admin-side-layout,body.admin-no-left.admin-no-right .admin-side-layout{grid-template-columns:1fr}
}


/* Ajuste v1.7: marcador de pantalla listo para máximo 4 equipos */
.screen-layout{
  grid-template-columns:minmax(0,1fr) clamp(330px,26vw,390px);
}
.side-panel .score-row{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.side-panel .team-card{
  min-width:0;
  padding:12px 10px 11px;
  border-radius:16px;
}
.side-panel .team-card:before{
  height:5px;
}
.side-panel .team-name{
  max-width:100%;
  font-size:clamp(11px,1vw,14px);
  line-height:1.05;
}
.side-panel .team-score{
  width:100%;
  font-size:clamp(34px,4.6vw,58px);
  line-height:.9;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
.side-panel .team-card.active{
  outline-width:3px;
  outline-offset:-3px;
}
@media (max-height:760px){
  .side-panel{gap:10px}
  .side-panel .card{padding:12px}
  .side-panel .score-row{gap:8px}
  .side-panel .team-card{padding:10px 8px 9px}
  .side-panel .team-score{font-size:clamp(30px,4vw,48px)}
}
@media (max-width:1100px){
  .side-panel .score-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .side-panel .team-score{font-size:clamp(30px,6vw,48px)}
}
@media (max-width:720px){
  .side-panel .score-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .side-panel .team-score{font-size:clamp(32px,12vw,54px)}
}

/* Ajuste v1.8: centrar nombre y marcador en pantalla.php */
.side-panel .score-row .team-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.side-panel .score-row .team-name{
  width:100%;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
.side-panel .score-row .team-score{
  width:100%;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
  overflow:visible;
}

/* Ajuste v2.2: herramientas de dibujo visibles en celular */
.draw-toolbox{
  position:sticky;
  bottom:8px;
  z-index:18;
  padding:8px;
  margin-top:-2px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:rgba(2,6,23,.86);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 42px rgba(0,0,0,.36);
}
.draw-toolbox button{
  min-height:46px;
  font-size:15px;
  letter-spacing:-.01em;
}
.draw-toolbox.is-active{
  outline:2px solid rgba(250,204,21,.28);
}
.player-options .undo-action,
.player-options .clear-drawing-action{
  display:block;
}
@media (max-width:720px){
  .mobile-main .wrap{
    padding-bottom:calc(92px + env(safe-area-inset-bottom));
  }
  .phone-actions.draw-toolbox{
    position:fixed;
    left:8px;
    right:8px;
    bottom:max(8px, env(safe-area-inset-bottom));
    grid-template-columns:1fr 1fr;
  }
  .phone-actions.draw-toolbox button{
    padding:12px 8px;
    font-size:14px;
    border-radius:14px;
  }
  .mobile-canvas.square-board{
    width:min(100%, 50vh, 520px);
  }
}

/* Ajuste v2.3: modo simultáneo por equipos */
.team-correct-buttons{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:7px;
  margin:0 0 8px;
}
.team-correct-buttons button{
  width:100%;
  min-height:42px;
}
.mobile-correct-teams{
  grid-template-columns:1fr;
  margin-bottom:10px;
}
.players-summary{
  font-size:clamp(16px,1.8vw,28px);
  line-height:1.16;
}

.screen-boards{
  display:grid;
  gap:12px;
  align-content:center;
  justify-content:center;
  justify-items:center;
  min-height:calc(100vh - 32px);
  width:100%;
}
.screen-boards[data-count="1"]{grid-template-columns:minmax(0,1fr)}
.screen-boards[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.screen-boards[data-count="3"],
.screen-boards[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.screen-board-card{
  width:100%;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:center;
}
.screen-boards[data-count="1"] .screen-board-card{max-width:min(100%, calc(100vh - 32px), 980px)}
.screen-boards[data-count="2"] .screen-board-card{max-width:min(100%, calc(100vh - 72px), 620px)}
.screen-boards[data-count="3"] .screen-board-card,
.screen-boards[data-count="4"] .screen-board-card{max-width:min(100%, calc((100vh - 92px) / 2), 430px)}
.screen-board-title{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 12px;
  border:1px solid var(--line);
  border-left:8px solid var(--team,#facc15);
  border-radius:16px;
  background:rgba(15,23,42,.88);
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}
.screen-board-title span,
.screen-board-title strong{
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.screen-board-title span{font-weight:1000;color:#fff}
.screen-board-title strong{font-weight:900;color:#cbd5e1;text-align:right}
.screen-team-canvas.square-board{
  width:100%;
  height:auto;
  border-width:6px;
  border-color:var(--team,#facc15);
}
.simultaneous-screen .screen-layout{
  grid-template-columns:minmax(0,1fr) clamp(330px,24vw,390px);
}

.admin-board-grid{
  width:100%;
  min-height:0;
  flex:1 1 auto;
  display:grid;
  gap:8px;
  align-content:center;
  justify-content:center;
  justify-items:center;
}
.admin-board-grid[data-count="1"]{grid-template-columns:minmax(0,1fr)}
.admin-board-grid[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-board-grid[data-count="3"],
.admin-board-grid[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-board-card{
  width:100%;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:center;
}
.admin-board-grid[data-count="1"] .admin-board-card{max-width:min(100%, calc(100vh - 176px), 860px)}
.admin-board-grid[data-count="2"] .admin-board-card{max-width:min(100%, calc(100vw - 650px), 430px)}
.admin-board-grid[data-count="3"] .admin-board-card,
.admin-board-grid[data-count="4"] .admin-board-card{max-width:min(100%, calc((100vh - 236px) / 2), 330px)}
.admin-board-title{
  padding:6px 9px;
  border-radius:13px;
  font-size:12px;
}
.team-preview-canvas.admin-centered-canvas.compact-canvas.square-board{
  width:100%!important;
  min-width:0!important;
  max-width:none!important;
  height:auto!important;
  border-color:var(--team,#facc15);
}
.admin-board-grid[data-count="2"] .team-preview-canvas.admin-centered-canvas.compact-canvas.square-board{
  border-width:5px;
}
.admin-board-grid[data-count="3"] .team-preview-canvas.admin-centered-canvas.compact-canvas.square-board,
.admin-board-grid[data-count="4"] .team-preview-canvas.admin-centered-canvas.compact-canvas.square-board{
  border-width:4px;
  border-radius:16px;
}

@media (max-height:780px){
  .screen-boards[data-count="3"] .screen-board-card,
  .screen-boards[data-count="4"] .screen-board-card{max-width:min(100%, calc((100vh - 78px) / 2), 390px)}
  .admin-board-grid[data-count="3"] .admin-board-card,
  .admin-board-grid[data-count="4"] .admin-board-card{max-width:min(100%, calc((100vh - 214px) / 2), 300px)}
  .screen-board-title{padding:6px 10px;font-size:13px}
}
@media (max-width:1100px){
  .screen-boards{min-height:0}
  .screen-boards[data-count="2"],
  .screen-boards[data-count="3"],
  .screen-boards[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}
  .screen-boards[data-count="1"] .screen-board-card,
  .screen-boards[data-count="2"] .screen-board-card,
  .screen-boards[data-count="3"] .screen-board-card,
  .screen-boards[data-count="4"] .screen-board-card{max-width:100%}
  .admin-board-grid[data-count="2"],
  .admin-board-grid[data-count="3"],
  .admin-board-grid[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-board-grid[data-count="1"] .admin-board-card,
  .admin-board-grid[data-count="2"] .admin-board-card,
  .admin-board-grid[data-count="3"] .admin-board-card,
  .admin-board-grid[data-count="4"] .admin-board-card{max-width:min(100%,520px)}
}
@media (max-width:720px){
  .screen-boards[data-count="2"],
  .screen-boards[data-count="3"],
  .screen-boards[data-count="4"],
  .admin-board-grid[data-count="2"],
  .admin-board-grid[data-count="3"],
  .admin-board-grid[data-count="4"]{grid-template-columns:1fr}
  .team-correct-buttons{grid-template-columns:1fr}
  .screen-board-title{font-size:13px}
}

/* ================= Pictionary v2.5: pantalla compartida y admin sencillo ================ */
.hidden{display:none!important}
.phase-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:950;letter-spacing:.08em;background:#e5e7eb;color:#111827;margin-bottom:8px;text-transform:uppercase}
.phase-preview{background:#fef3c7;color:#92400e}.phase-drawing{background:#dcfce7;color:#166534}.phase-finished{background:#fee2e2;color:#991b1b}.phase-idle{background:#e5e7eb;color:#111827}
.shared-screen-layout .screen-boards[data-count="2"],.screen-boards[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.screen-boards[data-count="3"],.screen-boards[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.screen-board-card{min-width:0}.screen-board-title{text-align:center;justify-content:center;gap:10px}.screen-board-title span,.screen-board-title strong{display:block;text-align:center;white-space:normal;overflow-wrap:anywhere}.screen-team-canvas{aspect-ratio:1/1;width:100%;max-height:calc(100vh - 120px)}
.compact-screen-title .title{font-size:clamp(22px,3vw,38px)}
.simple-admin-wrap{max-width:1920px;padding:10px}.simple-admin-header{margin-bottom:8px}.simple-admin-grid{display:grid;grid-template-columns:minmax(260px,330px) minmax(480px,1fr) minmax(300px,390px);gap:10px;align-items:start}.simple-admin-side{min-width:0}.simple-admin-stage{display:flex;flex-direction:column;gap:10px;min-width:0}.simple-control-card{padding:12px}.simple-control-card .admin-timer{font-size:clamp(34px,5vw,78px);line-height:.95}.admin-secret-word{font-size:clamp(22px,3.2vw,48px);margin:6px 0 4px}.simple-main-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;margin-top:10px}.big-action{font-size:16px;font-weight:950;padding:12px 14px}.simple-admin-boards{display:grid;gap:10px}.simple-admin-boards[data-count="1"]{grid-template-columns:1fr}.simple-admin-boards[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}.simple-admin-boards[data-count="3"],.simple-admin-boards[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))}.simple-admin-boards .admin-main-canvas{width:100%;aspect-ratio:1/1;max-height:calc(100vh - 330px);min-height:260px}.admin-board-card{min-width:0}.word-history-list{display:flex;flex-direction:column;gap:8px;max-height:48vh;overflow:auto;padding-right:2px}.word-score-row{border:1px solid rgba(15,23,42,.12);border-radius:16px;padding:10px;background:rgba(255,255,255,.74);box-shadow:0 8px 18px rgba(15,23,42,.05)}.word-score-row.current{border-color:#f59e0b;background:#fffbeb}.word-score-main{display:flex;justify-content:space-between;gap:10px;align-items:baseline;margin-bottom:8px}.word-score-main strong{font-size:16px;line-height:1.1}.word-score-main span{font-size:11px;color:#64748b;font-weight:800;text-transform:uppercase}.word-score-buttons{display:grid;grid-template-columns:1fr;gap:6px}.word-team-score{display:grid;grid-template-columns:1fr auto auto;gap:6px;align-items:center;border-left:5px solid var(--team,#2563eb);padding-left:8px}.word-team-score b{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.word-team-score button{padding:6px 8px}.mobile-canvas.hidden{display:none!important}.draw-toolbox.hidden{display:none!important}.wordbox.hidden{display:none!important}#waitingBox.hidden{display:none!important}
@media (max-width:1100px){.simple-admin-grid{grid-template-columns:1fr}.simple-admin-boards .admin-main-canvas{max-height:none}.simple-main-actions{grid-template-columns:1fr}.word-history-list{max-height:none}.screen-layout{grid-template-columns:1fr}.side-panel{order:-1}.screen-boards[data-count="2"],.screen-boards[data-count="3"],.screen-boards[data-count="4"]{grid-template-columns:1fr}}
@media (orientation:landscape) and (max-height:700px){.simple-admin-wrap{padding:6px}.simple-admin-grid{gap:8px}.simple-admin-side .card{padding:8px}.simple-control-card .admin-timer{font-size:38px}.admin-secret-word{font-size:26px}.big-action{padding:8px 10px;font-size:14px}.word-history-list{max-height:42vh}}

/* ================= Pictionary v2.6: celular compacto + palabra por pulsación ================ */
.compact-player .phone-wrap{
  width:min(100vw - 12px,720px);
  height:100dvh;
  min-height:100vh;
  padding:6px 0 calc(52px + env(safe-area-inset-bottom));
  display:flex;
  flex-direction:column;
  gap:6px;
}
.phone-topbar{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:7px;
  min-height:34px;
}
.team-chip{
  --team:#2563eb;
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(2,6,23,.62);
  color:#e5e7eb;
  border-radius:999px;
  padding:5px 8px;
  max-width:122px;
  font-size:11px;
  font-weight:1000;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.team-chip span{width:10px;height:10px;flex:0 0 auto;border-radius:50%;background:var(--team);box-shadow:0 0 16px var(--team)}
.team-chip b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.phone-player-info{min-width:0;line-height:1.05;text-align:left}
.phone-player-info strong{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#f8fafc}
.phone-player-info small{display:block;font-size:10.5px;color:#94a3b8;font-weight:900;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.phone-gear{width:34px;height:34px;font-size:16px;border-radius:14px}
.compact-player-options{grid-template-columns:repeat(3,minmax(0,1fr));gap:5px;margin:0;padding:6px;border:1px solid var(--line);border-radius:14px;background:rgba(2,6,23,.72)}
.compact-player-options button{padding:8px 6px;border-radius:10px;font-size:11px;min-height:34px}
.phone-score-row{display:none!important}
.phone-waiting{padding:10px 12px;border-radius:16px;min-height:76px;display:grid;place-items:center;flex:1}
.phone-waiting .message{font-size:clamp(18px,5vw,28px);line-height:1.05}
.phone-drawing-board{
  width:min(100%, calc(100dvh - 138px), 680px);
  max-width:100%;
  max-height:calc(100dvh - 138px);
  min-height:0!important;
  height:auto!important;
  flex:0 1 auto;
  align-self:center;
  border-width:4px;
  border-radius:18px;
  box-shadow:0 14px 42px rgba(0,0,0,.36);
}
.phone-drawing-board .canvas-placeholder{font-size:clamp(22px,6vw,38px);opacity:.10}
.word-overlay{
  position:fixed;
  left:50%;
  top:44%;
  transform:translate(-50%,-50%);
  z-index:50;
  width:min(calc(100vw - 28px),560px);
  padding:18px 16px;
  border:2px solid rgba(250,204,21,.85);
  background:linear-gradient(180deg,rgba(30,41,59,.98),rgba(15,23,42,.98));
  box-shadow:0 28px 90px rgba(0,0,0,.68),0 0 38px rgba(250,204,21,.20);
  border-radius:22px;
}
.word-overlay .muted{font-size:12px;font-weight:1000;letter-spacing:.16em;color:#fef3c7;text-transform:uppercase}
.word-overlay .secret-word{font-size:clamp(32px,10vw,72px);line-height:.95;margin:8px 0;color:#fff;text-shadow:0 0 22px rgba(250,204,21,.28)}
.phone-status-card{padding:6px 8px;border-radius:14px;box-shadow:0 10px 26px rgba(0,0,0,.24)}
.phone-timer{font-size:clamp(24px,10vw,44px);letter-spacing:-.06em;line-height:.84}
.phone-message{font-size:clamp(12px,4vw,17px);line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}
.compact-draw-toolbox{
  left:8px!important;
  right:8px!important;
  bottom:max(6px, env(safe-area-inset-bottom))!important;
  max-width:720px;
  margin:0 auto!important;
  padding:5px!important;
  border-radius:14px!important;
  gap:5px!important;
  grid-template-columns:1fr 1fr!important;
}
.compact-draw-toolbox button{min-height:36px!important;font-size:12px!important;padding:7px 8px!important;border-radius:11px!important;box-shadow:0 8px 18px rgba(0,0,0,.22)}
@media (orientation:landscape) and (max-height:520px){
  .compact-player .phone-wrap{padding-bottom:46px;gap:4px}
  .phone-drawing-board{width:min(72vh,100%);max-height:calc(100dvh - 92px)}
  .phone-status-card{position:fixed;right:8px;top:48px;width:120px;z-index:12;background:rgba(2,6,23,.76)}
  .phone-timer{font-size:28px}.phone-message{font-size:11px;white-space:normal}
  .word-overlay{top:50%;width:min(70vw,520px)}
}
@media (max-width:420px){
  .phone-drawing-board{width:min(100%, calc(100dvh - 132px));}
  .team-chip{max-width:96px;padding:5px 7px;font-size:10px}.phone-player-info strong{font-size:12px}.phone-player-info small{font-size:9.5px}
}

.hold-word-btn{user-select:none;touch-action:none}
.hold-word-btn.is-holding{background:linear-gradient(135deg,#fde047,#fb923c)!important;color:#111827!important;box-shadow:0 0 0 3px rgba(250,204,21,.28),0 18px 38px rgba(251,146,60,.26)!important}
.simple-admin-page .simple-admin-wrap{width:min(100vw - 12px,1920px);padding:6px}
.simple-admin-page .simple-admin-header{margin-bottom:6px;min-height:34px}
.simple-admin-page .admin-logo{width:26px;height:26px;border-radius:9px}
.simple-admin-page .admin-title{font-size:clamp(18px,1.8vw,26px)}
.simple-admin-page .admin-subtitle{font-size:10px;margin-top:0}
.simple-admin-page .admin-top-actions{gap:5px}.simple-admin-page .admin-top-actions button{padding:6px 8px;font-size:11px;border-radius:10px}
.simple-admin-page .simple-admin-grid{grid-template-columns:minmax(220px,280px) minmax(430px,1fr) minmax(260px,340px);gap:8px}
.simple-admin-page .card{padding:9px;border-radius:16px}.simple-admin-page .card h2{font-size:15px;margin-bottom:7px}.simple-admin-page label{font-size:9px;margin-bottom:4px}.simple-admin-page input,.simple-admin-page select{padding:7px 8px;border-radius:10px;font-size:12px}
.simple-admin-page .simple-control-card{padding:8px}.simple-admin-page .phase-pill{padding:5px 9px;font-size:10px;margin-bottom:5px}.simple-admin-page .simple-control-card .admin-timer{font-size:clamp(28px,4.4vw,54px)}
.simple-admin-page .admin-secret-word{font-size:clamp(18px,2.6vw,34px);margin:4px 0}.simple-admin-page .admin-message{font-size:clamp(13px,1.6vw,18px)}
.simple-admin-page .players-summary{font-size:12px;color:#cbd5e1;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.simple-admin-page .simple-main-actions{gap:6px;margin-top:7px;grid-template-columns:repeat(2,minmax(0,1fr))}.simple-admin-page .big-action{padding:9px 10px;font-size:13px;border-radius:12px;min-height:40px}
.simple-admin-page .simple-admin-boards{gap:8px}.simple-admin-page .simple-admin-boards .admin-main-canvas{max-height:calc(100vh - 292px);min-height:210px;border-width:4px;border-radius:16px}.simple-admin-page .screen-board-title{font-size:12px;margin-bottom:5px}
.simple-admin-page .word-history-list{max-height:calc(100vh - 246px);gap:6px}.simple-admin-page .word-score-row{padding:7px;border-radius:12px}.simple-admin-page .word-score-main{margin-bottom:5px}.simple-admin-page .word-score-main strong{font-size:14px}.simple-admin-page .word-team-score{gap:4px}.simple-admin-page .word-team-score button{padding:5px 7px;font-size:11px}
.simple-admin-page .admin-score-card{padding:8px;border-radius:13px}.simple-admin-page .admin-team-score{font-size:30px}.simple-admin-page .team-name{font-size:12px}.simple-admin-page .players-scroll{max-height:calc(100vh - 455px);overflow:auto}
.admin-mobile-page .mobile-admin-wrap{width:min(100vw - 10px,620px);padding:6px 0;gap:7px}.admin-mobile-page .admin-header{margin-bottom:4px}.admin-mobile-page .admin-title{font-size:20px}.admin-mobile-page .subtitle{font-size:10px}.admin-mobile-page .card{padding:9px;border-radius:15px}.admin-mobile-page .phase-pill{padding:5px 9px;font-size:10px;margin-bottom:5px}.admin-mobile-page .timer{font-size:34px}.admin-mobile-page .secret-word{font-size:22px;margin:3px 0}.admin-mobile-page .message{font-size:15px}.admin-mobile-page .players-summary{font-size:12px}.admin-mobile-page .big-action{min-height:42px;font-size:14px;padding:9px 10px;border-radius:12px}.admin-mobile-page .form-row{gap:6px}.admin-mobile-page label{font-size:9px;margin-bottom:4px}.admin-mobile-page input,.admin-mobile-page select{padding:8px 9px;font-size:12px;border-radius:10px}.admin-mobile-page .word-history-list{max-height:none}.admin-mobile-page .word-score-row{padding:8px}.admin-mobile-page .admin-score-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.admin-mobile-page .admin-team-score{font-size:30px}
@media (max-width:1100px){.simple-admin-page .simple-admin-grid{grid-template-columns:1fr}.simple-admin-page .players-scroll{max-height:none}.simple-admin-page .simple-admin-boards .admin-main-canvas{max-height:none}.simple-admin-page .word-history-list{max-height:none}}

/* ================= Pictionary v2.7: iPhone SE, popup real y pantalla TV full ================ */
:root{--safe-bottom:env(safe-area-inset-bottom)}

/* Celular del jugador: el lienzo manda, todo lo demás se vuelve compacto o flotante */
.compact-player .phone-wrap{
  width:min(100vw - 8px,760px)!important;
  height:100dvh!important;
  min-height:100dvh!important;
  padding:4px 0 calc(44px + var(--safe-bottom))!important;
  gap:4px!important;
  overflow:hidden;
}
.phone-topbar{min-height:30px!important;gap:5px!important;padding:0 2px}
.team-chip{max-width:112px!important;padding:4px 7px!important;font-size:9.5px!important;letter-spacing:.035em!important}
.team-chip span{width:8px!important;height:8px!important}
.phone-player-info strong{font-size:11.5px!important}
.phone-player-info small{font-size:9px!important}
.phone-gear{width:30px!important;height:30px!important;border-radius:11px!important;font-size:14px!important}
.compact-player-options{position:fixed;right:6px;top:38px;width:min(280px,calc(100vw - 12px));z-index:60;grid-template-columns:1fr!important;background:rgba(2,6,23,.94)!important;box-shadow:0 18px 48px rgba(0,0,0,.42)}
.compact-player-options button{min-height:32px!important;font-size:11px!important;padding:7px 8px!important}
.phone-waiting{min-height:0!important;flex:1!important;margin:0!important;padding:8px!important}
.phone-waiting .message{font-size:clamp(16px,5vw,24px)!important}
.phone-drawing-board{
  width:min(calc(100vw - 8px), calc(100dvh - 88px), 760px)!important;
  height:auto!important;
  aspect-ratio:1/1!important;
  max-height:calc(100dvh - 88px)!important;
  min-height:0!important;
  align-self:center!important;
  flex:0 0 auto!important;
  border-width:3px!important;
  border-radius:14px!important;
  margin:0 auto!important;
}
.phone-drawing-board .canvas-placeholder{font-size:clamp(18px,6vw,32px)!important}
.phone-status-card{
  position:fixed!important;
  right:6px!important;
  top:39px!important;
  width:92px!important;
  z-index:20!important;
  padding:5px 6px!important;
  border-radius:11px!important;
  background:rgba(2,6,23,.70)!important;
  border:1px solid rgba(255,255,255,.13)!important;
  backdrop-filter:blur(8px)!important;
}
.phone-timer{font-size:24px!important;line-height:.86!important}
.phone-message{font-size:9.5px!important;white-space:normal!important;line-height:1.05!important;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.compact-draw-toolbox{
  position:fixed!important;
  display:grid!important;
  left:6px!important;
  right:6px!important;
  bottom:max(5px,var(--safe-bottom))!important;
  z-index:55!important;
  max-width:760px!important;
  grid-template-columns:1fr 1fr!important;
  background:rgba(2,6,23,.56)!important;
  border:1px solid rgba(255,255,255,.11)!important;
  backdrop-filter:blur(10px)!important;
}
.compact-draw-toolbox.hidden{display:none!important}
.compact-draw-toolbox button{min-height:32px!important;font-size:11px!important;padding:6px 7px!important;border-radius:10px!important}
.word-overlay{
  position:fixed!important;
  left:50%!important;
  top:48px!important;
  transform:translateX(-50%)!important;
  z-index:90!important;
  width:min(300px,calc(100vw - 18px))!important;
  padding:9px 12px!important;
  border-radius:16px!important;
  border:2px solid rgba(250,204,21,.90)!important;
  background:rgba(15,23,42,.96)!important;
  box-shadow:0 18px 52px rgba(0,0,0,.54),0 0 26px rgba(250,204,21,.22)!important;
  pointer-events:none!important;
}
.word-overlay .muted{font-size:9px!important;letter-spacing:.13em!important}
.word-overlay .secret-word{font-size:clamp(22px,8vw,38px)!important;line-height:.95!important;margin:4px 0!important;color:#fff!important}
.word-overlay #phaseHint{font-size:10px!important}

@media (max-width:390px){
  .compact-player .phone-wrap{width:min(100vw - 4px,760px)!important;padding-top:3px!important;padding-bottom:calc(40px + var(--safe-bottom))!important;gap:3px!important}
  .phone-topbar{min-height:28px!important}
  .team-chip{max-width:86px!important;font-size:8.5px!important;padding:3px 5px!important}
  .phone-player-info strong{font-size:10.5px!important}.phone-player-info small{font-size:8px!important}
  .phone-gear{width:28px!important;height:28px!important}
  .phone-drawing-board{width:min(calc(100vw - 4px), calc(100dvh - 80px), 760px)!important;max-height:calc(100dvh - 80px)!important;border-width:2px!important;border-radius:12px!important}
  .phone-status-card{top:34px!important;right:4px!important;width:82px!important;padding:4px!important}.phone-timer{font-size:21px!important}.phone-message{font-size:8.5px!important}
  .compact-draw-toolbox{left:4px!important;right:4px!important;padding:4px!important}.compact-draw-toolbox button{min-height:29px!important;font-size:10px!important;padding:5px!important}
  .word-overlay{top:40px!important;width:min(250px,calc(100vw - 12px))!important;padding:7px 10px!important}.word-overlay .secret-word{font-size:clamp(20px,8vw,32px)!important}
}
@media (orientation:landscape) and (max-height:520px){
  .compact-player .phone-wrap{padding-bottom:calc(38px + var(--safe-bottom))!important}
  .phone-drawing-board{width:min(calc(100dvh - 46px), calc(100vw - 132px), 520px)!important;max-height:calc(100dvh - 46px)!important}
  .phone-status-card{top:36px!important;width:86px!important}.phone-timer{font-size:20px!important}.phone-message{font-size:8.5px!important}
  .word-overlay{top:36px!important;width:min(260px,50vw)!important}
}

/* Pantalla TV: sin panel lateral, dibujo(s) en primer plano, marcador arriba */
body.tv-full-page{overflow:hidden;background:radial-gradient(circle at 20% 0,#1e293b 0,#070a12 48%,#020617 100%)}
.tv-full-layout{height:100dvh;width:100vw;padding:10px;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:8px;position:relative;overflow:hidden}
.tv-topbar{display:grid;grid-template-columns:minmax(170px,260px) minmax(210px,360px) minmax(360px,1fr);align-items:center;gap:10px;min-height:74px}
.tv-brand-block,.tv-status-block,.tv-score-block{min-width:0;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:9px 11px;box-shadow:0 12px 32px rgba(0,0,0,.24);backdrop-filter:blur(8px)}
.tv-title{margin:0;font-size:clamp(24px,3vw,42px);font-weight:1000;letter-spacing:-.05em;line-height:.92}.tv-subtitle{margin:3px 0 0;color:#94a3b8;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.tv-status-block{text-align:center;padding:7px 10px}.tv-status-block .phase-pill{margin-bottom:2px;padding:4px 9px;font-size:10px}.tv-timer{font-size:clamp(34px,4.8vw,70px)!important;line-height:.85!important}.tv-message{font-size:clamp(13px,1.35vw,22px)!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.tv-score-row{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:7px!important}.tv-score-row .team-card{padding:8px 7px 7px!important;border-radius:14px!important;text-align:center!important}.tv-score-row .team-card:before{height:5px!important}.tv-score-row .team-name{font-size:clamp(10px,.9vw,14px)!important;text-align:center!important;margin-top:2px!important}.tv-score-row .team-score{font-size:clamp(28px,3.4vw,54px)!important;text-align:center!important;margin-top:2px!important}
.tv-players-line{display:flex;justify-content:center;align-items:center;gap:12px;min-height:28px;overflow:hidden;white-space:nowrap;font-size:clamp(13px,1.35vw,20px);font-weight:950;color:#dbeafe;text-align:center}.tv-players-line span{display:inline-flex;align-items:center;gap:5px;border-left:6px solid var(--team);padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.06);max-width:48vw;overflow:hidden;text-overflow:ellipsis}.tv-players-line b{color:#fff}
.tv-boards{height:100%;min-height:0;display:grid!important;gap:10px!important;align-items:center!important;justify-items:center!important;overflow:hidden!important}.tv-boards[data-count="1"]{grid-template-columns:1fr!important}.tv-boards[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))!important}.tv-boards[data-count="3"],.tv-boards[data-count="4"]{grid-template-columns:repeat(2,minmax(0,1fr))!important}
.tv-board-card{height:100%;width:100%;min-width:0;min-height:0;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.10);border-radius:22px;padding:8px;box-shadow:0 16px 42px rgba(0,0,0,.28)}
.tv-board-title{flex:0 0 auto;width:100%;display:flex!important;justify-content:center!important;align-items:center!important;gap:8px!important;text-align:center!important;padding:6px 10px!important;margin-bottom:6px!important;border-radius:14px!important;background:linear-gradient(90deg,var(--team),rgba(15,23,42,.92))!important;font-size:clamp(13px,1.3vw,22px)!important}.tv-board-title span,.tv-board-title strong{display:block!important;text-align:center!important;white-space:normal!important;overflow-wrap:anywhere!important}.tv-board-title strong{color:#fff!important;opacity:.92!important}
.tv-canvas{width:auto!important;height:auto!important;aspect-ratio:1/1!important;max-width:100%!important;max-height:calc(100dvh - 146px)!important;min-height:0!important;border-width:5px!important;border-radius:18px!important;flex:0 1 auto!important}.tv-boards[data-count="1"] .tv-canvas{width:min(100%,calc(100dvh - 150px),1120px)!important}.tv-boards[data-count="2"] .tv-canvas{width:min(100%,calc(100dvh - 150px),900px)!important}.tv-boards[data-count="3"] .tv-canvas,.tv-boards[data-count="4"] .tv-canvas{width:min(100%,calc((100dvh - 166px)/2),520px)!important}
.tv-answer-pop{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:100;width:min(620px,calc(100vw - 48px));padding:24px 28px;border-radius:28px;border:3px solid rgba(250,204,21,.95);background:linear-gradient(180deg,rgba(15,23,42,.98),rgba(2,6,23,.98));box-shadow:0 34px 120px rgba(0,0,0,.72),0 0 52px rgba(250,204,21,.30);text-align:center;animation:answerPop .18s ease-out}.tv-answer-label{font-size:14px;font-weight:1000;letter-spacing:.18em;color:#fde68a;text-transform:uppercase}.tv-answer-word{font-size:clamp(42px,7vw,92px);font-weight:1000;line-height:.95;letter-spacing:-.06em;color:#fff;margin-top:8px;text-shadow:0 0 34px rgba(250,204,21,.24)}@keyframes answerPop{from{opacity:0;transform:translate(-50%,-50%) scale(.94)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.tv-sound-btn{position:fixed;right:10px;bottom:10px;z-index:30;padding:8px 10px!important;font-size:11px!important;border-radius:12px!important;opacity:.55}.tv-sound-btn:hover{opacity:1}
@media (max-width:1100px){.tv-full-layout{overflow:auto;height:auto;min-height:100dvh}.tv-topbar{grid-template-columns:1fr}.tv-score-row{grid-template-columns:repeat(2,minmax(0,1fr))!important}.tv-boards[data-count="2"],.tv-boards[data-count="3"],.tv-boards[data-count="4"]{grid-template-columns:1fr!important}.tv-canvas{width:min(100%,72vh,760px)!important;max-height:none!important}.tv-board-card{height:auto}.tv-players-line{flex-wrap:wrap;white-space:normal}}
@media (orientation:landscape) and (max-height:780px){.tv-full-layout{padding:6px;gap:5px}.tv-topbar{min-height:58px;grid-template-columns:minmax(140px,220px) minmax(180px,300px) minmax(330px,1fr);gap:6px}.tv-brand-block,.tv-status-block,.tv-score-block{padding:6px 8px;border-radius:14px}.tv-title{font-size:clamp(20px,2.5vw,32px)}.tv-subtitle{font-size:10px}.tv-status-block .phase-pill{font-size:9px;padding:3px 7px}.tv-timer{font-size:clamp(30px,4.4vw,56px)!important}.tv-message{font-size:clamp(11px,1.1vw,16px)!important}.tv-score-row{gap:5px!important}.tv-score-row .team-card{padding:6px 5px 5px!important}.tv-score-row .team-score{font-size:clamp(24px,3vw,42px)!important}.tv-players-line{min-height:22px;font-size:clamp(11px,1.2vw,16px)}.tv-board-card{padding:5px;border-radius:16px}.tv-board-title{font-size:clamp(11px,1.2vw,16px)!important;margin-bottom:4px!important;padding:5px 8px!important}.tv-boards{gap:6px!important}.tv-boards[data-count="1"] .tv-canvas{width:min(100%,calc(100dvh - 116px),980px)!important}.tv-boards[data-count="2"] .tv-canvas{width:min(100%,calc(100dvh - 116px),720px)!important}.tv-boards[data-count="3"] .tv-canvas,.tv-boards[data-count="4"] .tv-canvas{width:min(100%,calc((100dvh - 126px)/2),430px)!important}}

/* Admin todavía más compacto para correr el juego */
.simple-admin-page .simple-admin-wrap{padding:5px!important}.simple-admin-page .simple-admin-grid{grid-template-columns:minmax(205px,260px) minmax(420px,1fr) minmax(250px,320px)!important;gap:6px!important}.simple-admin-page .simple-control-card{padding:7px!important}.simple-admin-page .big-action{min-height:36px!important;font-size:12px!important;padding:8px 9px!important}.simple-admin-page .simple-control-card .admin-timer{font-size:clamp(26px,4vw,48px)!important}.simple-admin-page .admin-secret-word{font-size:clamp(16px,2.2vw,28px)!important}.simple-admin-page .admin-message{font-size:clamp(12px,1.3vw,16px)!important}.simple-admin-page .simple-admin-boards .admin-main-canvas{max-height:calc(100vh - 274px)!important}.admin-mobile-page .big-action{min-height:38px!important;font-size:13px!important}.admin-mobile-page .timer{font-size:30px!important}.admin-mobile-page .secret-word{font-size:19px!important}.admin-mobile-page .message{font-size:13px!important}
@media (max-width:1100px){.simple-admin-page .simple-admin-grid{grid-template-columns:1fr!important}}
/* Ajuste final v2.7 */
.tv-board-card{max-width:100%!important}
@media (orientation:landscape) and (max-height:520px){
  .phone-drawing-board{width:min(calc(100dvh - 90px), calc(100vw - 132px), 520px)!important;max-height:calc(100dvh - 90px)!important}
}

/* ================= Pictionary v2.8: palabra temporal y lienzo máximo en celular ================ */
.word-overlay{
  width:min(250px,calc(100vw - 14px))!important;
  top:34px!important;
  padding:6px 9px!important;
  border-radius:13px!important;
  z-index:120!important;
}
.word-overlay .muted{font-size:8px!important;letter-spacing:.11em!important;line-height:1!important}
.word-overlay .secret-word{font-size:clamp(18px,7vw,30px)!important;margin:3px 0 0!important;line-height:.96!important;overflow-wrap:anywhere!important}
.word-overlay #phaseHint{display:none!important}
.phone-status-card{top:33px!important;width:78px!important;padding:4px 5px!important}
.phone-timer{font-size:20px!important}
.phone-message{font-size:8px!important;line-height:1!important}
.phone-drawing-board{width:min(calc(100vw - 4px), calc(100dvh - 72px), 780px)!important;max-height:calc(100dvh - 72px)!important}
.compact-player .phone-wrap{padding-top:2px!important;padding-bottom:calc(36px + var(--safe-bottom))!important;gap:2px!important}
.compact-draw-toolbox{bottom:max(3px,var(--safe-bottom))!important;padding:3px!important}
.compact-draw-toolbox button{min-height:28px!important;font-size:10px!important;padding:4px 6px!important}
@media (max-width:390px){
  .word-overlay{top:31px!important;width:min(220px,calc(100vw - 10px))!important;padding:5px 8px!important}
  .word-overlay .secret-word{font-size:clamp(17px,7vw,27px)!important}
  .phone-drawing-board{width:min(calc(100vw - 2px), calc(100dvh - 64px), 760px)!important;max-height:calc(100dvh - 64px)!important}
  .phone-status-card{top:30px!important;right:3px!important;width:72px!important;padding:3px!important}
  .phone-timer{font-size:18px!important}.phone-message{font-size:7.5px!important}
  .compact-draw-toolbox button{min-height:26px!important;font-size:9.5px!important;padding:4px!important}
}
@media (orientation:landscape) and (max-height:520px){
  .word-overlay{top:28px!important;width:min(230px,46vw)!important}
  .phone-drawing-board{width:min(calc(100dvh - 38px), calc(100vw - 118px), 560px)!important;max-height:calc(100dvh - 38px)!important}
}

/* ================= Pictionary v2.9: score en celular/admin móvil + respuesta anterior en TV ================ */
.phone-score-row.phone-score-mini{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:3px!important;
  margin:0!important;
  width:100%;
  min-height:22px;
}
.phone-score-row.phone-score-mini[data-count="1"]{grid-template-columns:1fr}
.phone-score-row.phone-score-mini[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.phone-score-row.phone-score-mini[data-count="3"]{grid-template-columns:repeat(3,minmax(0,1fr))}
.phone-score-row.phone-score-mini[data-count="4"]{grid-template-columns:repeat(4,minmax(0,1fr))}
.phone-score-pill,
.mobile-score-pill{
  --team:#2563eb;
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:4px;
  padding:3px 5px;
  border-radius:8px;
  background:rgba(2,6,23,.72);
  border:1px solid rgba(255,255,255,.12);
  border-left:4px solid var(--team);
  color:#e5e7eb;
  box-shadow:0 6px 14px rgba(0,0,0,.18);
}
.phone-score-pill.active,
.mobile-score-pill.active{outline:1px solid var(--team);box-shadow:0 0 14px rgba(250,204,21,.12)}
.phone-score-pill span,
.mobile-score-pill span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:8.5px;
  font-weight:1000;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.phone-score-pill b,
.mobile-score-pill b{
  font-size:14px;
  line-height:1;
  font-weight:1000;
  color:#fff;
  flex:0 0 auto;
}
.mobile-score-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:4px;
  margin-top:6px;
}
.mobile-score-strip[data-count="1"]{grid-template-columns:1fr}
.mobile-score-strip[data-count="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}
.mobile-score-strip[data-count="3"]{grid-template-columns:repeat(3,minmax(0,1fr))}
.mobile-score-strip[data-count="4"]{grid-template-columns:repeat(4,minmax(0,1fr))}
.admin-mobile-score-strip .mobile-score-pill{
  background:rgba(15,23,42,.88);
  padding:5px 6px;
}
.admin-mobile-score-strip .mobile-score-pill span{font-size:9px}
.admin-mobile-score-strip .mobile-score-pill b{font-size:18px}
@media (max-width:390px){
  .phone-score-row.phone-score-mini{gap:2px!important;min-height:18px}
  .phone-score-pill{padding:2px 4px;border-radius:7px;border-left-width:3px}
  .phone-score-pill span{font-size:7.5px}
  .phone-score-pill b{font-size:12px}
  .admin-mobile-score-strip .mobile-score-pill{padding:4px 5px}
  .admin-mobile-score-strip .mobile-score-pill span{font-size:8px}
  .admin-mobile-score-strip .mobile-score-pill b{font-size:16px}
}
@media (orientation:landscape) and (max-height:520px){
  .phone-score-row.phone-score-mini{position:fixed;left:4px;top:33px;width:min(44vw,260px);z-index:11}
  .phone-score-pill span{font-size:7px}.phone-score-pill b{font-size:11px}
}


/* ================= Pictionary v3.1: puntaje arriba en admin móvil + score más visible en celulares ================ */
.admin-mobile-page .mobile-score-actions-panel{
  order:-1;
  padding:8px!important;
  border:2px solid rgba(250,204,21,.28);
  background:linear-gradient(180deg,rgba(255,251,235,.95),rgba(255,255,255,.88));
}
.admin-mobile-page .mobile-score-actions-panel h2{
  margin-bottom:5px!important;
  font-size:14px!important;
}
.admin-mobile-page .mobile-word-history-top{
  max-height:31dvh!important;
  overflow:auto!important;
  padding-right:2px;
  gap:5px!important;
}
.admin-mobile-page .mobile-word-history-top .word-score-row{
  padding:7px!important;
  border-radius:12px!important;
}
.admin-mobile-page .mobile-word-history-top .word-score-main{
  margin-bottom:5px!important;
}
.admin-mobile-page .mobile-word-history-top .word-score-main strong{
  font-size:14px!important;
}
.admin-mobile-page .mobile-word-history-top .word-score-main span{
  font-size:9px!important;
}
.admin-mobile-page .mobile-word-history-top .word-team-score{
  grid-template-columns:1fr auto auto!important;
  gap:4px!important;
  padding-left:6px!important;
  border-left-width:4px!important;
}
.admin-mobile-page .mobile-word-history-top .word-team-score b{
  font-size:11px!important;
}
.admin-mobile-page .mobile-word-history-top .word-team-score button{
  padding:7px 9px!important;
  font-size:12px!important;
  min-height:32px!important;
  border-radius:10px!important;
}
.admin-mobile-page .mobile-admin-wrap > .card.center{
  padding:7px!important;
}
.admin-mobile-page .mobile-admin-wrap > .card.center .secret-word{
  font-size:18px!important;
}
.admin-mobile-page .mobile-admin-wrap > .card.center .mobile-score-strip{
  margin-top:4px!important;
}

/* Scores de celulares de jugador: un poco más grandes, sin quitar demasiado lienzo */
.phone-score-row.phone-score-mini{
  min-height:26px!important;
  gap:4px!important;
}
.phone-score-pill{
  padding:4px 6px!important;
  border-radius:9px!important;
  border-left-width:5px!important;
}
.phone-score-pill span{
  font-size:9.5px!important;
}
.phone-score-pill b{
  font-size:18px!important;
}
@media (max-width:390px){
  .phone-score-row.phone-score-mini{min-height:22px!important;gap:3px!important}
  .phone-score-pill{padding:3px 5px!important;border-left-width:4px!important}
  .phone-score-pill span{font-size:8.2px!important}
  .phone-score-pill b{font-size:15px!important}
  .phone-drawing-board{width:min(calc(100vw - 4px), calc(100dvh - 76px), 780px)!important;max-height:calc(100dvh - 76px)!important}
}
@media (orientation:landscape) and (max-height:520px){
  .phone-score-row.phone-score-mini{width:min(50vw,290px)!important;min-height:22px!important}
  .phone-score-pill span{font-size:7.8px!important}
  .phone-score-pill b{font-size:14px!important}
}

.admin-mobile-page .mobile-score-panel-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:5px;
}
.admin-mobile-page .mobile-score-panel-title h2{margin:0!important}
.admin-mobile-page .mobile-score-panel-title button{
  flex:0 0 auto;
  min-height:32px!important;
  padding:7px 10px!important;
  font-size:12px!important;
  border-radius:10px!important;
}


/* ================= Pictionary v3.2: admin móvil con marcador simple arriba ================ */
.admin-mobile-page .mobile-main-score-panel{
  order:-2;
  padding:8px!important;
  border:2px solid rgba(250,204,21,.32);
  background:linear-gradient(180deg,rgba(255,251,235,.96),rgba(255,255,255,.9));
}
.admin-mobile-page .mobile-main-score-panel h2{
  margin:0!important;
  font-size:16px!important;
}
.admin-mobile-page .mobile-main-score-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
  margin-top:7px!important;
}
.admin-mobile-page .mobile-main-score-row .admin-score-card{
  min-height:104px!important;
  padding:9px 8px 8px!important;
  border-radius:18px!important;
  display:grid!important;
  grid-template-columns:auto 1fr!important;
  grid-template-areas:"buttons name" "score score"!important;
  align-items:start!important;
  gap:4px 8px!important;
  overflow:hidden!important;
}
.admin-mobile-page .mobile-main-score-row .admin-score-card:before{height:5px!important}
.admin-mobile-page .mobile-main-score-row .team-name{
  grid-area:name!important;
  align-self:center!important;
  justify-self:end!important;
  max-width:100%!important;
  text-align:right!important;
  font-size:11px!important;
  line-height:1!important;
  margin:0!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.admin-mobile-page .mobile-main-score-row .admin-team-score{
  grid-area:score!important;
  font-size:48px!important;
  line-height:.9!important;
  margin:2px 0 0!important;
  text-align:left!important;
  letter-spacing:-.06em!important;
}
.admin-mobile-page .mobile-main-score-row .score-mini-buttons{
  grid-area:buttons!important;
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:5px!important;
  min-width:86px!important;
  max-width:100%!important;
}
.admin-mobile-page .mobile-main-score-row .score-mini-buttons button{
  min-width:40px!important;
  min-height:38px!important;
  padding:0!important;
  font-size:18px!important;
  font-weight:1000!important;
  border-radius:12px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.admin-mobile-page .mobile-results-collapsed{
  order:20!important;
  padding:8px!important;
  border:1px solid rgba(148,163,184,.25)!important;
  background:rgba(255,255,255,.82)!important;
}
.admin-mobile-page .mobile-results-collapsed summary{
  cursor:pointer;
  font-weight:1000;
  font-size:13px;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.admin-mobile-page .mobile-results-collapsed summary::-webkit-details-marker{display:none}
.admin-mobile-page .mobile-results-collapsed summary:after{content:'Ver';font-size:11px;color:#64748b}
.admin-mobile-page .mobile-results-collapsed[open] summary:after{content:'Ocultar'}
.admin-mobile-page .mobile-score-actions-panel.mobile-results-collapsed .mobile-word-history-top{
  max-height:38dvh!important;
  margin-top:8px!important;
}
.admin-mobile-page .mobile-status-card{
  order:-1;
}
.admin-mobile-page .mobile-status-card .admin-mobile-score-strip{
  display:none!important;
}
@media (max-width:390px){
  .admin-mobile-page .mobile-main-score-row{gap:6px!important}
  .admin-mobile-page .mobile-main-score-row .admin-score-card{min-height:96px!important;padding:8px 7px!important;gap:3px 6px!important}
  .admin-mobile-page .mobile-main-score-row .score-mini-buttons{min-width:78px!important;gap:4px!important}
  .admin-mobile-page .mobile-main-score-row .score-mini-buttons button{min-width:36px!important;min-height:35px!important;font-size:16px!important;border-radius:11px!important}
  .admin-mobile-page .mobile-main-score-row .admin-team-score{font-size:44px!important}
  .admin-mobile-page .mobile-main-score-row .team-name{font-size:10px!important}
}

/* Scores en celulares de participantes un poco más grandes, sin robar demasiado lienzo */
.phone-score-pill b{font-size:20px!important}
.phone-score-pill span{font-size:10px!important}
.phone-score-pill{padding:4px 7px!important}
@media (max-width:390px){
  .phone-score-pill b{font-size:17px!important}
  .phone-score-pill span{font-size:8.7px!important}
  .phone-score-pill{padding:3px 5px!important}
}

/* ================= Pictionary v3.3: Reset completo visible arriba en admin móvil ================ */
.admin-mobile-page .mobile-score-panel-title-reset{
  align-items:flex-start!important;
  gap:8px!important;
}
.admin-mobile-page .mobile-top-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:6px!important;
  width:min(100%, 245px)!important;
}
.admin-mobile-page .mobile-top-actions button{
  width:100%!important;
  min-height:34px!important;
  padding:7px 8px!important;
  font-size:11px!important;
  line-height:1.05!important;
}
.admin-mobile-page #resetAllBtn{
  background:linear-gradient(180deg,#ef4444,#b91c1c)!important;
  border-color:rgba(239,68,68,.55)!important;
  color:#fff!important;
}
.admin-mobile-page .mobile-reset-panel{
  order:22!important;
}
@media (max-width:390px){
  .admin-mobile-page .mobile-score-panel-title-reset{
    flex-direction:column!important;
    align-items:stretch!important;
  }
  .admin-mobile-page .mobile-top-actions{
    width:100%!important;
  }
}


/* v3.4 reset completo visible y táctil */
.admin-mobile-page .mobile-score-panel-title-reset{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.admin-mobile-page .mobile-score-top-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.admin-mobile-page #resetAllBtn{min-height:38px;font-weight:900;box-shadow:0 0 0 1px rgba(255,255,255,.12) inset}
.admin-mobile-page #resetHardLink{margin-top:8px;text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
@media (max-width:420px){.admin-mobile-page .mobile-score-panel-title-reset h2{font-size:1rem}.admin-mobile-page .mobile-score-top-actions .small{font-size:.72rem;padding:8px 9px}}


/* v3.5 Reset completo visible y admin con scroll real */
body.admin-page.simple-admin-page{overflow:auto!important;}
.simple-admin-header{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,rgba(2,6,23,.96),rgba(2,6,23,.78));backdrop-filter:blur(10px);border-radius:18px;padding:6px 8px;}
.reset-direct-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:12px;border:1px solid rgba(239,68,68,.45);background:rgba(239,68,68,.16);color:#fee2e2!important;font-weight:1000;padding:8px 10px;font-size:12px;line-height:1;box-shadow:0 8px 18px rgba(0,0,0,.18);}
.admin-top-actions .reset-direct-link{flex:0 0 auto;white-space:nowrap;}
.mobile-top-actions .reset-direct-link{min-height:34px;padding:9px 10px;}
@media (max-width:720px){.admin-top-actions .reset-direct-link{grid-column:1/-1}.mobile-top-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.mobile-reset-direct{grid-column:1/-1}}
