:root{color-scheme:light;--background: #f2f5fa;--surface: rgba(255, 255, 255, .9);--surface-strong: rgba(255, 255, 255, 1);--border: rgba(12, 20, 44, .08);--border-strong: rgba(12, 20, 44, .18);--accent: #4f46e5;--accent-muted: rgba(79, 70, 229, .15);--text: #112034;--text-weak: rgba(17, 32, 52, .6);--success: #059669;--danger: #dc2626;--shadow: 0 24px 44px rgba(15, 23, 42, .15)}[data-theme=dark]{color-scheme:dark;--background: #060d1c;--surface: rgba(15, 23, 42, .85);--surface-strong: rgba(15, 23, 42, .95);--border: rgba(148, 163, 184, .12);--border-strong: rgba(148, 163, 184, .24);--accent: #818cf8;--accent-muted: rgba(129, 140, 248, .18);--text: #f8fafc;--text-weak: rgba(226, 232, 240, .7);--shadow: 0 24px 44px rgba(2, 6, 23, .35)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Poppins,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--background);color:var(--text);position:relative;overflow-x:hidden}body[data-scroll-locked=true]{overflow:hidden}.gradient{position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse at top,rgba(79,70,229,.16),transparent 60%),radial-gradient(ellipse at bottom,rgba(14,165,233,.12),transparent 55%);filter:blur(20px);z-index:1}.parallax-scene{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}.parallax-layer{position:absolute;inset:0;mix-blend-mode:screen;opacity:.75;background-repeat:no-repeat;background-size:120% 120%;background-position:center;filter:blur(40px)}.parallax-layer-back{opacity:.55;background-image:radial-gradient(circle at 18% 22%,rgba(79,70,229,.18),transparent 60%),radial-gradient(circle at 82% 18%,rgba(56,189,248,.16),transparent 55%),radial-gradient(circle at 50% 82%,rgba(16,185,129,.14),transparent 60%)}.parallax-layer-mid{opacity:.65;background-image:radial-gradient(circle at 28% 68%,rgba(236,72,153,.2),transparent 55%),radial-gradient(circle at 74% 42%,rgba(129,140,248,.28),transparent 52%),radial-gradient(circle at 58% 80%,rgba(59,130,246,.16),transparent 58%);filter:blur(28px)}.parallax-layer-front{opacity:.92;mix-blend-mode:normal;background-image:url(/assets/dice-CoVautP4.png),radial-gradient(circle at 30% 48%,rgba(255,255,255,.28),transparent 42%),radial-gradient(circle at 72% 58%,rgba(79,70,229,.2),transparent 55%),radial-gradient(circle at 55% 18%,rgba(20,184,166,.18),transparent 52%);background-size:500px auto,120% 120%,120% 120%,120% 120%;background-position:center 60%,30% 45%,70% 50%,45% 20%;filter:blur(0)}body>*:not(.gradient):not(.parallax-scene):not(#back-to-dice-button):not(#turn-indicator):not(.toast):not(.reconnect-modal):not(.winner-modal):not(#virtual-announce-select-dialog):not(#announce-dialog):not(#straight-dialog):not(#announce-confirm-dialog){position:relative;z-index:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-header{display:flex;justify-content:space-between;align-items:center;padding:clamp(1.25rem,2vw + 1rem,2rem) clamp(1.25rem,4vw,3rem) 0;gap:1rem}.app-header h1{margin:0;font-weight:700;font-size:clamp(1.75rem,5vw,2.4rem)}.app-header p{margin:.25rem 0 0;color:var(--text-weak);font-weight:500}.online-status-banner{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;margin:clamp(.75rem,1vw,.75rem) clamp(1.25rem,4vw,3rem) 0;padding:.75rem clamp(1rem,2vw + .5rem,1.5rem);border:1px solid var(--border);border-radius:18px;background:var(--surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);position:relative;z-index:2}.online-status-banner[hidden]{display:none}.online-status-room{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:.95rem;color:var(--text)}.online-status-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.12em;color:var(--text-weak)}.online-room-code{font-size:1rem;font-weight:700;letter-spacing:.18em;padding:.15rem .4rem;background:var(--surface-strong);border-radius:8px;border:1px dashed var(--border-strong)}.online-player-statuses{display:flex;flex-wrap:wrap;align-items:center;gap:.9rem 1.25rem;margin:0;padding:0;list-style:none}.player-status-item{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text);font-weight:500}.player-status-item.is-self{font-weight:600}.player-status-item.status-disconnected{color:var(--text-weak)}.status-indicator{width:.7rem;height:.7rem;border-radius:50%;display:inline-block;box-shadow:0 0 0 2px #fff9}.status-indicator.status-connected{background:var(--success)}.status-indicator.status-disconnected{background:var(--danger)}.actions{display:flex;gap:.75rem;align-items:center}button{border:none;border-radius:999px;padding:.6rem 1.4rem;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}button.primary{background:var(--accent);color:#fff;box-shadow:0 12px 22px #4f46e561}button.ghost{background:var(--surface);color:var(--text);box-shadow:0 8px 18px #0f172a1f}.action-button{padding-inline:1.2rem;height:48px}.icon-button{width:48px;height:48px;padding:0;border-radius:56px}.icon-button,.action-button{flex:0 0 auto}.settings-action-subtitle{text-align:left}.icon{display:inline-flex;width:1.4rem;height:1.4rem;align-items:center;justify-content:center}.icon svg{width:100%;height:100%;fill:currentColor}button:hover{transform:translateY(-2px)}button:active{transform:translateY(0)}.switch{position:relative;width:88px;height:32px;display:inline-flex;align-items:center;justify-content:center;min-height:32px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;inset:2px 18px;background:var(--border-strong);border-radius:999px;transition:background .18s ease}#settings-dialog .slider{inset:0 10px}.slider:before{content:"";position:absolute;height:20px;width:20px;left:6px;bottom:4px;background:var(--surface-strong);border-radius:50%;box-shadow:0 4px 10px #0f172a3d;transition:transform .18s ease,background .18s ease}.switch input:checked+.slider{background:var(--accent)}.switch input:checked+.slider:before{transform:translate(22px)}.switch-icon{position:absolute;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-weak);transition:color .2s ease,transform .2s ease;pointer-events:none}.switch-icon svg{fill:currentColor}.switch-icon-sun{left:-2px}.switch-icon-moon{right:-2px}.switch input:checked~.switch-icon-sun{color:#94a3b8b3;transform:scale(.9)}.switch input:checked~.switch-icon-moon{color:var(--accent);transform:scale(1.05)}.layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,2fr);gap:clamp(1.5rem,3vw,2.5rem);padding:clamp(1.25rem,2vw + 1rem,2rem) clamp(1.25rem,4vw,3rem) 3rem}.section-header h2{margin:0 0 .35rem;font-size:1.25rem}.section-header p{margin:0;color:var(--text-weak)}.scorecard{background:var(--surface);border-radius:24px;border:1px solid var(--border);padding:clamp(1rem,2vw + .5rem,1.75rem);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow)}[data-theme=dark] .scorecard,[data-theme=dark] .virtual-dice-panel{background:linear-gradient(135deg,#4f46e52e,#0ea5e929);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.table-wrap{margin-top:1rem}table{width:100%;border-collapse:collapse;min-width:min(600px,100%);table-layout:fixed}th,td{padding:.65rem .75rem;text-align:center;border-bottom:1px solid var(--border)}th:first-child,td:first-child{text-align:left;font-weight:600}.category-label{position:relative;display:flex;align-items:center;gap:.7rem}.category-label .label-content{display:flex;flex-direction:column;gap:.2rem}.category-label .label-text{display:block;font-weight:600;line-height:1.25}.category-label .label-detail{font-size:.82rem;color:var(--text-weak);line-height:1.2;word-break:break-word}.category-label.has-hint{cursor:pointer}.category-label.has-hint:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.die{width:2.35rem;height:2.35rem;border-radius:.75rem;border:2px solid var(--border-strong);background:var(--surface-strong);box-shadow:inset 0 3px 6px #0f172a1f;flex-shrink:0}.die svg{width:100%;height:100%;display:block;fill:none}.die circle{fill:var(--text);transition:fill .18s ease}thead th{font-size:.85rem;text-transform:none;letter-spacing:.04em;color:var(--text-weak)}tbody tr:hover{background:#4f46e50d}tbody tr.total-row{background:#4f46e50d;font-weight:600}tbody tr.total-strong{background:#4f46e51f;font-weight:700}input.score-input{width:100%;text-align:center;font:inherit;border:none;background:transparent;color:var(--text);border-radius:12px;padding:.45rem .3rem;transition:background .18s ease,box-shadow .18s ease;min-width:44px}input.score-input:focus{outline:none;background:var(--accent-muted);box-shadow:0 0 0 2px #4f46e51f}input.score-input[data-is-filled=true]{background:#0f766e1f;color:var(--text);font-weight:600}input.score-input[data-error=true]{background:#dc262629;box-shadow:0 0 0 2px #dc262633;color:var(--danger)}input.score-input.turn-locked{background:#64748b1f;cursor:not-allowed;color:var(--text-weak)}input.score-input.turn-locked[data-is-filled=true]{background:#0f766e1f;color:var(--text)}input.score-input.score-highlight{animation:scoreHighlight 1.5s ease-out 0s 2}@keyframes scoreHighlight{0%{background:#4f46e54d;box-shadow:0 0 0 4px #4f46e533}to{background:#0f766e1f;box-shadow:none}}.summary-panel{background:var(--surface);border-radius:24px;border:1px solid var(--border);padding:clamp(1rem,2vw + .5rem,1.75rem);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.4rem}[data-theme=dark] .summary-panel{background:#0f172a00;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.summary-list{list-style:none;margin:0;padding:0;display:grid;gap:1rem}.summary-item{padding:.85rem 1rem;border-radius:16px;border:1px dashed var(--border-strong);background:var(--surface-strong);display:grid;grid-template-columns:1fr auto;align-items:center;gap:.35rem .9rem}[data-theme=dark] .summary-item{background:#fff0}.summary-item h3{margin:0;grid-column:1;font-size:1.05rem}.summary-item .summary-value{grid-column:2;grid-row:1;justify-self:end;font-weight:600;font-size:1.1rem;font-feature-settings:"tnum" 1}.summary-item[data-trend=up] .summary-value{color:var(--success)}.summary-item[data-trend=down] .summary-value{color:var(--danger)}.summary-item .summary-detail{grid-column:1 / -1;color:var(--text-weak);font-size:.85rem}.grand-total-row{background:#4f46e514;font-size:1.05rem;border-top:2px solid var(--border-strong)}.grand-total-row th{text-align:right}.grand-total-row td{font-weight:700;font-feature-settings:"tnum" 1}.note{padding:1rem 1.25rem;border-radius:18px;background:linear-gradient(135deg,#4f46e52e,#0ea5e929);color:#0f172acc}[data-theme=dark] .note{color:#f8fafce6}[data-theme=dark] svg{fill:#fff}.note h3{margin:0 0 .4rem;font-size:1rem}.note p{margin:0;font-size:.9rem}.app-dialog{border:none;border-radius:24px;padding:0;max-width:520px;width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);background:var(--surface-strong);color:var(--text)}.app-dialog::backdrop{background:#0f172a66}.app-dialog form{display:flex;flex-direction:column}.app-dialog header{position:relative;padding:1.4rem 3.5rem 1.4rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:flex-start;gap:1rem}.app-dialog header h2{margin:0}.app-dialog header button{position:absolute;top:1rem;right:1.25rem;width:36px;height:36px;border-radius:50%;font-size:1.5rem;background:transparent;box-shadow:none;display:inline-flex;align-items:center;justify-content:center;line-height:1}.app-dialog .dialog-body{padding:1.4rem 1.5rem 1rem;color:var(--text);display:grid;gap:1rem}.announce-dialog-body{gap:1.25rem}.announce-dialog-message{margin:0;color:var(--text-weak);font-size:.9rem}.announce-dialog-footer{align-items:center;gap:1rem}.announce-dialog-actions{display:flex;gap:.75rem}.announce-roller{display:flex;justify-content:center;gap:.85rem;min-height:72px}.announce-roller .die{width:3rem;height:3rem;border-radius:.9rem;animation:announce-roll 1.6s ease-in-out infinite}.announce-roller .die:nth-child(2){animation-delay:.12s}.announce-roller .die:nth-child(3){animation-delay:.24s}#announce-dialog-input{margin:0 1.5rem .5rem;padding:.7rem .85rem;border-radius:12px;border:1px solid var(--border);background:#4f46e514;font:inherit;text-align:center;color:var(--text)}#announce-dialog-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #4f46e540;background:#4f46e51f}@keyframes announce-roll{0%{transform:translateY(0) rotate(0)}30%{transform:translateY(-10%) rotate(-8deg)}60%{transform:translateY(6%) rotate(6deg)}to{transform:translateY(0) rotate(0)}}.option-grid{display:grid;gap:.75rem}.option-card{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;border-radius:18px;padding:1rem 1.15rem;background:#4f46e514;color:var(--text);text-align:left;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.option-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px #4f46e529}.option-card .option-title{font-weight:600;font-size:1rem}.option-card .option-subtitle{font-size:.85rem;color:var(--text-weak)}.option-card.ghost{background:#94a3b81f}.option-card.ghost:hover{box-shadow:0 10px 20px #94a3b82e}.dialog-label{padding:1.4rem 1.5rem .5rem;color:var(--text-weak);font-size:.85rem}#export-textarea{border:none;resize:vertical;min-height:180px;margin:0 1.5rem 1rem;padding:1rem;border-radius:16px;background:#4f46e50f;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;color:var(--text)}#import-textarea{border:none;resize:vertical;min-height:200px;margin:0 1.5rem 1rem;padding:1rem;border-radius:16px;background:#4f46e50f;font-family:JetBrains Mono,Fira Code,monospace;font-size:.9rem;color:var(--text)}#import-textarea:focus{outline:none;box-shadow:0 0 0 2px #4f46e533}.dialog-footer{display:flex;justify-content:flex-end;padding:.75rem 1.5rem 1.5rem}.settings-dialog-body{display:grid;gap:.75rem;padding:1.4rem 1.5rem 1rem}.settings-action{width:100%;border-radius:18px;padding:1rem 1.15rem;background:#4f46e514;color:var(--text);justify-content:flex-start;gap:.85rem;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.settings-toggle{display:flex;align-items:center}.settings-toggle .settings-action-text{flex:1 1 auto}.settings-toggle-control{margin-left:auto}.settings-toggle-control .switch{width:72px;height:28px;min-height:28px}.settings-toggle-note{font-size:.78rem;color:var(--text-weak);margin:0;padding:0 .35rem 0 3.3rem}.settings-action:hover{transform:translateY(-2px);box-shadow:0 12px 24px #4f46e529}.settings-action-text{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.settings-action-title{font-weight:600}.settings-action-subtitle{font-size:.85rem;color:var(--text-weak)}.settings-dialog-footer{justify-content:flex-end}.import-dialog-footer,.reset-dialog-footer{justify-content:space-between;gap:.75rem;flex-wrap:wrap}.reset-dialog-body{padding:1.5rem 1.5rem 1rem}.reset-dialog-body p{margin:0;color:var(--text-weak);line-height:1.6}.completion-dialog-body{display:grid;gap:1.25rem;text-align:center}.confetti-stage{position:relative;height:140px;overflow:hidden}.confetti-piece{position:absolute;top:-10px;width:10px;height:18px;border-radius:4px;background:var(--confetti-color, var(--accent));opacity:0;animation:confetti-fall var(--confetti-duration, 2.6s) ease-out forwards;transform:rotate(var(--confetti-rotate, 0deg));left:var(--confetti-left, 50%);animation-delay:var(--confetti-delay, 0s)}@keyframes confetti-fall{0%{opacity:0;transform:translateY(0) rotate(var(--confetti-rotate, 0deg))}10%{opacity:1}to{opacity:0;transform:translateY(160px) rotate(calc(var(--confetti-rotate, 0deg) + 180deg))}}.completion-message{margin:0;font-size:1rem;color:var(--text-weak)}.completion-summary{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.completion-summary li{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.15rem;border-radius:18px;background:#4f46e514;border:1px solid rgba(79,70,229,.12);font-weight:600}.completion-summary li[data-placement=top]{background:#10b9812e;border-color:#10b9813d}.completion-summary .summary-label{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;font-weight:600}.completion-summary .summary-label span{font-size:.85rem;font-weight:500;color:var(--text-weak)}.completion-summary .summary-label .summary-name{font-size:1rem;font-weight:600;color:var(--text)}.completion-summary .summary-label .summary-detail{font-size:.85rem;font-weight:500;color:var(--text-weak)}.completion-summary .summary-score{font-size:1.1rem}@media (max-width: 1100px){.layout{grid-template-columns:1fr}}@media (max-width: 768px){.app-header{flex-direction:column;align-items:flex-start}.actions{width:100%;justify-content:space-between}table{min-width:100%}}@media (max-width: 520px){.btn-announce,.btn-roll{width:100%}.actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:.75rem;width:100%}.actions .action-button{grid-column:1 / -1;width:100%;justify-content:center}.actions .icon-button{justify-self:start}.actions .switch{justify-self:end;order:initial;margin-left:0}.switch{width:88px;height:32px;min-height:32px}}#score-table thead th svg{height:24px}#score-table thead{position:relative;z-index:2}#score-table thead:after{content:"";position:absolute;inset-inline:0;bottom:-12px;height:12px;pointer-events:none;background:linear-gradient(to bottom,color-mix(in srgb,var(--text) 16%,transparent),transparent);opacity:.4}#score-table thead th{position:-webkit-sticky;position:sticky;top:env(safe-area-inset-top,0px);z-index:3;background:linear-gradient(to bottom,color-mix(in srgb,var(--surface-strong) 82%,transparent),color-mix(in srgb,var(--surface) 72%,transparent));background-color:var(--surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:.8rem;padding:.4rem .35rem;border-bottom:1px solid var(--border)}[data-theme=dark] #score-table th:first-child,#score-table td:first-child,#score-table thead th{background:none;background-color:#0f172a00}@media (max-width: 680px){#score-table th,#score-table td{padding:.45rem .35rem;font-size:.85rem}#score-table th:first-child,#score-table td:first-child{position:-webkit-sticky;position:sticky;left:0;background:linear-gradient(to right,color-mix(in srgb,var(--surface-strong) 88%,transparent),color-mix(in srgb,var(--surface) 72%,transparent));background-color:var(--surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:8px 0 18px #0f172a14;width:34%;min-width:34%;max-width:34%;text-align:left;padding-left:.65rem}#score-table tr.total-row>th:first-child,#score-table tr.total-row>td:first-child{background:inherit;background-color:inherit;-webkit-backdrop-filter:none;backdrop-filter:none}.category-label{align-items:center;gap:.35rem}.category-label .label-content{gap:.15rem}.category-label .label-text{font-size:.92rem}.category-label .label-detail{font-size:.72rem}.category-label.die-only .label-content{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.category-label.die-only{gap:0}.category-label.die-only .die{width:1.9rem;height:1.9rem}#score-table th[data-column],#score-table td[data-column]{width:16.5%;min-width:60px}#score-table td[data-column]{text-align:center}input.score-input{font-size:.82rem;padding:.4rem .25rem;border-radius:10px}}.game-mode-dialog .dialog-content{max-width:500px}.game-mode-selection{display:flex;flex-direction:column;gap:1.5rem}.mode-group{display:flex;flex-direction:column;gap:.75rem}.mode-group h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text)}.mode-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mode-option{position:relative;padding:1.5rem .625rem;background:var(--surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center}.mode-option .score-option.controls-disabled{pointer-events:none;cursor:not-allowed;opacity:.6}.mode-option:hover,.mode-option.selected{border-color:var(--accent);background:var(--accent-muted)}.mode-option.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.mode-option.disabled:hover{border-color:var(--border);background:var(--surface)}.mode-option input[type=radio]{position:absolute;opacity:0;pointer-events:none}.mode-option-icon{font-size:1.5rem;margin-bottom:.25rem}.mode-option-label{font-weight:600;font-size:.8rem;color:var(--text)}.mode-option-description{font-size:.75rem;color:var(--text-weak);margin-top:.15rem}.virtual-dice-container{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background:var(--surface);border-radius:16px;border:1px solid var(--border)}.virtual-dice-container.controls-disabled{opacity:.88;transition:opacity .2s ease}.virtual-dice-container.controls-disabled .die.clickable{cursor:not-allowed;pointer-events:none}.virtual-dice-container.controls-disabled .btn-roll,.virtual-dice-container.controls-disabled .btn-announce,.virtual-dice-container.controls-disabled .score-option{pointer-events:none;cursor:not-allowed;opacity:.6}.virtual-dice-container.controls-disabled .possible-scores,.virtual-dice-container.controls-disabled .scores-header{opacity:.75}.dice-status{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--accent-muted);border-radius:10px;font-size:.9rem}.dice-status strong{color:var(--accent)}.announced{color:var(--text)}.dice-display{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;padding:1rem}#virtual-dice-main-panel .die{position:relative;width:70px;height:70px;background:linear-gradient(145deg,#fff,#e6e9f0);border:2px solid var(--border-strong);border-radius:12px;box-shadow:0 4px 12px #0000001a;transition:all .3s cubic-bezier(.34,1.56,.64,1);cursor:default}[data-theme=dark] .die{background:linear-gradient(145deg,#1e293b,#0f172a)!important}.die.clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.die.clickable:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 16px #4f46e54d}@media (hover: hover) and (pointer: fine){.die.clickable:active{transform:translateY(-2px) scale(1.02);box-shadow:0 4px 8px #4f46e533;transition-duration:.15s}}@keyframes diceTouchBounce{0%{transform:translateY(0) scale(1);box-shadow:0 4px 8px #4f46e526}40%{transform:translateY(-6px) scale(1.08);box-shadow:0 10px 20px #4f46e566}60%{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 16px #4f46e54d}to{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 16px #4f46e54d}}.die.clickable.touch-active{animation:diceTouchBounce .6s cubic-bezier(.34,1.56,.64,1) forwards}.die.locked{background:linear-gradient(145deg,#fef3c7,#fcd34d)!important;border-color:#f59e0b!important;transition:all .4s cubic-bezier(.34,1.56,.64,1)}[data-theme=dark] .die.locked{background:linear-gradient(145deg,#78350f,#451a03)!important;border-color:#f59e0b!important;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.die-face{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.die-dots{display:grid;padding:8px;width:100%;height:100%;align-items:center;justify-items:center}.die-1,.die-2,.die-3{grid-template:1fr 1fr 1fr / 1fr 1fr 1fr}.die-4{grid-template:1fr 1fr / 1fr 1fr}.die-5{grid-template:1fr 1fr 1fr / 1fr 1fr 1fr}.die-6{grid-template:1fr 1fr 1fr / 1fr 1fr}.dot{width:10px;height:10px;background:var(--text);border-radius:50%}[data-theme=dark] .dot{background:var(--text)}.die.locked .dot{background:#92400e}[data-theme=dark] .die.locked .dot{background:#fff}.die-1 .dot:nth-child(1){grid-area:2 / 2}.die-2 .dot:nth-child(1){grid-area:1 / 1}.die-2 .dot:nth-child(2){grid-area:3 / 3}.die-3 .dot:nth-child(1){grid-area:1 / 1}.die-3 .dot:nth-child(2){grid-area:2 / 2}.die-3 .dot:nth-child(3){grid-area:3 / 3}.die-4 .dot:nth-child(1){grid-area:1 / 1}.die-4 .dot:nth-child(2){grid-area:1 / 2}.die-4 .dot:nth-child(3){grid-area:2 / 1}.die-4 .dot:nth-child(4){grid-area:2 / 2}.die-5 .dot:nth-child(1){grid-area:1 / 1}.die-5 .dot:nth-child(2){grid-area:1 / 3}.die-5 .dot:nth-child(3){grid-area:2 / 2}.die-5 .dot:nth-child(4){grid-area:3 / 1}.die-5 .dot:nth-child(5){grid-area:3 / 3}.die-6 .dot:nth-child(1){grid-area:1 / 1}.die-6 .dot:nth-child(2){grid-area:1 / 2}.die-6 .dot:nth-child(3){grid-area:2 / 1}.die-6 .dot:nth-child(4){grid-area:2 / 2}.die-6 .dot:nth-child(5){grid-area:3 / 1}.die-6 .dot:nth-child(6){grid-area:3 / 2}.lock-indicator{position:absolute;top:-8px;right:-8px;font-size:1.2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));z-index:10;pointer-events:none}.dice-controls{display:flex;flex-direction:column;align-items:center;gap:.75rem}.btn-roll{padding:.875rem 2rem;background:linear-gradient(135deg,var(--accent),#6366f1);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #4f46e54d}.btn-roll:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.btn-roll:active:not(:disabled){transform:translateY(0)}.btn-roll:disabled{opacity:.5;cursor:not-allowed}.btn-announce{padding:.75rem 1.5rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #f59e0b4d}.btn-announce:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f59e0b66}.btn-announce:active:not(:disabled){transform:translateY(0)}.btn-announce:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(135deg,#9ca3af,#6b7280)}.announce-prompt{padding:.75rem;text-align:center}.announce-prompt.announce-required{background:#f59e0b1a;border:2px solid rgba(245,158,11,.3);border-radius:8px}.announce-prompt.announce-required p{color:#f59e0b;font-weight:600;margin:0 0 .5rem}.announced{padding:.5rem 1rem;background:#f59e0b33;border:2px solid rgba(245,158,11,.4);border-radius:8px;display:inline-flex;align-items:center;gap:.5rem}.announced strong{color:#f59e0b}.announce-icon{font-size:1.2rem}.dice-hint{margin:0;font-size:.85rem;color:var(--text-weak);text-align:center}.possible-scores{margin-top:1rem}.possible-scores h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text)}.score-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.score-option{padding:.875rem;background:var(--surface-strong);border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:all .2s ease;text-align:center}.score-options.no-animation .score-option,.score-option.no-animation{animation:none!important}.score-option:hover:not(.unavailable){border-color:var(--accent);background:var(--accent-muted);transform:translateY(-2px)}.score-option.unavailable{opacity:.5;cursor:not-allowed}.option-label{font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:.25rem}.option-value{font-size:1.25rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.option-description{font-size:.75rem;color:var(--text-weak)}.option-warning{margin-top:.25rem;font-size:.7rem;color:var(--danger);font-weight:500}.no-options{text-align:center;color:var(--text-weak);font-style:italic;padding:1rem}.virtual-dice-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);margin-bottom:2rem}.virtual-dice-panel .section-header{margin-bottom:1.5rem}#virtual-dice-main-container{min-height:400px}.virtual-dice-panel .virtual-dice-container{border:none;padding:0;background:transparent}@media (max-width: 768px){.dice-display{gap:.75rem}.die{width:60px;height:60px}.dot{width:8px;height:8px}.score-options{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}#virtual-dice-main-container{min-height:350px}}@keyframes diceRoll{0%{transform:rotateX(0) rotateY(0) rotate(0)}25%{transform:rotateX(180deg) rotateY(90deg) rotate(45deg) scale(1.1)}50%{transform:rotateX(270deg) rotateY(180deg) rotate(90deg) scale(1.05)}75%{transform:rotateX(360deg) rotateY(270deg) rotate(135deg) scale(1.1)}to{transform:rotateX(720deg) rotateY(360deg) rotate(180deg) scale(1)}}@-webkit-keyframes diceRoll{0%{-webkit-transform:rotateX(0deg) rotateY(0deg) rotateZ(0deg);transform:rotateX(0) rotateY(0) rotate(0)}25%{-webkit-transform:rotateX(180deg) rotateY(90deg) rotateZ(45deg) scale(1.1);transform:rotateX(180deg) rotateY(90deg) rotate(45deg) scale(1.1)}50%{-webkit-transform:rotateX(270deg) rotateY(180deg) rotateZ(90deg) scale(1.05);transform:rotateX(270deg) rotateY(180deg) rotate(90deg) scale(1.05)}75%{-webkit-transform:rotateX(360deg) rotateY(270deg) rotateZ(135deg) scale(1.1);transform:rotateX(360deg) rotateY(270deg) rotate(135deg) scale(1.1)}to{-webkit-transform:rotateX(720deg) rotateY(360deg) rotateZ(180deg) scale(1);transform:rotateX(720deg) rotateY(360deg) rotate(180deg) scale(1)}}@keyframes diceSettleStay{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@-webkit-keyframes diceSettleStay{0%,to{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.08);transform:scale(1.08)}}@keyframes diceSettleUnlock{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@-webkit-keyframes diceSettleUnlock{0%,to{-webkit-transform:scale(1);transform:scale(1)}50%{-webkit-transform:scale(1.05);transform:scale(1.05)}}.die.rolling{animation:diceRoll .6s cubic-bezier(.25,.46,.45,.94);-webkit-animation:diceRoll .6s cubic-bezier(.25,.46,.45,.94);transform-origin:center center;will-change:transform}.die.settling-stay{animation:diceSettleStay .3s ease-out;-webkit-animation:diceSettleStay .3s ease-out;will-change:transform}.die.settling-unlock{animation:diceSettleUnlock .3s ease-out;-webkit-animation:diceSettleUnlock .3s ease-out;will-change:transform}.score-option{animation:fadeInUp .3s ease-out backwards}.score-option:nth-child(1){animation-delay:.05s}.score-option:nth-child(2){animation-delay:.1s}.score-option:nth-child(3){animation-delay:.15s}.score-option:nth-child(4){animation-delay:.2s}.score-option:nth-child(5){animation-delay:.25s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.scores-controls{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.btn-sort,.btn-toggle-zeros{padding:.4rem .8rem;font-size:.85rem;background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;color:var(--text);cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-sort:hover,.btn-toggle-zeros:hover{background:var(--accent-muted);border-color:var(--accent);transform:translateY(-1px)}.btn-sort.active,.btn-toggle-zeros.active{background:var(--accent);color:#fff;border-color:var(--accent)}.no-visible-options{text-align:center;padding:2rem 1rem}.no-visible-options .btn-toggle-zeros{margin-top:1rem}.virtual-announce-dialog .dialog-body{min-width:320px}.dialog-instructions{margin:0 0 1rem;color:var(--text-weak);font-size:.95rem}.announce-category-list{display:flex;flex-direction:column;gap:.5rem;max-height:280px;overflow-y:auto}@media (min-width: 768px){.announce-category-list{max-height:unset;overflow-y:unset}}.announce-category-option{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--surface);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:1rem;font-family:inherit;text-align:left}.announce-category-option:hover{background:var(--accent-muted);border-color:var(--accent);transform:translate(4px)}.announce-category-option:active{transform:translate(2px)}.announce-category-option .category-name{font-weight:600;color:var(--text)}.announce-category-option .category-icon{font-size:1.2rem;opacity:.6;transition:opacity .2s ease}.announce-category-option:hover .category-icon{opacity:1}.confirm-dialog .dialog-body{min-width:320px}.confirm-dialog .dialog-message{margin:0;font-size:1rem;color:var(--text);line-height:1.5}.confirm-dialog .dialog-message strong{color:var(--accent);font-weight:600}.confirm-dialog .dialog-warning{margin:.5rem 0 0;padding:.75rem 1rem;background:#f59e0b1a;border-left:3px solid #f59e0b;border-radius:4px;font-size:.9rem;color:var(--text-weak);line-height:1.5}.back-to-dice-fab{position:fixed;bottom:20px;right:20px;z-index:1000;display:none;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,var(--accent),#6366f1);color:#fff;border:none;border-radius:50px;box-shadow:0 8px 24px #4f46e566;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-weight:600;font-size:.95rem;font-family:inherit;animation:fabSlideIn .4s cubic-bezier(.34,1.56,.64,1)}.back-to-dice-fab.visible{display:flex}.back-to-dice-fab svg{width:24px;height:24px;flex-shrink:0}.back-to-dice-fab:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 32px #4f46e580}.back-to-dice-fab:active{transform:translateY(-2px) scale(1.02)}@keyframes fabSlideIn{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@media (min-width: 769px){.back-to-dice-fab{display:none!important}}@media (max-width: 768px){.back-to-dice-fab{bottom:16px;left:16px;padding:.75rem 1rem;font-size:.875rem}.back-to-dice-fab svg{width:20px;height:20px}.winner-subheading{font-size:1.1rem;color:var(--text-weak);margin:0 0 1.5rem}.fab-label{display:inline}}@media (max-width: 520px){.back-to-dice-fab{bottom:12px;left:12px;padding:.65rem .875rem}.fab-label{display:none}.back-to-dice-fab{width:56px;height:56px;padding:0;border-radius:50%;justify-content:center}}.online-lobby-dialog{max-width:500px;width:90%;padding:0;border:none;border-radius:20px;background:var(--surface);box-shadow:var(--shadow);position:relative}.online-lobby-dialog::backdrop{background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.online-lobby-dialog .dialog-content{padding:2rem}.online-lobby-dialog .dialog-title{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text);text-align:center;font-weight:600;padding:0 2rem}.dialog-close-btn{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:none;background:var(--surface);color:var(--text-weak);font-size:2rem;line-height:1;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.dialog-close-btn:hover{background:var(--border);color:var(--text);transform:rotate(90deg)}.lobby-section{padding:.5rem 0}.lobby-description{text-align:center;color:var(--text-weak);margin-bottom:1.5rem;font-size:.95rem;line-height:1.5}.lobby-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-large{padding:1rem 1.5rem;font-size:1rem;font-weight:600}.btn-icon{margin-right:.5rem;font-size:1.2em}.btn-back{background:none;border:none;color:var(--accent);font-size:.9rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem;display:inline-flex;align-items:center;gap:.25rem;font-weight:500;transition:all .2s}.btn-back:hover{color:var(--text);transform:translate(-4px)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text);font-size:.9rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid var(--border);border-radius:12px;font-size:1rem;background:var(--surface);color:var(--text);transition:all .2s;font-family:inherit}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.room-code-input{font-family:Courier New,monospace;font-size:1.3rem;text-align:center;letter-spacing:.3em;text-transform:uppercase;font-weight:700}.error-message{background:#dc26261a;border:1px solid rgba(220,38,38,.3);color:var(--danger);padding:.875rem 1rem;border-radius:12px;margin-top:1rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.error-message:before{content:"⚠️";font-size:1.2em}.room-code-display{background:linear-gradient(135deg,var(--accent-muted),rgba(79,70,229,.08));border:2px solid var(--accent);border-radius:16px;padding:1.75rem;text-align:center;margin-bottom:1.5rem;position:relative;overflow:hidden}.room-code-display:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 3s infinite}@keyframes shimmer{to{left:100%}}.room-code-label{font-size:.8rem;color:var(--text-weak);margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.room-code-value{font-family:Courier New,monospace;font-size:2.25rem;font-weight:700;color:var(--accent);letter-spacing:.4em;margin-bottom:1rem;text-shadow:0 2px 4px rgba(79,70,229,.2)}.room-code-display .btn{margin:.25rem;min-width:100px}.room-code-display .btn-small{padding:.5rem 1rem;font-size:.9rem}.players-list{margin-bottom:1.5rem}.players-list h4{margin:0 0 1rem;font-size:.9rem;color:var(--text-weak);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.player-item{display:flex;align-items:center;padding:.875rem 1.25rem;background:var(--surface);border:2px solid var(--border);border-radius:12px;margin-bottom:.625rem;transition:all .2s}.player-item:hover{border-color:var(--border-strong);transform:translate(4px)}.player-item.player-host{background:var(--accent-muted);border-color:var(--accent)}.player-name{flex:1;font-weight:600;font-size:1rem}.player-badge{background:var(--accent);color:#fff;font-size:.7rem;padding:.3rem .6rem;border-radius:6px;margin-left:.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.player-status{margin-left:.75rem;font-size:1rem}.waiting-actions{display:flex;flex-direction:column;gap:.75rem}.waiting-message{text-align:center;color:var(--text-weak);font-style:italic;margin-top:1.25rem;font-size:.9rem;padding:1rem;background:var(--accent-muted);border-radius:12px;border:1px dashed var(--accent)}.lobby-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;position:absolute;inset:0;background:var(--surface);border-radius:20px;z-index:100}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lobby-loading p{margin-top:1.5rem;color:var(--text-weak);font-weight:500}.turn-indicator{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:.75rem 1.5rem;border-radius:50px;font-weight:600;font-size:.95rem;z-index:9999;box-shadow:0 4px 12px #00000026;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;gap:.75rem}.turn-indicator.my-turn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;animation:pulse 2s infinite}.turn-indicator.their-turn{background:var(--surface);border:2px solid var(--border);color:var(--text-weak)}.turn-indicator.offline{background:var(--surface);border:2px solid var(--danger);color:var(--danger);box-shadow:0 4px 18px #dc26264d;animation:pulse-offline 1.8s infinite}.turn-indicator-text{white-space:nowrap}.turn-indicator-retry{background:transparent;border:1px solid currentColor;color:inherit;padding:.35rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease}.turn-indicator-retry:hover:not(:disabled){background:var(--danger);color:#fff}.turn-indicator-retry:disabled{opacity:.6;cursor:not-allowed}@keyframes pulse{0%,to{box-shadow:0 4px 12px #10b9814d}50%{box-shadow:0 4px 20px #10b98199}}@keyframes pulse-offline{0%,to{box-shadow:0 4px 14px #dc262633}50%{box-shadow:0 4px 26px #dc262680}}.virtual-dice-panel.disabled{position:relative}.virtual-dice-panel.disabled:after{display:none}.toast{position:fixed;bottom:20px;right:20px;padding:1rem 1.5rem;border-radius:12px;font-weight:500;font-size:.9rem;z-index:2000;box-shadow:0 4px 12px #00000026;transform:translateY(100px);opacity:0;transition:all .3s ease}.toast.show{transform:translateY(0);opacity:1}.toast-info{background:var(--accent);color:#fff}.toast-success{background:#10b981;color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-warning{background:#f59e0b;color:#fff}.scorecard-switcher{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background:var(--surface-alt);border-radius:12px;margin-bottom:1.5rem;border:2px solid var(--border)}.switcher-label{font-weight:600;color:var(--text-weak);font-size:.9rem}.switcher-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.switcher-btn{padding:.6rem 1.2rem;border:2px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.switcher-btn:hover{background:var(--surface-hover);border-color:var(--accent);transform:translateY(-2px)}.switcher-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.switcher-btn.my-scorecard{border-color:var(--accent)}@media (max-width: 640px){.scorecard-switcher{flex-direction:column;align-items:stretch;text-align:center;gap:.75rem}.switcher-label{margin-bottom:.25rem}.switcher-buttons{justify-content:center;width:100%}}.scorecard.opponent-view .cell{cursor:not-allowed}.scorecard.opponent-view .cell:hover{transform:none}.scorecard.opponent-view .cell.filled{background:var(--surface-alt);border-color:var(--border)}.reconnect-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .3s ease}.reconnect-content{background:var(--surface);padding:2rem;border-radius:20px;text-align:center;max-width:400px;box-shadow:0 20px 60px #00000080}.reconnect-content h2{font-size:1.8rem;color:var(--accent);margin-bottom:1rem}.reconnect-content p{font-size:1.1rem;margin-bottom:1.5rem;color:var(--text-muted)}.game-info{background:var(--surface-alt);padding:1rem;border-radius:12px;margin-bottom:1.5rem;font-size:.9rem;color:var(--text-muted)}.game-info div{margin:.5rem 0}.reconnect-actions{display:flex;gap:1rem}.btn-rejoin,.btn-new-game{flex:1;padding:1rem;font-size:1.1rem;font-weight:600;border-radius:12px;border:none;cursor:pointer;transition:transform .2s,opacity .2s}.btn-rejoin{background:var(--accent);color:#fff}.btn-new-game{background:var(--surface-alt);color:var(--text);border:2px solid var(--border)}.btn-rejoin:hover,.btn-new-game:hover{transform:translateY(-2px);opacity:.9}.winner-modal{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .5s ease}.winner-content{background:var(--surface);padding:3rem;border-radius:20px;text-align:center;max-width:500px;box-shadow:0 20px 60px #00000080;position:relative;z-index:10001}.winner-content h1{font-size:2.2rem;margin-bottom:.5rem;color:var(--text)}.winner-subheading{font-size:1.1rem;color:var(--text-weak);margin:0 0 1.5rem}.winner-name{font-size:2.5rem;color:var(--accent);margin:1rem 0 2rem;text-shadow:0 2px 10px rgba(139,92,246,.3)}.final-scores{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}.player-score{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--surface-alt);border-radius:12px;border:2px solid var(--border);transition:transform .2s}.player-score.winner{border-color:var(--accent);background:linear-gradient(135deg,#8b5cf61a,#8b5cf60d);transform:scale(1.02)}.player-rank{font-size:2rem;min-width:3rem}.player-info{flex:1;text-align:left}.player-name{font-size:1.3rem;font-weight:600;color:var(--text)}.player-breakdown{font-size:.85rem;color:var(--text-weak);margin-top:.25rem;display:flex;flex-wrap:wrap;gap:.4rem}.player-results{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;min-width:5rem}.player-total{font-size:2rem;font-weight:700;color:var(--accent);min-width:4rem;text-align:right}.player-diff{font-size:.85rem;color:var(--text-weak)}.winner-actions{display:flex;gap:1rem;margin-top:2rem}.btn-lobby{flex:1;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:12px;border:2px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;transition:transform .2s,opacity .2s}.btn-lobby:hover{transform:translateY(-2px);opacity:.9}.confetti{position:fixed;width:10px;height:10px;background:var(--accent);animation:confetti-fall 3s linear forwards;z-index:9999;top:-10px}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.virtual-dice-container.rolling .die{animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0) rotate(0)}10%,30%,50%,70%,90%{transform:translate(-2px) rotate(-5deg)}20%,40%,60%,80%{transform:translate(2px) rotate(5deg)}}.scorecard .recent-score,.score-input.recent-score{animation:scoreHighlight 2s ease}@keyframes scoreHighlight{0%,to{background:var(--surface-alt);box-shadow:none}50%{background:#8b5cf633;box-shadow:0 0 20px #8b5cf666}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
