:root{--bg:#0b1020;--panel:#121a2f;--text:#f8fafc;--muted:#94a3b8;--line:rgba(255,255,255,.12);--accent:#22c55e;--accent2:#38bdf8;--warn:#facc15;--danger:#fb7185;--shadow:0 22px 60px rgba(0,0,0,.35)}
*{box-sizing:border-box}
body{margin:0;min-height:100vh;font-family:Arial,Helvetica,sans-serif;background:radial-gradient(circle at top left,#17325d,var(--bg) 45%);color:var(--text)}
.shell{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:32px 0}.home-shell{display:grid;gap:22px}
.hero-card,.panel,.topbar{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}
.hero-card{padding:36px}.brand{color:var(--accent);font-weight:800;letter-spacing:.08em;text-transform:uppercase}
h1{margin:10px 0 12px;font-size:clamp(2rem,5vw,4rem);line-height:1}h2{margin:0 0 16px}p{color:var(--muted);line-height:1.6}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}.panel{padding:24px}.panel.compact{padding:18px}
label{display:block;margin:14px 0 8px;color:var(--muted);font-size:.94rem}
input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);outline:none}
button,.link-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;padding:13px 18px;margin-top:18px;background:var(--accent);color:#052e16;font-weight:800;cursor:pointer;text-decoration:none}
button:disabled{opacity:.55;cursor:not-allowed}.link-btn{background:rgba(255,255,255,.08);color:var(--text);border:1px solid var(--line);margin-top:0}
.form-message{min-height:22px;margin-top:12px;color:var(--warn)}.muted{color:var(--muted)}.hidden{display:none!important}
.topbar{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.players-list{display:grid;gap:12px;margin-top:18px}.player-row,.score-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.04)}
.badge{padding:6px 10px;border-radius:999px;background:rgba(56,189,248,.16);color:#bae6fd;font-size:.82rem}
.game-layout{width:min(1500px,calc(100% - 24px));margin:0 auto;padding:20px 0;display:grid;grid-template-columns:1fr 330px;grid-template-rows:auto 1fr;gap:18px}
.game-topbar{grid-column:1/-1;margin-bottom:0}.board-wrap{position:relative}.board{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:24px;padding:16px;min-height:680px}
.cell{position:relative;min-height:110px;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(160deg,rgba(56,189,248,.08),rgba(34,197,94,.05));overflow:hidden}
.cell-number{position:absolute;top:8px;left:10px;color:var(--muted);font-size:.85rem}.cell.meta{background:linear-gradient(160deg,rgba(34,197,94,.25),rgba(250,204,21,.12))}
.pawns{position:absolute;left:8px;right:8px;bottom:8px;display:flex;flex-wrap:wrap;gap:6px}
.pawn{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:800;background:var(--accent2);color:#082f49;border:2px solid rgba(255,255,255,.7)}
.pawn.p2{background:var(--accent);color:#052e16}.pawn.p3{background:var(--warn);color:#422006}.pawn.p4{background:var(--danger);color:#4c0519}
.side-panel{display:grid;gap:18px;align-content:start}.dice{width:92px;height:92px;border-radius:22px;background:#f8fafc;color:#0f172a;display:grid;place-items:center;font-size:3rem;font-weight:900;margin:6px auto 0}
.events-log{display:grid;gap:10px;max-height:220px;overflow:auto;color:var(--muted);font-size:.92rem}.event-item{border-bottom:1px solid var(--line);padding-bottom:8px}
.modal{position:absolute;inset:0;background:rgba(2,6,23,.58);display:grid;place-items:center;padding:18px;z-index:10;border-radius:24px}
.modal-card{width:min(720px,100%);background:var(--panel);border:1px solid var(--line);border-radius:26px;padding:24px;box-shadow:var(--shadow)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.timer{color:var(--warn);font-weight:800}.answer-options{display:grid;gap:12px;margin-top:18px}
.answer-options button{margin:0;width:100%;justify-content:flex-start;background:rgba(255,255,255,.08);color:var(--text);border:1px solid var(--line)}
@media(max-width:1000px){.game-layout{grid-template-columns:1fr}.board{grid-template-columns:repeat(5,1fr);min-height:auto}.cell{min-height:90px}}
@media(max-width:720px){.grid-2{grid-template-columns:1fr}.hero-card{padding:24px}.topbar{flex-wrap:wrap}.board{grid-template-columns:repeat(3,1fr);gap:8px;padding:10px}.cell{min-height:86px;border-radius:14px}}

/* Ruleta 1-6 para reemplazar el dado */
.roulette-panel{text-align:center}
.roulette-wrap{position:relative;width:156px;height:156px;margin:8px auto 0}
.roulette-pointer{position:absolute;left:50%;top:-4px;transform:translateX(-50%);width:0;height:0;border-left:13px solid transparent;border-right:13px solid transparent;border-top:24px solid var(--warn);z-index:2;filter:drop-shadow(0 4px 8px rgba(0,0,0,.35))}
.roulette{position:relative;width:156px;height:156px;border-radius:50%;border:8px solid rgba(255,255,255,.82);background:conic-gradient(from -30deg,#38bdf8 0deg 60deg,#22c55e 60deg 120deg,#facc15 120deg 180deg,#fb7185 180deg 240deg,#a78bfa 240deg 300deg,#f97316 300deg 360deg);box-shadow:inset 0 0 0 2px rgba(15,23,42,.55),0 18px 35px rgba(0,0,0,.35);transition:transform 3.8s cubic-bezier(.12,.72,.08,1)}
.roulette:after{content:'';position:absolute;inset:47px;border-radius:50%;background:#f8fafc;box-shadow:inset 0 0 0 2px rgba(15,23,42,.2)}
.roulette.spinning{filter:brightness(1.08)}
.roulette-num{position:absolute;left:50%;top:50%;z-index:1;font-size:1.22rem;font-weight:900;color:#0f172a;text-shadow:0 1px 1px rgba(255,255,255,.55)}
.roulette-num.n1{transform:translate(-50%,-50%) rotate(0deg) translateY(-56px) rotate(0deg)}
.roulette-num.n2{transform:translate(-50%,-50%) rotate(60deg) translateY(-56px) rotate(-60deg)}
.roulette-num.n3{transform:translate(-50%,-50%) rotate(120deg) translateY(-56px) rotate(-120deg)}
.roulette-num.n4{transform:translate(-50%,-50%) rotate(180deg) translateY(-56px) rotate(-180deg)}
.roulette-num.n5{transform:translate(-50%,-50%) rotate(240deg) translateY(-56px) rotate(-240deg)}
.roulette-num.n6{transform:translate(-50%,-50%) rotate(300deg) translateY(-56px) rotate(-300deg)}
.roulette-result{width:64px;height:64px;border-radius:18px;background:#f8fafc;color:#0f172a;display:grid;place-items:center;font-size:2rem;font-weight:900;margin:12px auto 0}

/* Animación de avance de ficha casilla por casilla */
.pawn.pawn-jump{animation:pawnHop .28s ease-in-out both;box-shadow:0 10px 22px rgba(0,0,0,.35),0 0 0 4px rgba(255,255,255,.16)}
@keyframes pawnHop{0%{transform:translateY(0) scale(1)}45%{transform:translateY(-18px) scale(1.12)}100%{transform:translateY(0) scale(1)}}
.cell:has(.pawn-jump){outline:2px solid rgba(250,204,21,.75);outline-offset:-3px}

/* Casillas por categoría persistente de sala */
.category-cell{--cell-color:#64748b;background:var(--cell-color)!important;border-color:transparent}
.category-cell:before{display:none}
.cell-category-icon{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:0;display:grid;place-items:center;background:transparent;border:0;color:#fff;font-size:1.8rem;z-index:1;box-shadow:none;text-shadow:0 2px 7px rgba(0,0,0,.38)}
.cell-category-name{position:absolute;left:8px;right:8px;bottom:42px;text-align:center;color:rgba(255,255,255,.88);font-size:.74rem;font-weight:800;line-height:1.1;z-index:1;text-shadow:0 2px 6px rgba(0,0,0,.45)}
.category-cell .cell-number,.category-cell .pawns{z-index:2}.category-cell.meta{box-shadow:inset 0 0 0 2px rgba(250,204,21,.55)}
@supports not (background:color-mix(in srgb,#000 50%,transparent)){.category-cell{background:var(--cell-color)!important;border-color:transparent}}


.board-question-modal{align-items:center;justify-items:center;backdrop-filter:blur(2px)}
.board-question-modal .modal-card{width:min(60%,760px);max-width:760px;min-width:420px;text-align:center}
.board-question-modal #questionText{text-align:center;margin:18px auto 20px;line-height:1.25}
.board-question-modal .modal-head{justify-content:center;gap:18px}
.board-question-modal .answer-options{justify-items:center}
.board-question-modal .answer-options button{justify-content:center;text-align:center;max-width:620px}

/* Animaciones v6: resultado de ruleta, zoom de pregunta y feedback */
.roulette-result-pop{animation:rouletteResultPop .72s cubic-bezier(.16,1,.3,1) both;box-shadow:0 0 0 8px rgba(250,204,21,.18),0 16px 32px rgba(0,0,0,.34)}
@keyframes rouletteResultPop{0%{transform:scale(.25) rotate(-12deg);opacity:.25}55%{transform:scale(1.28) rotate(5deg);opacity:1}100%{transform:scale(1) rotate(0);opacity:1}}
.modal-card{max-height:90vh;overflow:auto;transform-origin:center}
.modal.modal-zoom-in .modal-card{animation:questionZoomIn .68s cubic-bezier(.16,1,.3,1) both}
@keyframes questionZoomIn{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.feedback-modal{position:fixed;inset:0;z-index:30;display:grid;place-items:center;pointer-events:none;background:rgba(2,6,23,.18)}
.feedback-card{width:min(60vw,620px);min-height:170px;border-radius:34px;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;text-align:center;box-shadow:0 30px 90px rgba(0,0,0,.45);transform-origin:center;padding:28px;background:var(--panel)}
.feedback-text{font-size:clamp(2.3rem,7vw,5.4rem);font-weight:950;letter-spacing:.02em;text-shadow:0 4px 20px rgba(0,0,0,.28)}
.feedback-ok{background:linear-gradient(160deg,rgba(34,197,94,.95),rgba(21,128,61,.92));color:#ecfdf5}
.feedback-bad{background:linear-gradient(160deg,rgba(251,113,133,.95),rgba(190,18,60,.92));color:#fff1f2}
.feedback-none{background:linear-gradient(160deg,rgba(250,204,21,.96),rgba(217,119,6,.92));color:#422006}
.feedback-show .feedback-card{animation:feedbackZoomIn .72s cubic-bezier(.16,1,.3,1) both}
.feedback-hide .feedback-card{animation:feedbackZoomOut .62s ease-in both}
@keyframes feedbackZoomIn{0%{transform:scale(0);opacity:0}65%{transform:scale(1.08);opacity:1}100%{transform:scale(1);opacity:1}}
@keyframes feedbackZoomOut{0%{transform:scale(1);opacity:1}100%{transform:scale(0);opacity:0}}
@media(max-width:720px){.board-question-modal .modal-card{width:92%;min-width:0}.feedback-card{width:92vw;min-height:140px}}

/* Ajuste v8: salida en blanco, jugador en turno y retiro de eventos */
.start-cell{background:#f8fafc!important;color:#0f172a;border-color:rgba(255,255,255,.82)}
.start-cell .cell-number{color:#334155;font-weight:900}
.start-cell .cell-category-name{color:#334155;font-weight:900}
.start-cell-icon{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:0;display:grid;place-items:center;background:transparent;border:0;color:#0f172a;font-size:1.8rem;z-index:1;box-shadow:none}
.score-row.current-turn{border-color:rgba(250,204,21,.85);background:linear-gradient(135deg,rgba(250,204,21,.18),rgba(255,255,255,.04));box-shadow:0 0 0 1px rgba(250,204,21,.28),0 12px 28px rgba(0,0,0,.22)}
.score-player-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.turn-badge,.winner-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:.72rem;font-weight:900;letter-spacing:.04em}
.turn-badge{background:rgba(250,204,21,.22);color:#fde68a;border:1px solid rgba(250,204,21,.45)}
.winner-badge{background:rgba(34,197,94,.22);color:#bbf7d0;border:1px solid rgba(34,197,94,.45)}
.pawn.pawn-turn{outline:3px solid rgba(250,204,21,.9);box-shadow:0 0 0 5px rgba(250,204,21,.18),0 12px 28px rgba(0,0,0,.35)}

/* Ajuste v8: salida en blanco, jugador en turno y retiro de eventos */
.start-cell{background:#f8fafc!important;color:#0f172a;border-color:rgba(255,255,255,.82)}
.start-cell .cell-number{color:#334155;font-weight:900}
.start-cell .cell-category-name{color:#334155;font-weight:900}
.start-cell-icon{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:0;display:grid;place-items:center;background:transparent;border:0;color:#0f172a;font-size:1.8rem;z-index:1;box-shadow:none}
.score-row.current-turn{border-color:rgba(250,204,21,.85);background:linear-gradient(135deg,rgba(250,204,21,.18),rgba(255,255,255,.04));box-shadow:0 0 0 1px rgba(250,204,21,.28),0 12px 28px rgba(0,0,0,.22)}
.score-player-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.turn-badge,.winner-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:.72rem;font-weight:900;letter-spacing:.04em}
.turn-badge{background:rgba(250,204,21,.22);color:#fde68a;border:1px solid rgba(250,204,21,.45)}
.winner-badge{background:rgba(34,197,94,.22);color:#bbf7d0;border:1px solid rgba(34,197,94,.45)}
.pawn.pawn-turn{outline:3px solid rgba(250,204,21,.9);box-shadow:0 0 0 5px rgba(250,204,21,.18),0 12px 28px rgba(0,0,0,.35)}


/* Ajuste v11: números negros, categoría debajo del ícono, ruleta alineada y ganador global */
.category-cell .cell-number{color:#000!important;font-weight:900;text-shadow:none;background:rgba(255,255,255,.32);padding:2px 6px;border-radius:999px}
.category-cell .cell-category-icon{top:41%;font-size:1.85rem;text-shadow:0 2px 7px rgba(0,0,0,.28)}
.category-cell .cell-category-name{top:61%;bottom:auto;color:#fff;font-size:.72rem;font-weight:900;text-shadow:0 2px 6px rgba(0,0,0,.38)}
.start-cell .start-cell-icon{top:41%}.start-cell .cell-category-name{top:61%;bottom:auto;color:#334155!important;text-shadow:none}
.roulette-num{display:grid;place-items:center;width:28px;height:28px;line-height:1;text-align:center}
.winner-modal{position:fixed;inset:0;z-index:40;display:grid;place-items:center;pointer-events:none;background:rgba(2,6,23,.24)}
.winner-card{width:min(60vw,660px);min-height:190px;border-radius:34px;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;text-align:center;box-shadow:0 30px 90px rgba(0,0,0,.48);transform-origin:center;padding:30px;background:linear-gradient(160deg,rgba(250,204,21,.98),rgba(245,158,11,.94));color:#422006}
.winner-title{font-size:clamp(2.1rem,6vw,5rem);font-weight:950;letter-spacing:.02em;text-shadow:0 4px 18px rgba(255,255,255,.22)}
.winner-player-name{margin-top:10px;font-size:clamp(1.6rem,4vw,3.4rem);font-weight:950;color:#111827;text-shadow:0 2px 12px rgba(255,255,255,.26)}
.winner-show .winner-card{animation:feedbackZoomIn .72s cubic-bezier(.16,1,.3,1) both}
.winner-hide .winner-card{animation:feedbackZoomOut .62s ease-in both}
@media(max-width:720px){.winner-card{width:92vw;min-height:150px}.category-cell .cell-category-icon{top:39%;font-size:1.45rem}.category-cell .cell-category-name{top:58%;font-size:.62rem}}

/* Ajuste v12: tablero tipo recorrido con salida gris, meta verde y 50 espacios */
.game-layout{width:min(1760px,calc(100% - 24px));grid-template-columns:minmax(980px,1fr) 330px}
.board.board-path{display:block;min-height:720px;padding:0;background:transparent;border:0;overflow:visible}
.board-arena{position:relative;min-height:720px;border-radius:50%;background:#dbeafe;border:2px solid rgba(15,23,42,.95);box-shadow:inset 0 0 0 34px rgba(191,219,254,.95),0 24px 70px rgba(0,0,0,.35);padding:178px 78px 170px;overflow:hidden}
.track-row{position:relative;z-index:4;display:flex;align-items:stretch;gap:2px;width:100%;max-width:1120px;margin:0 auto}
.track-row-top{justify-content:flex-end;margin-top:34px}
.track-row-bottom{justify-content:flex-start;margin-top:18px}
.path-cell{position:relative;flex:1 1 0;min-width:0;height:72px;border-radius:0;border:1px solid rgba(15,23,42,.62);overflow:hidden;background:var(--cell-color,#64748b)!important;box-shadow:none}
.path-cell.start-cell{flex:0 0 54px;background:#b8b8b8!important;color:#0f172a;border-color:#334155}
.path-cell.finish-cell{background:#35ff00!important;border-color:#14532d;box-shadow:inset 0 0 0 2px rgba(255,255,255,.3)}
.path-cell .cell-number{position:absolute;top:3px;left:4px;color:#000!important;background:transparent!important;padding:0;border-radius:0;font-size:.62rem;font-weight:950;text-shadow:none;z-index:4}
.path-cell .cell-category-icon{position:absolute;left:50%;top:35%;transform:translate(-50%,-50%);font-size:1rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.42);width:auto;height:auto;z-index:2}
.path-cell .cell-category-name{position:absolute;left:2px;right:2px;top:54%;bottom:auto;color:#fff;font-size:.44rem;font-weight:900;line-height:1.02;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.5);z-index:2;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.path-cell .start-cell-icon{position:absolute;left:50%;top:35%;transform:translate(-50%,-50%);font-size:1rem;color:#111827;width:auto;height:auto;z-index:2}
.path-cell.start-cell .cell-category-name{top:54%;color:#111827!important;font-size:.48rem;text-shadow:none}
.path-cell .pawns{left:2px;right:2px;bottom:2px;gap:1px;justify-content:center;z-index:8}
.path-cell .pawn{width:17px;height:17px;font-size:.48rem;border-width:1px}
.board-center-info{position:absolute;z-index:2;left:50%;top:50%;transform:translate(-50%,-50%);width:min(440px,44%);display:grid;justify-items:center;gap:16px;pointer-events:none}
.room-pill{background:#f59e0b;color:#111827;border:1px solid #111827;border-radius:8px;padding:9px 22px;font-weight:900;box-shadow:0 4px 10px rgba(0,0,0,.18)}
.board-player-chips{display:grid;grid-template-columns:repeat(2,minmax(110px,1fr));gap:9px 12px;width:100%}
.board-player-chip{display:grid;place-items:center;min-height:34px;border-radius:7px;border:1px solid #111827;color:#111827;font-weight:900;padding:6px 10px;box-shadow:0 3px 8px rgba(0,0,0,.14)}
.board-player-chip.p1{background:#e879f9}.board-player-chip.p2{background:#fef08a}.board-player-chip.p3{background:#67e8f9}.board-player-chip.p4{background:#ff2d2d;color:#fff}.board-player-chip.active{outline:3px solid #facc15;outline-offset:2px}
.outer-arrow{position:absolute;z-index:1;color:#ff2600;font-size:5.2rem;font-weight:950;line-height:1;text-shadow:0 1px 0 rgba(255,255,255,.35)}
.arrow-top{top:54px;left:27%;transform:rotate(190deg)}
.arrow-right{right:42px;top:35%;transform:rotate(92deg)}
.arrow-bottom{bottom:44px;left:44%;transform:rotate(185deg)}
.arrow-left{left:40px;top:48%;transform:rotate(-88deg)}
.board-question-modal{inset:0;z-index:20}.board-question-modal .modal-card{width:min(60%,760px)}
@media(max-width:1280px){.game-layout{grid-template-columns:1fr}.board-arena{min-height:640px;padding:150px 46px}.track-row{max-width:980px}.path-cell{height:64px}.path-cell .cell-category-name{font-size:.4rem}.board-center-info{width:min(420px,54%)}}
@media(max-width:820px){.board.board-path{min-height:700px}.board-arena{border-radius:30px;box-shadow:inset 0 0 0 18px rgba(191,219,254,.95);padding:116px 14px 130px;min-height:700px}.track-row{gap:1px}.path-cell{height:58px}.path-cell.start-cell{flex-basis:42px}.path-cell .cell-category-icon,.path-cell .start-cell-icon{font-size:.78rem}.path-cell .cell-category-name{font-size:.32rem}.path-cell .cell-number{font-size:.5rem}.path-cell .pawn{width:14px;height:14px;font-size:.38rem}.board-player-chips{grid-template-columns:1fr 1fr}.board-center-info{width:72%;gap:10px}.outer-arrow{font-size:3.2rem}.arrow-top{top:52px}.arrow-bottom{bottom:50px}.arrow-right{right:16px}.arrow-left{left:16px}}

/* Ajuste v13: tablero circular completo con todo el perímetro lleno de casillas */
.board.board-ring{display:block;min-height:820px;padding:0;background:transparent;border:0;overflow:visible}
.ring-arena{position:relative;min-height:820px;border-radius:50%;background:#dbeafe;border:2px solid rgba(15,23,42,.95);box-shadow:inset 0 0 0 54px rgba(191,219,254,.96),0 24px 70px rgba(0,0,0,.35);padding:0;overflow:hidden}
.ring-cell{position:absolute;left:50%;top:50%;width:58px;height:58px;min-width:0;flex:none;border-radius:10px;border:1px solid rgba(15,23,42,.7);background:var(--cell-color,#64748b)!important;box-shadow:none;overflow:hidden;transform:rotate(var(--angle)) translateX(min(43vw,370px)) rotate(calc(-1 * var(--angle))) translate(-50%,-50%);transform-origin:0 0}
.ring-cell.start-cell{width:66px;height:58px;background:#b8b8b8!important;color:#0f172a;border-color:#334155}
.ring-cell.finish-cell{background:#35ff00!important;border-color:#14532d;box-shadow:inset 0 0 0 2px rgba(255,255,255,.3)}
.ring-cell .cell-number{position:absolute;top:3px;left:4px;color:#000!important;background:transparent!important;padding:0;border-radius:0;font-size:.55rem;font-weight:950;text-shadow:none;z-index:4}
.ring-cell .cell-category-icon,.ring-cell .start-cell-icon{position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);font-size:.9rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.42);width:auto;height:auto;z-index:2}
.ring-cell .start-cell-icon{color:#111827;text-shadow:none}
.ring-cell .cell-category-name{position:absolute;left:2px;right:2px;top:53%;bottom:auto;color:#fff;font-size:.34rem;font-weight:900;line-height:1.02;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.5);z-index:2;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ring-cell.start-cell .cell-category-name{color:#111827!important;text-shadow:none;font-size:.42rem}
.ring-cell .pawns{left:2px;right:2px;bottom:2px;gap:1px;justify-content:center;z-index:8}
.ring-cell .pawn{width:16px;height:16px;font-size:.44rem;border-width:1px}
.ring-arena .track-row,.ring-arena .outer-arrow{display:none!important}
.ring-direction{position:absolute;z-index:1;color:#ff2600;font-size:3.8rem;font-weight:950;line-height:1;text-shadow:0 1px 0 rgba(255,255,255,.35);pointer-events:none}
.ring-direction.arrow-a{top:48px;left:32%;transform:rotate(15deg)}
.ring-direction.arrow-b{right:42px;top:36%;transform:rotate(82deg)}
.ring-direction.arrow-c{bottom:44px;left:45%;transform:rotate(188deg)}
.ring-direction.arrow-d{left:40px;top:48%;transform:rotate(265deg)}
.ring-arena .board-center-info{z-index:3;width:min(460px,42%)}
.board-question-modal{inset:0;z-index:20}.board-question-modal .modal-card{width:min(60%,760px)}
@media(max-width:1280px){.game-layout{grid-template-columns:1fr}.board.board-ring{min-height:760px}.ring-arena{min-height:760px}.ring-cell{width:52px;height:52px;transform:rotate(var(--angle)) translateX(min(42vw,330px)) rotate(calc(-1 * var(--angle))) translate(-50%,-50%)}.ring-cell.start-cell{width:60px;height:52px}.ring-cell .cell-category-name{font-size:.3rem}.ring-arena .board-center-info{width:min(420px,50%)}}
@media(max-width:820px){.board.board-ring{min-height:700px}.ring-arena{min-height:700px;border-radius:30px;box-shadow:inset 0 0 0 24px rgba(191,219,254,.95)}.ring-cell{width:42px;height:46px;border-radius:8px;transform:rotate(var(--angle)) translateX(min(43vw,295px)) rotate(calc(-1 * var(--angle))) translate(-50%,-50%)}.ring-cell.start-cell{width:48px;height:46px}.ring-cell .cell-category-icon,.ring-cell .start-cell-icon{font-size:.68rem}.ring-cell .cell-category-name{font-size:.24rem}.ring-cell .cell-number{font-size:.42rem}.ring-cell .pawn{width:12px;height:12px;font-size:.32rem}.ring-arena .board-player-chips{grid-template-columns:1fr 1fr}.ring-arena .board-center-info{width:68%;gap:10px}.ring-direction{font-size:2.7rem}.ring-direction.arrow-a{top:42px}.ring-direction.arrow-b{right:18px}.ring-direction.arrow-c{bottom:40px}.ring-direction.arrow-d{left:16px}}

/* Ajuste v14: ruta completa con anillo y rectas llenas de casillas */
.board.board-route-map{display:block;min-height:880px;padding:0;background:transparent;border:0;overflow:visible}
.route-arena{position:relative;min-height:880px;border-radius:50%;background:#f8fafc;border:2px solid rgba(15,23,42,.95);box-shadow:0 24px 70px rgba(0,0,0,.35);padding:0;overflow:hidden}
.route-ring-bg{position:absolute;inset:5.5%;border-radius:50%;border:64px solid #dbeafe;background:transparent;box-shadow:inset 0 0 0 1px rgba(15,23,42,.18),0 0 0 1px rgba(15,23,42,.18);z-index:1}
.route-track{position:absolute;left:21%;right:18%;height:8%;background:#dbeafe;border:1px solid rgba(15,23,42,.75);z-index:2;box-shadow:0 2px 0 rgba(255,255,255,.5) inset}
.route-track-top{top:39%}.route-track-bottom{top:53%}
.route-cell{position:absolute;transform:translate(-50%,-50%) rotate(var(--route-angle,0deg));border-radius:7px;border:1px solid rgba(15,23,42,.72);background:var(--cell-color,#64748b)!important;box-shadow:none;overflow:hidden;z-index:5;display:block;min-width:0;flex:none}
.route-cell.route-ring{border-radius:9px}
.route-cell.start-cell{background:#b8b8b8!important;color:#111827;border-color:#334155;z-index:7}
.route-cell.finish-cell{background:#35ff00!important;border-color:#14532d;box-shadow:inset 0 0 0 2px rgba(255,255,255,.32);z-index:7}
.route-cell .cell-number{position:absolute;top:2px;left:3px;color:#000!important;background:transparent!important;padding:0;border-radius:0;font-size:.53rem;font-weight:950;text-shadow:none;z-index:4}
.route-cell .cell-category-icon,.route-cell .start-cell-icon{position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);font-size:.82rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.42);width:auto;height:auto;z-index:2}
.route-cell .start-cell-icon{color:#111827;text-shadow:none}
.route-cell .cell-category-name{position:absolute;left:2px;right:2px;top:53%;bottom:auto;color:#fff;font-size:.30rem;font-weight:900;line-height:1.02;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.5);z-index:2;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.route-cell.start-cell .cell-category-name{color:#111827!important;text-shadow:none;font-size:.38rem}
.route-cell .pawns{position:absolute;left:1px;right:1px;bottom:1px;gap:1px;justify-content:center;z-index:8}
.route-cell .pawn{width:14px;height:14px;font-size:.38rem;border-width:1px}
.route-direction{position:absolute;z-index:3;color:#ff2600;font-size:4.8rem;font-weight:950;line-height:1;text-shadow:0 1px 0 rgba(255,255,255,.35);pointer-events:none}
.route-arrow-top{top:9%;left:32%;transform:rotate(15deg)}
.route-arrow-right{right:6%;top:37%;transform:rotate(82deg)}
.route-arrow-bottom{bottom:8%;left:42%;transform:rotate(188deg)}
.route-arrow-left{left:6%;top:48%;transform:rotate(265deg)}
.route-center-info{z-index:4;width:min(470px,42%)}
.board-question-modal{inset:0;z-index:30}.board-question-modal .modal-card{width:min(60%,760px)}
@media(max-width:1280px){.game-layout{grid-template-columns:1fr}.board.board-route-map{min-height:760px}.route-arena{min-height:760px}.route-ring-bg{border-width:52px}.route-cell .cell-category-name{font-size:.25rem}.route-cell .cell-category-icon,.route-cell .start-cell-icon{font-size:.68rem}.route-cell .pawn{width:12px;height:12px;font-size:.32rem}.route-center-info{width:min(420px,50%)}}
@media(max-width:820px){.board.board-route-map{min-height:700px}.route-arena{min-height:700px;border-radius:30px}.route-ring-bg{inset:4%;border-width:34px}.route-track{left:16%;right:13%;height:7%}.route-cell{border-radius:5px}.route-cell .cell-number{font-size:.38rem}.route-cell .cell-category-icon,.route-cell .start-cell-icon{font-size:.5rem}.route-cell .cell-category-name{font-size:.18rem}.route-cell .pawn{width:10px;height:10px;font-size:.26rem}.route-center-info{width:68%;gap:10px}.route-direction{font-size:2.8rem}.route-arrow-top{top:8%}.route-arrow-right{right:4%}.route-arrow-bottom{bottom:7%}.route-arrow-left{left:4%}}

/* v15: tablero rectangular de 50 casillas */
.board.board-rectangular-50{
    display:grid!important;
    grid-template-columns:repeat(10,minmax(72px,1fr));
    gap:8px;
    min-height:auto;
    padding:16px;
    background:rgba(15,23,42,.72);
    border:1px solid rgba(148,163,184,.32);
    border-radius:24px;
    overflow:visible;
}
.rectangular-cell{
    position:relative;
    min-height:92px;
    border-radius:14px;
    border:1px solid rgba(15,23,42,.45);
    overflow:hidden;
    box-shadow:none;
}
.rectangular-cell.category-cell{background:var(--cell-color,#64748b)!important;border-color:rgba(15,23,42,.38)}
.rectangular-cell.finish-cell{background:#35ff00!important;border-color:#14532d;box-shadow:inset 0 0 0 2px rgba(255,255,255,.28)}
.rectangular-cell.start-cell{background:#b8b8b8!important;color:#111827;border-color:#334155}
.rectangular-cell .cell-number{position:absolute;top:6px;left:7px;color:#000!important;background:transparent!important;padding:0;border-radius:0;font-size:.72rem;font-weight:950;text-shadow:none;z-index:4}
.rectangular-cell .cell-category-icon,.rectangular-cell .start-cell-icon{position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);font-size:1.35rem;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.38);width:auto;height:auto;background:transparent;border:0;box-shadow:none;z-index:2}
.rectangular-cell .start-cell-icon{color:#111827;text-shadow:none}
.rectangular-cell .cell-category-name{position:absolute;left:4px;right:4px;top:58%;bottom:auto;color:#fff;font-size:.58rem;font-weight:900;line-height:1.05;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.45);z-index:2;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.rectangular-cell.start-cell .cell-category-name{color:#111827!important;text-shadow:none;font-size:.68rem}
.rectangular-cell .pawns{position:absolute;left:3px;right:3px;bottom:3px;gap:2px;justify-content:center;z-index:8}
.rectangular-cell .pawn{width:20px;height:20px;font-size:.56rem;border-width:1px}
@media(max-width:1280px){.board.board-rectangular-50{grid-template-columns:repeat(8,minmax(62px,1fr))}.rectangular-cell{min-height:84px}.rectangular-cell .cell-category-name{font-size:.5rem}.rectangular-cell .cell-category-icon,.rectangular-cell .start-cell-icon{font-size:1.12rem}}
@media(max-width:820px){.board.board-rectangular-50{grid-template-columns:repeat(5,minmax(52px,1fr));gap:6px;padding:10px}.rectangular-cell{min-height:76px;border-radius:10px}.rectangular-cell .cell-number{font-size:.56rem}.rectangular-cell .cell-category-icon,.rectangular-cell .start-cell-icon{font-size:.92rem}.rectangular-cell .cell-category-name{font-size:.38rem}.rectangular-cell .pawn{width:15px;height:15px;font-size:.38rem}}

/* Ajuste v17: botón central animado de ruleta */
.roulette-center-btn{position:absolute;left:50%;top:50%;z-index:4;transform:translate(-50%,-50%) scale(1);width:66px;height:66px;border:4px solid rgba(255,255,255,.92);border-radius:50%;display:grid;place-items:center;background:#22c55e;color:#fff;font-size:1.85rem;box-shadow:0 14px 28px rgba(0,0,0,.36),inset 0 0 0 2px rgba(15,23,42,.14);cursor:pointer;transition:background .22s ease,transform .16s ease,box-shadow .22s ease,filter .22s ease}
.roulette-center-btn:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 16px 32px rgba(0,0,0,.42),0 0 0 7px rgba(34,197,94,.18),inset 0 0 0 2px rgba(15,23,42,.14)}
.roulette-center-btn:active:not(:disabled),.roulette-center-btn.roulette-btn-pressed{background:#ef4444;transform:translate(-50%,-50%) scale(.88);box-shadow:0 8px 18px rgba(0,0,0,.34),0 0 0 10px rgba(239,68,68,.22),inset 0 0 0 2px rgba(15,23,42,.18)}
.roulette-center-btn.roulette-btn-spinning{background:#ef4444;animation:rouletteCenterPulse .72s ease-in-out infinite alternate;cursor:wait}
.roulette-center-btn:disabled{opacity:.92}
@keyframes rouletteCenterPulse{0%{transform:translate(-50%,-50%) scale(.96);box-shadow:0 10px 22px rgba(0,0,0,.36),0 0 0 4px rgba(239,68,68,.18)}100%{transform:translate(-50%,-50%) scale(1.07);box-shadow:0 18px 36px rgba(0,0,0,.42),0 0 0 13px rgba(239,68,68,.24)}}

/* v18: boton central de ruleta con tamaño de centro y efecto 3D */
.roulette-center-btn{width:37px;height:37px;border:3px solid rgba(255,255,255,.96);font-size:1.08rem;background:radial-gradient(circle at 35% 28%,#bbf7d0 0%,#22c55e 42%,#15803d 100%);text-shadow:0 1px 3px rgba(0,0,0,.34);box-shadow:0 8px 0 rgba(15,23,42,.72),0 13px 22px rgba(0,0,0,.42),inset 0 3px 6px rgba(255,255,255,.38),inset 0 -4px 8px rgba(0,0,0,.24);transition:background .22s ease,transform .16s ease,box-shadow .18s ease,filter .22s ease}
.roulette-center-btn:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 8px 0 rgba(15,23,42,.72),0 15px 24px rgba(0,0,0,.46),inset 0 4px 8px rgba(255,255,255,.42),inset 0 -4px 8px rgba(0,0,0,.24)}
.roulette-center-btn:active:not(:disabled),.roulette-center-btn.roulette-btn-pressed{background:radial-gradient(circle at 35% 28%,#fecaca 0%,#ef4444 45%,#991b1b 100%);transform:translate(-50%,-50%) translateY(4px) scale(.96);box-shadow:0 4px 0 #7f1d1d,0 9px 15px rgba(0,0,0,.38),0 0 0 6px rgba(239,68,68,.18),inset 0 3px 6px rgba(255,255,255,.34),inset 0 -3px 7px rgba(0,0,0,.28)}
.roulette-center-btn.roulette-btn-spinning{background:radial-gradient(circle at 35% 28%,#fecaca 0%,#ef4444 45%,#991b1b 100%);animation:rouletteCenterPulse3d .72s ease-in-out infinite alternate;cursor:wait}
.roulette-center-btn:disabled{opacity:.96}
@keyframes rouletteCenterPulse3d{0%{transform:translate(-50%,-50%) translateY(3px) scale(.97);box-shadow:0 4px 0 #7f1d1d,0 9px 15px rgba(0,0,0,.38),0 0 0 4px rgba(239,68,68,.16),inset 0 3px 6px rgba(255,255,255,.32),inset 0 -3px 7px rgba(0,0,0,.28)}100%{transform:translate(-50%,-50%) translateY(0) scale(1.04);box-shadow:0 7px 0 #7f1d1d,0 14px 24px rgba(0,0,0,.44),0 0 0 8px rgba(239,68,68,.20),inset 0 3px 7px rgba(255,255,255,.36),inset 0 -4px 8px rgba(0,0,0,.30)}}

/* v20: centra el botón exactamente en el centro geométrico de la ruleta */
.roulette-wrap > .roulette-center-btn{
    position:absolute;
    left:50%;
    top:50%;
    margin:0;
    padding:0;
    transform:translate(-50%,-50%) scale(1);
}
.roulette-wrap > .roulette-center-btn:active:not(:disabled),
.roulette-wrap > .roulette-center-btn.roulette-btn-pressed{
    transform:translate(-50%,-50%) translateY(4px) scale(.96);
}
.roulette-wrap > .roulette-center-btn.roulette-btn-spinning{
    margin:0;
}

/* v24: ruleta solo como modal centrado sobre el tablero para el jugador en turno */
.board-roulette-modal{
    inset:0;
    z-index:24;
    display:grid;
    place-items:center;
    background:rgba(2,6,23,.42);
    backdrop-filter:blur(2px);
}
.roulette-modal-card{
    width:min(360px,92%);
    min-height:330px;
    display:grid;
    place-items:center;
    align-content:center;
    gap:10px;
    text-align:center;
    background:rgba(18,26,47,.96);
    border:1px solid rgba(255,255,255,.18);
    border-radius:28px;
    padding:24px 22px;
    box-shadow:0 30px 90px rgba(0,0,0,.48);
    transform-origin:center;
}
.board-roulette-modal.modal-zoom-in .roulette-modal-card{
    animation:questionZoomIn .68s cubic-bezier(.16,1,.3,1) both;
}
.roulette-modal-card h2{
    margin:0 0 4px;
    font-size:1.45rem;
}
.roulette-modal-card .roulette-wrap{
    margin:4px auto 0;
}
.roulette-modal-card .roulette-result{
    margin:10px auto 0;
}
.roulette-modal-card #gameMessage{
    width:100%;
    min-height:28px;
    margin-top:2px;
    text-align:center;
}

/* v26: barra superior muestra solo el jugador en turno, con color de ficha */
.topbar-player-turn{display:flex;align-items:center;justify-content:center;min-width:170px}
.turn-player-chip{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 16px;border-radius:999px;font-weight:950;letter-spacing:.02em;border:2px solid rgba(255,255,255,.72);box-shadow:0 10px 24px rgba(0,0,0,.28);background:var(--accent2);color:#082f49}
.turn-player-chip::before{content:'Jugador: ';font-weight:700;opacity:.78;margin-right:4px}
.turn-player-chip.p1{background:var(--accent2);color:#082f49}
.turn-player-chip.p2{background:var(--accent);color:#052e16}
.turn-player-chip.p3{background:var(--warn);color:#422006}
.turn-player-chip.p4{background:var(--danger);color:#4c0519}
.turn-player-chip.finished{background:rgba(255,255,255,.12);color:var(--text);border-color:rgba(255,255,255,.25)}
.turn-player-chip.finished::before{content:''}

/* v29: todas las fichas visibles y sincronizadas en cada tablero */
.pawn.pawn-mine{box-shadow:0 0 0 3px rgba(255,255,255,.85),0 10px 22px rgba(0,0,0,.30)}
.pawn.pawn-turn.pawn-mine{outline:3px solid rgba(250,204,21,.95);box-shadow:0 0 0 4px rgba(255,255,255,.75),0 0 0 8px rgba(250,204,21,.18),0 12px 28px rgba(0,0,0,.36)}

/* v30 PRUEBA: tablero rectangular con estilo 3D visual CSS.
   Reversión: reemplazar este archivo por el de v29 o quitar este bloque. */
.board-wrap{
    perspective:1200px;
    perspective-origin:50% 18%;
}
.board.board-rectangular-50{
    transform:rotateX(10deg);
    transform-origin:center top;
    transform-style:preserve-3d;
    background:linear-gradient(180deg,rgba(30,41,59,.92),rgba(15,23,42,.96));
    border:1px solid rgba(255,255,255,.18);
    box-shadow:0 34px 70px rgba(0,0,0,.46),0 14px 0 rgba(2,6,23,.72),inset 0 1px 0 rgba(255,255,255,.12);
}
.rectangular-cell{
    transform-style:preserve-3d;
    transform:translateZ(0);
    border:1px solid rgba(255,255,255,.26);
    box-shadow:0 10px 0 rgba(15,23,42,.78),0 18px 22px rgba(0,0,0,.34),inset 0 2px 0 rgba(255,255,255,.24),inset 0 -10px 18px rgba(0,0,0,.18);
    transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.rectangular-cell.category-cell{
    border-color:rgba(255,255,255,.24);
    box-shadow:0 10px 0 rgba(15,23,42,.78),0 18px 22px rgba(0,0,0,.34),inset 0 2px 0 rgba(255,255,255,.26),inset 0 -12px 20px rgba(0,0,0,.20);
}
.rectangular-cell.start-cell{
    box-shadow:0 10px 0 #475569,0 18px 22px rgba(0,0,0,.34),inset 0 2px 0 rgba(255,255,255,.38),inset 0 -12px 20px rgba(0,0,0,.16);
}
.rectangular-cell.finish-cell{
    box-shadow:0 10px 0 #166534,0 18px 22px rgba(0,0,0,.34),inset 0 2px 0 rgba(255,255,255,.36),inset 0 -12px 20px rgba(0,0,0,.18)!important;
}
.rectangular-cell:after{
    content:'';
    position:absolute;
    inset:0;
    border-radius:inherit;
    background:linear-gradient(180deg,rgba(255,255,255,.20),rgba(255,255,255,0) 34%,rgba(0,0,0,.12));
    pointer-events:none;
    z-index:1;
}
.rectangular-cell .cell-number,
.rectangular-cell .cell-category-icon,
.rectangular-cell .start-cell-icon,
.rectangular-cell .cell-category-name,
.rectangular-cell .pawns{
    z-index:3;
}
.rectangular-cell .pawn{
    box-shadow:0 7px 0 rgba(15,23,42,.65),0 12px 16px rgba(0,0,0,.38),inset 0 2px 4px rgba(255,255,255,.42),inset 0 -4px 7px rgba(0,0,0,.22);
    border-color:rgba(255,255,255,.9);
}
.rectangular-cell .pawn.pawn-jump{
    animation:pawnHop3d .34s ease-in-out both;
}
@keyframes pawnHop3d{
    0%{transform:translateY(0) translateZ(0) scale(1)}
    45%{transform:translateY(-24px) translateZ(34px) scale(1.16)}
    100%{transform:translateY(0) translateZ(0) scale(1)}
}
.rectangular-cell:has(.pawn-turn){
    filter:brightness(1.08);
    box-shadow:0 10px 0 rgba(15,23,42,.78),0 0 0 3px rgba(250,204,21,.78),0 20px 28px rgba(0,0,0,.38),inset 0 2px 0 rgba(255,255,255,.28),inset 0 -12px 20px rgba(0,0,0,.20);
}
@media(max-width:820px){
    .board.board-rectangular-50{transform:none;box-shadow:0 22px 48px rgba(0,0,0,.42),0 8px 0 rgba(2,6,23,.72),inset 0 1px 0 rgba(255,255,255,.12)}
    .rectangular-cell{box-shadow:0 6px 0 rgba(15,23,42,.78),0 12px 16px rgba(0,0,0,.32),inset 0 2px 0 rgba(255,255,255,.22),inset 0 -8px 14px rgba(0,0,0,.16)}
}

/* Ajuste v31: fichas 3D con forma por jugador, nombre completo visible y números grandes blancos */
.rectangular-cell .cell-number{
    color:#fff!important;
    font-size:1.08rem!important;
    font-weight:1000;
    line-height:1;
    text-shadow:0 2px 5px rgba(0,0,0,.62)!important;
    z-index:9;
}
.rectangular-cell.start-cell .cell-number{
    color:#fff!important;
    text-shadow:0 2px 5px rgba(0,0,0,.45)!important;
}
.rectangular-cell .pawns{
    left:4px;
    right:4px;
    bottom:4px;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:3px;
    overflow:visible;
    z-index:12;
}
.rectangular-cell .pawn,
.ring-cell .pawn,
.route-cell .pawn,
.path-cell .pawn,
.pawn{
    width:auto!important;
    min-width:0!important;
    max-width:96%;
    height:auto!important;
    min-height:24px;
    border:0!important;
    border-radius:999px;
    display:inline-flex!important;
    align-items:center;
    justify-content:center;
    gap:4px;
    padding:2px 6px 3px 3px;
    background:rgba(15,23,42,.72)!important;
    color:#fff!important;
    font-size:.56rem!important;
    font-weight:950;
    line-height:1;
    overflow:visible;
    box-shadow:0 7px 0 rgba(15,23,42,.72),0 12px 16px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.26)!important;
    transform-style:preserve-3d;
}
.pawn .pawn-mark{
    position:relative;
    flex:0 0 auto;
    width:20px;
    height:20px;
    display:grid;
    place-items:center;
    color:#fff;
    font-size:.58rem;
    font-weight:1000;
    text-shadow:0 1px 2px rgba(0,0,0,.5);
    box-shadow:0 5px 0 rgba(15,23,42,.55),0 9px 12px rgba(0,0,0,.35),inset 0 2px 4px rgba(255,255,255,.42),inset 0 -5px 7px rgba(0,0,0,.22);
    background:#38bdf8;
    transform:translateZ(10px);
}
.pawn .pawn-mark::after{
    content:'';
    position:absolute;
    inset:2px 3px auto 3px;
    height:35%;
    border-radius:inherit;
    background:rgba(255,255,255,.25);
    pointer-events:none;
}
.pawn .pawn-name{
    display:block;
    max-width:82px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    color:#fff;
    text-shadow:0 1px 3px rgba(0,0,0,.72);
}
.pawn.p1 .pawn-mark{
    border-radius:50%;
    background:linear-gradient(145deg,#7dd3fc,#0284c7 68%,#075985);
}
.pawn.p2 .pawn-mark{
    border-radius:5px;
    background:linear-gradient(145deg,#fca5a5,#dc2626 66%,#7f1d1d);
    transform:rotate(45deg) translateZ(10px);
}
.pawn.p2 .pawn-mark span{
    transform:rotate(-45deg);
}
.pawn.p3 .pawn-mark{
    border-radius:6px 6px 9px 9px;
    clip-path:polygon(50% 0%,100% 20%,86% 100%,14% 100%,0% 20%);
    background:linear-gradient(145deg,#86efac,#16a34a 66%,#14532d);
}
.pawn.p4 .pawn-mark{
    border-radius:5px;
    clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);
    background:linear-gradient(145deg,#d8b4fe,#9333ea 66%,#581c87);
}
.pawn.pawn-mine{
    box-shadow:0 0 0 2px rgba(255,255,255,.88),0 7px 0 rgba(15,23,42,.72),0 12px 16px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.26)!important;
}
.pawn.pawn-turn{
    outline:2px solid rgba(250,204,21,.95);
    outline-offset:2px;
}
.rectangular-cell .pawn.pawn-jump{
    animation:pawnHop3dName .38s ease-in-out both;
}
@keyframes pawnHop3dName{
    0%{transform:translateY(0) translateZ(0) scale(1)}
    45%{transform:translateY(-26px) translateZ(38px) scale(1.08)}
    100%{transform:translateY(0) translateZ(0) scale(1)}
}
@media(max-width:820px){
    .rectangular-cell .cell-number{font-size:.82rem!important}
    .rectangular-cell .pawn,.pawn{font-size:.44rem!important;padding:2px 4px 2px 2px;gap:3px;max-width:98%}
    .pawn .pawn-mark{width:15px;height:15px;font-size:.42rem}
    .pawn .pawn-name{max-width:54px}
}

/* v32: pregunta visible para todos, activa solo para jugador en turno */
.board-question-modal.question-active-viewer{background:rgba(30,64,175,.58)}
.board-question-modal.question-waiting-viewer{background:rgba(127,29,29,.62)}
.board-question-modal.question-active-viewer .modal-card{background:linear-gradient(180deg,#1d4ed8 0%,#1e40af 100%);border-color:rgba(147,197,253,.85);box-shadow:0 24px 60px rgba(30,64,175,.48),0 0 0 1px rgba(255,255,255,.12) inset;color:#fff}
.board-question-modal.question-waiting-viewer .modal-card{background:linear-gradient(180deg,#dc2626 0%,#991b1b 100%);border-color:rgba(252,165,165,.9);box-shadow:0 24px 60px rgba(127,29,29,.52),0 0 0 1px rgba(255,255,255,.12) inset;color:#fff}
.question-player-label{display:inline-flex;align-items:center;justify-content:center;margin:12px auto 4px;padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);font-weight:900;color:#fff;letter-spacing:.01em;box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
.board-question-modal .timer{color:#fff;background:rgba(15,23,42,.24);padding:8px 12px;border-radius:999px}
.board-question-modal .badge{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.34);color:#fff}
.board-question-modal .answer-options button{background:rgba(255,255,255,.94);color:#0f172a;border-color:rgba(255,255,255,.85);font-weight:900;box-shadow:0 10px 20px rgba(0,0,0,.22)}
.board-question-modal .answer-options button.answer-disabled,.board-question-modal .answer-options button:disabled{opacity:.68;cursor:not-allowed;filter:grayscale(.15);box-shadow:none}
.board-question-modal #answerMessage{color:#fff;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.25)}

/* v33: sincronización de pregunta, selección visible y color por categoría */
.board-question-modal.question-active-viewer{
    background:color-mix(in srgb,var(--question-category-color,#1d4ed8) 62%,rgba(15,23,42,.78));
}
.board-question-modal.question-active-viewer .modal-card{
    background:linear-gradient(180deg,color-mix(in srgb,var(--question-category-color,#1d4ed8) 88%,#ffffff 12%) 0%,color-mix(in srgb,var(--question-category-color,#1d4ed8) 72%,#0f172a 28%) 100%);
    border-color:rgba(255,255,255,.72);
    box-shadow:0 28px 70px color-mix(in srgb,var(--question-category-color,#1d4ed8) 52%,transparent),0 0 0 1px rgba(255,255,255,.16) inset;
    color:#fff;
}
.board-question-modal .answer-options button.answer-selected,
.board-question-modal .answer-options button.answer-selected:disabled{
    background:#facc15!important;
    color:#111827!important;
    border-color:#fff7a8!important;
    opacity:1!important;
    transform:scale(1.035);
    box-shadow:0 0 0 4px rgba(250,204,21,.28),0 18px 30px rgba(0,0,0,.34)!important;
}
.board-question-modal.question-reveal-viewer .modal-card{
    animation:answerRevealPulse .55s ease both;
}
@keyframes answerRevealPulse{
    0%{transform:scale(.96);filter:saturate(.9)}
    55%{transform:scale(1.025);filter:saturate(1.15)}
    100%{transform:scale(1);filter:saturate(1)}
}

/* v36: cierre de sala y despedida */
.goodbye-modal{position:fixed;inset:0;z-index:45;display:grid;place-items:center;pointer-events:none;background:rgba(2,6,23,.30)}
.goodbye-card{width:min(60vw,660px);min-height:190px;border-radius:34px;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;text-align:center;box-shadow:0 30px 90px rgba(0,0,0,.48);transform-origin:center;padding:30px;background:linear-gradient(160deg,rgba(14,165,233,.98),rgba(37,99,235,.94));color:#eff6ff}
.goodbye-title{font-size:clamp(2.1rem,6vw,5rem);font-weight:950;letter-spacing:.02em;text-shadow:0 4px 18px rgba(0,0,0,.25)}
.goodbye-show .goodbye-card{animation:feedbackZoomIn .72s cubic-bezier(.16,1,.3,1) both}
.goodbye-hide .goodbye-card{animation:feedbackZoomOut .62s ease-in both}
@media(max-width:720px){.goodbye-card{width:92vw;min-height:150px}}

/* v39: color de visor no activo igual al fondo de la ruleta */
.board-question-modal.question-waiting-viewer{
    background:rgba(2,6,23,.42)!important;
    backdrop-filter:blur(2px);
}
.board-question-modal.question-waiting-viewer .modal-card{
    background:rgba(18,26,47,.96)!important;
    border-color:rgba(255,255,255,.18)!important;
    box-shadow:0 28px 70px rgba(2,6,23,.42),0 0 0 1px rgba(255,255,255,.12) inset!important;
    color:#fff;
}

/* v42: código QR de invitación a sala */
.room-share-card{display:flex;align-items:center;justify-content:space-between;gap:18px;margin:18px 0 20px;padding:16px;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.045)}
.room-share-info{display:grid;gap:8px;min-width:0}
.room-share-info strong{font-size:clamp(1.8rem,5vw,3.2rem);letter-spacing:.08em;line-height:1;color:#fff}
.room-join-link{color:#bae6fd;text-decoration:none;font-weight:800;word-break:break-all}
.room-join-link:hover{text-decoration:underline}
.room-qr-box{width:150px;height:150px;display:grid;place-items:center;flex:0 0 150px;border-radius:20px;background:#fff;padding:10px;box-shadow:0 16px 34px rgba(0,0,0,.28)}
.room-qr-img{width:100%;height:100%;object-fit:contain;display:block}
.prefilled-room-code{border-color:rgba(34,197,94,.85)!important;box-shadow:0 0 0 4px rgba(34,197,94,.14)}
@media(max-width:720px){.room-share-card{flex-direction:column;text-align:center}.room-qr-box{width:190px;height:190px;flex-basis:190px}.room-share-info strong{font-size:2.4rem}}
