*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}body{background:#0a0a0a;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,3%) 1px,transparent 0);background-size:40px 40px;font-family:segoe ui,system-ui,-apple-system,sans-serif;min-height:100vh;color:#e0e0e0}.game-wrapper{max-width:700px;margin:0 auto;padding:12px 10px 40px}#player-bar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.player-slot{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;background:rgba(255,255,255,4%);flex:1;position:relative;overflow:hidden;transition:box-shadow .3s}.player-slot.active{box-shadow:0 0 12px rgba(212,167,106,.5);background:rgba(212,167,106,8%)}.player-slot .player-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover}.player-slot .player-name{color:#fff;font-weight:600;font-size:.95em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.score-label{color:#aaa;font-size:.8em}.borne-off-count{color:#ff9800;font-weight:700}.indicator{width:8px;height:8px;border-radius:50%;position:absolute;top:8px;right:8px}.skeleton-avatar{width:34px;height:34px;border-radius:50%;background:#333}.skeleton-name{width:80px;height:14px;border-radius:4px;background:#333}.shimmer{background:linear-gradient(90deg,#333 25%,#444 50%,#333 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}#timer-container{height:4px;background:rgba(255,255,255,6%);border-radius:2px;overflow:hidden;margin-bottom:6px}#timer-bar{height:100%;width:0%;background:#d4a76a;border-radius:2px;transition:width .25s linear,background .3s}#dice-area{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}#dice-display{display:flex;gap:8px}.die{width:42px;height:42px;border-radius:8px;background:#fff;color:#222;font-size:1.4em;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.3);transition:transform .2s}.die.used{opacity:.35;text-decoration:line-through}.die.rolled{animation:diceRoll .4s ease-out}@keyframes diceRoll{0%{transform:rotateZ(0)scale(.8)}50%{transform:rotateZ(180deg)scale(1.1)}100%{transform:rotateZ(360deg)scale(1)}}#dice-remaining{color:#aaa;font-size:.85em}.action-btn{padding:10px 22px;border:none;border-radius:8px;font-size:.95em;font-weight:700;cursor:pointer;transition:all .15s}.action-btn:disabled{opacity:.4;cursor:default}.roll-btn{background:linear-gradient(135deg,#d4a76a,#b8864e);color:#fff;box-shadow:0 3px #8b6232}.roll-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 5px #8b6232}.roll-btn:not(:disabled):active{transform:translateY(1px);box-shadow:0 0 #8b6232}#board-container{display:flex;justify-content:center;gap:8px;margin-bottom:10px}#board{background:linear-gradient(135deg,#2d1810,#3e2415);border:3px solid #5c3d2e;border-radius:10px;overflow:hidden;flex:1;max-width:600px}.board-half{display:flex;min-height:140px}.top-half{border-bottom:2px solid #5c3d2e}.quadrant{display:flex;flex:1;gap:1px}.bar-zone{width:30px;background:rgba(92,61,46,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.point-col{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;cursor:pointer;min-width:0;padding:2px 0}.point-col.top{justify-content:flex-start}.point-col.bottom{justify-content:flex-end}.point-col::before{content:'';position:absolute;width:80%;height:65%;clip-path:polygon(50% 100%,0 0,100% 0)}.point-col.top::before{top:0;clip-path:polygon(50% 100%,0 0,100% 0)}.point-col.bottom::before{bottom:0;clip-path:polygon(50% 0%,0 100%,100% 100%)}.point-col.dark::before{background:rgba(92,61,46,.6)}.point-col.light::before{background:rgba(212,167,106,.4)}.point-col.highlight{background:rgba(76,175,80,.15)}.point-col.highlight::after{content:'';position:absolute;inset:0;border:2px solid rgba(76,175,80,.5);border-radius:2px;pointer-events:none}.point-col.selected{background:rgba(255,152,0,.2)}.checker{width:28px;height:28px;border-radius:50%;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;font-size:.7em;font-weight:700;flex-shrink:0;transition:transform .15s;border:2px solid rgba(0,0,0,.3)}.checker.p0{background:linear-gradient(135deg,#d4a76a,#c29352);color:#3e2415}.checker.p1{background:linear-gradient(135deg,#5c3d2e,#3e2415);color:#d4a76a}.checker.selected{transform:scale(1.15);box-shadow:0 0 10px rgba(255,152,0,.6)}.checker.stacked{margin-top:-10px}.checker.top-stack{margin-bottom:-10px}.bar-checker{width:22px;height:22px;border-radius:50%;border:1px solid rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;font-size:.6em;font-weight:700}.bar-checker.p0{background:#d4a76a;color:#3e2415}.bar-checker.p1{background:#5c3d2e;color:#d4a76a}#bearoff-area{display:flex;flex-direction:column;gap:6px;justify-content:center}.bearoff-tray{width:40px;min-height:60px;background:rgba(255,255,255,4%);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px;cursor:pointer;transition:all .15s}.bearoff-tray.highlight{border-color:#4caf50;background:rgba(76,175,80,.1)}.bearoff-label{color:#888;font-size:.6em;white-space:nowrap}.bearoff-count{font-size:1.2em;font-weight:700;color:#ff9800}.point-number{font-size:.55em;color:rgba(255,255,255,.3);position:absolute;z-index:0}.point-col.top .point-number{bottom:2px}.point-col.bottom .point-number{top:2px}#game-status{text-align:center;padding:10px;color:#fff;font-size:1em;min-height:40px;margin-top:10px;border-radius:8px}.results-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.results-modal{background:#1a1a2e;border-radius:16px;padding:28px;max-width:420px;width:90%;text-align:center;animation:slideUp .4s ease-out;box-shadow:0 20px 60px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,8%)}@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.results-header{font-size:1.6em;font-weight:800;margin-bottom:6px;color:#fff}.results-outcome{color:#bbb;font-size:1em;margin-bottom:14px}.results-scores{display:flex;justify-content:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.score-badge{padding:8px 16px;border-radius:10px;background:rgba(255,255,255,5%);color:#fff;font-size:.95em}.score-badge.winner{background:rgba(76,175,80,.15);border:1px solid rgba(76,175,80,.3)}.challenge-message{color:#ff9800;font-weight:600;font-size:1em;margin-bottom:10px;animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-text{0%,100%{opacity:1}50%{opacity:.7}}.xp-gain-container{margin:14px 0}.xp-gain-label{display:flex;justify-content:space-between;font-size:.85em;color:#aaa;margin-bottom:4px}.xp-progress-bg{height:8px;background:rgba(255,255,255,8%);border-radius:4px;overflow:hidden}.xp-progress-fill{height:100%;background:linear-gradient(90deg,#d4a76a,#b8864e);border-radius:4px;width:0%;transition:width 1.2s ease-out}.rank-text{font-size:.82em;color:#888;margin-top:4px}.results-actions{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}.btn-primary{padding:11px 26px;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .15s}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{padding:11px 26px;background:rgba(255,255,255,8%);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:10px;font-size:1em;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:rgba(255,255,255,.12)}.flash-effect{animation:flash .4s}@keyframes flash{0%{box-shadow:0 0 rgba(255,255,255,0)}50%{box-shadow:0 0 30px rgba(255,255,255,.2)}100%{box-shadow:0 0 rgba(255,255,255,0)}}.back-link{display:block;text-align:center;color:#888;text-decoration:none;margin-top:20px;font-size:.9em}.back-link:hover{color:#fff}@media(max-width:600px){.checker{width:24px;height:24px;font-size:.6em}.player-slot{padding:6px 8px}.player-slot .player-name{max-width:80px;font-size:.85em}.die{width:36px;height:36px;font-size:1.2em}.bar-zone{width:24px}.bearoff-tray{width:34px;min-height:50px}.results-modal{padding:20px}.action-btn{padding:8px 16px;font-size:.88em}}@media(max-width:400px){.checker{width:20px;height:20px;font-size:.55em;border-width:1px}.checker.stacked{margin-top:-8px}.checker.top-stack{margin-bottom:-8px}.die{width:32px;height:32px;font-size:1em}.bar-zone{width:20px}.bar-checker{width:18px;height:18px;font-size:.5em}.bearoff-tray{width:30px;min-height:40px}.game-wrapper{padding:8px 6px 30px}.point-col{padding:1px 0}}