#auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;overflow:hidden;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#16213e,#0f3460 60%,#1a1a2e)}#auth-overlay.hidden{display:none!important}.auth-card{background:var(--glass-strong);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:22px;padding:2.5rem 2.8rem;width:min(420px,92vw);display:flex;flex-direction:column;gap:1.1rem;text-align:center;box-shadow:0 24px 64px #0000008c;animation:card-enter .45s cubic-bezier(.34,1.56,.64,1) both}@keyframes card-shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(7px)}45%{transform:translate(-6px)}60%{transform:translate(5px)}75%{transform:translate(-3px)}}.auth-card.shake{animation:card-shake .45s ease both}.auth-tabs{display:flex;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}.auth-tab{flex:1;padding:.6rem;background:transparent;border:none;color:#f0e6d380;cursor:pointer;font-size:.9rem;transition:background .2s,color .2s}.auth-tab.active{background:#ffd70026;color:gold;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-form input{padding:.75rem 1rem;border-radius:10px;border:1.5px solid rgba(255,255,255,.18);background:#ffffff12;color:#f0e6d3;font-family:Space Grotesk,sans-serif;font-size:.92rem;letter-spacing:.01em;outline:none;transition:border-color .2s}.auth-form input:focus{border-color:gold}.auth-form button[type=submit]{margin-top:.2rem;padding:.8rem;background:linear-gradient(135deg,gold,#f0a500);border:none;border-radius:10px;color:#1a1a2e;font-weight:700;font-size:1rem;cursor:pointer;transition:opacity .2s,transform .1s}.auth-form button[type=submit]:hover{opacity:.9}.auth-form button[type=submit]:active{transform:scale(.98)}.auth-form button:disabled{opacity:.5;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:.75rem;color:#ffffff40;font-size:.75rem;letter-spacing:.05em;margin:.25rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.btn-ghost{background:#ffd7000f;border:1.5px solid rgba(255,215,0,.4);border-radius:10px;padding:.7rem 1rem;color:#ffd700d9;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s;letter-spacing:.01em}.btn-ghost:hover{background:#ffd7001f;border-color:gold;color:gold}#btn-guest{width:100%;padding:.65rem 1.2rem;border:1px solid rgba(255,215,0,.4);border-radius:10px;background:#ffd7000f;color:#ffd700e6;font-weight:600;font-size:.88rem;letter-spacing:.03em;cursor:pointer;transition:background .18s,border-color .18s;display:flex;align-items:center;justify-content:center;gap:.5rem}#btn-guest:before{content:"→";font-size:1rem}#btn-guest:hover{background:#ffd7001f;border-color:#ffd700a6}.lobby-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.4rem}.btn-icon{background:transparent;border:none;font-size:1.3rem;cursor:pointer;padding:.2rem .4rem;border-radius:8px;transition:background .2s}.btn-icon:hover{background:#ffffff1a}.btn-icon--right{margin-left:auto}.side-panel{position:fixed;top:0;right:0;bottom:0;z-index:500;width:min(340px,100vw);background:var(--glass-strong);border-left:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;padding:1.5rem;gap:1rem;box-shadow:-8px 0 32px #0006;animation:slideIn .32s cubic-bezier(.34,1.2,.64,1) both}@keyframes slideIn{0%{transform:translate(100%);opacity:.6}to{transform:translate(0);opacity:1}}.side-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:499;background:#00000059;animation:backdrop-in .25s ease both}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.side-panel-header{display:flex;align-items:center;justify-content:space-between}.side-panel-header h3{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:.03em;color:gold}.btn-close{background:transparent;border:none;color:#f0e6d380;font-size:1rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;transition:color .2s}.btn-close:hover{color:#f0e6d3}.leaderboard-tabs{display:flex;gap:.4rem;flex-wrap:wrap}.lb-tab{flex:1;padding:.4rem;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:transparent;color:#f0e6d38c;font-size:.78rem;cursor:pointer;transition:background .2s,color .2s}.lb-tab.active{background:#ffd70026;color:gold;border-color:#ffd7004d}.leaderboard-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;flex:1}.lb-row{display:flex;align-items:center;gap:.6rem;background:#ffffff0d;border-radius:10px;padding:.6rem .8rem;font-size:.88rem}.lb-rank{font-size:1.1rem;min-width:1.8rem}.lb-name{flex:1;font-weight:600;font-size:.88rem}.lb-wins{color:gold;font-size:.75rem;opacity:.65}.lb-games{color:#f0e6d366;font-size:.75rem;opacity:.65}.lb-loading,.lb-empty{text-align:center;color:#f0e6d359;padding:1.5rem 0;font-size:.88rem}#profile-content{flex:1;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;overflow-x:hidden;min-height:0;margin-right:-1.5rem;padding-right:1.5rem;scrollbar-width:thin;scrollbar-color:rgba(255,215,0,.25) transparent}#profile-content::-webkit-scrollbar{width:4px}#profile-content::-webkit-scrollbar-track{background:transparent}#profile-content::-webkit-scrollbar-thumb{background:#ffd70040;border-radius:99px}#profile-content::-webkit-scrollbar-thumb:hover{background:#ffd70080}.profile-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:16px}.profile-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;color:#1a1a2e;flex-shrink:0;box-shadow:0 0 0 3px #ffffff1f}.profile-header-name{font-size:1.05rem;font-weight:700;color:#f0e6d3;line-height:1.2}.profile-header-meta{font-size:.75rem;color:#f0e6d366;margin-top:.2rem}.profile-section{display:flex;flex-direction:column;gap:.55rem;padding:.9rem 1.4rem .9rem 1.1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px}.profile-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffd70099}.profile-username-row{display:flex;gap:.5rem}.profile-username-input{flex:1;min-width:0;padding:.5rem .75rem;border-radius:9px;border:1.5px solid rgba(255,255,255,.12);background:#ffffff0f;color:#f0e6d3;font-size:.9rem;outline:none;transition:border-color .2s;font-family:Space Grotesk,sans-serif}.profile-username-input:focus{border-color:#ffd70099}.btn-save-username{padding:.5rem .9rem;border-radius:9px;border:none;background:linear-gradient(135deg,gold,#f0a500);color:#1a1a2e;font-weight:700;font-size:.85rem;cursor:pointer;white-space:nowrap;transition:opacity .2s}.btn-save-username:disabled{opacity:.3;cursor:default}.btn-save-username:hover:not(:disabled){opacity:.85}.profile-username-error{font-size:.76rem;color:#ff6b6b;min-height:1em}.player-name-badge{padding:.65rem 1rem;border-radius:10px;background:#ffd7001a;border:1.5px solid rgba(255,215,0,.3);color:gold;font-weight:700;font-size:1rem;text-align:center;letter-spacing:.02em}.profile-stats{display:flex;flex-direction:column;gap:.35rem}.profile-stat-row{display:flex;align-items:center;gap:.75rem;padding:.45rem .1rem;border-bottom:1px solid rgba(255,255,255,.04)}.profile-stat-row:last-child{border-bottom:none}.profile-stat-mode{display:flex;align-items:center;gap:.4rem;width:72px;flex-shrink:0}.profile-stat-icon{font-size:1rem;line-height:1}.profile-stat-label{font-size:.8rem;font-weight:600;color:#f0e6d3cc}.profile-stat-right{flex:1;display:flex;flex-direction:column;gap:.2rem}.profile-stat-nums{display:flex;justify-content:space-between;font-size:.72rem;color:#ffffff73}.profile-stat-best{color:#ffd700a6}.skin-preview-canvas{width:140px;height:140px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);display:block;margin:0 auto}.profile-skin-swatches{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}.btn-save-skin{padding:.55rem 1.8rem;background:linear-gradient(135deg,gold,#f0a500);border:none;border-radius:10px;color:#1a1a2e;font-weight:700;font-size:.9rem;cursor:pointer;transition:opacity .2s,transform .1s;align-self:center}.btn-save-skin:hover:not(:disabled){opacity:.85}.btn-save-skin:active:not(:disabled){transform:scale(.97)}.btn-save-skin:disabled{opacity:.3;cursor:default}:root{--glass-bg: rgba(255,248,220,.04);--glass-border: rgba(255,215,0,.12);--glass-strong: rgba(255,248,220,.08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Space Grotesk,system-ui,sans-serif;background:#0d0e1f;color:#f0e6d3;height:100dvh;overflow:hidden;-webkit-user-select:none;user-select:none}.hidden{display:none!important}.error{color:#ff6b6b;font-size:.85rem;min-height:1.2em;margin-top:.4rem}#lobby,#waiting-room{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;height:100dvh;background:radial-gradient(ellipse at center,#16213e,#0f3460 60%,#1a1a2e)}.lobby-card{background:var(--glass-strong);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:22px;padding:2.2rem 2.6rem;width:min(420px,92vw);display:flex;flex-direction:column;gap:1.1rem;text-align:center;box-shadow:0 24px 72px #0000008c;animation:card-enter .45s cubic-bezier(.34,1.56,.64,1) both}@keyframes card-enter{0%{transform:translateY(28px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.logo{display:flex;align-items:center;justify-content:center;gap:.65rem}.logo-title{font-family:var(--font-title, "Syne", sans-serif);font-weight:800;font-size:clamp(1.6rem,4vw,2.2rem);letter-spacing:.04em;text-transform:uppercase;color:gold;text-shadow:0 2px 20px rgba(255,215,0,.45)}.logo-die{width:2.6rem;height:2.6rem;flex-shrink:0;filter:drop-shadow(0 2px 8px rgba(255,215,0,.5))}@keyframes die-face-cycle{0%,3%{opacity:0}6%,13%{opacity:1}16%,to{opacity:0}}.die-face{opacity:0;animation:die-face-cycle 6s infinite both;animation-delay:calc(var(--di) * 1s)}.lobby-card input[type=text]{padding:.75rem 1rem;border-radius:10px;border:1.5px solid rgba(255,255,255,.2);background:#ffffff14;color:#f0e6d3;font-size:1rem;outline:none;transition:border-color .2s}.lobby-card input[type=text]:focus{border-color:gold}.lobby-actions{display:flex;flex-direction:column;gap:.8rem}.join-row{display:flex;gap:.5rem}.join-row input{flex:1;text-transform:uppercase;letter-spacing:.12em}#btn-create{padding:.9rem 1.4rem;background:linear-gradient(135deg,gold,#f0a500);color:#1a1a2e;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;border-radius:12px;box-shadow:0 4px 22px #ffd70047;transition:transform .15s,box-shadow .15s}#btn-create:hover{transform:translateY(-2px);box-shadow:0 8px 28px #ffd70066}#btn-create:active{transform:translateY(0)}#btn-join{background:transparent;border:1.5px solid rgba(255,215,0,.45);color:#ffd700d9;font-family:Space Grotesk,sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;border-radius:10px;transition:background .18s,border-color .18s,color .18s}#btn-join:hover{background:#ffd7001a;border-color:gold;color:gold}button{padding:.75rem 1.4rem;border-radius:10px;border:none;background:gold;color:#1a1a2e;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ffd70059}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.45;cursor:default}.copy-btn{background:none;border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#fff9;font-size:1rem;padding:2px 7px;cursor:pointer;line-height:1;transition:color .15s,border-color .15s,background .15s}.copy-btn:hover{color:#fff;border-color:#fff9;background:#ffffff14}.copy-btn.copied{color:#4caf50;border-color:#4caf50}.btn-share{width:100%;margin-top:.5rem;padding:.5rem 1rem;background:#ffffff12;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fffc;font-size:.9rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.btn-share:hover{background:#ffffff21;color:#fff;border-color:#ffffff80}.btn-share.copied{color:#4caf50;border-color:#4caf50}.waiting-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.waiting-title{font-family:Syne,sans-serif;font-size:1.3rem;font-weight:700;letter-spacing:.03em;color:#ffffffd9}.room-code-display{display:flex;align-items:center;gap:.5rem}.room-code-display span{font-family:Space Grotesk,monospace;font-weight:800;font-size:1.6rem;color:gold;letter-spacing:.15em;text-shadow:0 0 12px rgba(255,215,0,.35)}#player-list{list-style:none;display:flex;flex-direction:column;gap:.45rem;text-align:left}#player-list li{background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.55rem .85rem;display:flex;align-items:center;gap:.7rem;animation:player-join .3s cubic-bezier(.34,1.56,.64,1) both}@keyframes player-join{0%{transform:translate(-14px);opacity:0}to{transform:translate(0);opacity:1}}#player-list li:before{display:none}.player-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:#1a1a2e;flex-shrink:0;letter-spacing:0}.player-name-text{font-weight:600;font-size:.9rem;color:#f0e6d3}.player-name-you{font-size:.72rem;color:#ffd700b3;margin-left:.3rem;font-weight:500}.player-offline{opacity:.45}.player-disc-dot{width:7px;height:7px;border-radius:50%;background:#4caf50;margin-left:auto;flex-shrink:0}.player-disc-dot.offline{background:#ff6b6b}.skin-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;margin-bottom:.6rem}.skin-swatches{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.skin-swatch{width:44px;height:44px;border-radius:10px;border:2px solid transparent;cursor:pointer;position:relative;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center}.skin-swatch:after{content:"";width:10px;height:10px;border-radius:50%;background:var(--dot-color);box-shadow:0 1px 3px #0006}.skin-swatch:hover{transform:scale(1.12);box-shadow:0 4px 14px #0006}.skin-swatch.selected{border-color:#fff;box-shadow:0 0 0 3px #ffffff40,0 4px 14px #0006;transform:scale(1.12)}.skin-swatch-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#000c;color:#fff;font-size:.72rem;padding:3px 8px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s}.skin-swatch:hover .skin-swatch-tooltip{opacity:1}.skin-swatch.locked{opacity:.35;cursor:not-allowed;filter:grayscale(.6)}.skin-swatch.locked:before{content:"🔒";position:absolute;font-size:.8rem;line-height:1;z-index:1}.skin-swatch.locked:hover{transform:none;box-shadow:none}.ach-count{font-weight:700;color:#ffd700b3;margin-left:.4rem;font-size:.8rem}.profile-achievements-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.35rem;overflow:visible}.ach-badge{display:flex;flex-direction:column;align-items:center;gap:.18rem;padding:.5rem .2rem .45rem;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);text-align:center;opacity:.28;filter:grayscale(1);transition:opacity .25s,filter .25s,background .25s,border-color .25s;cursor:default;position:relative}.ach-global-tooltip{position:fixed;background:#1e1e2e;border:1px solid rgba(255,215,0,.35);color:#f0e6d3f2;font-size:.72rem;line-height:1.3;padding:.35rem .65rem;border-radius:7px;white-space:nowrap;pointer-events:none;z-index:9999;box-shadow:0 4px 14px #00000080;display:none;transition:opacity .12s}.ach-badge.unlocked{opacity:1;filter:none;background:#ffd70012;border-color:#ffd70040}.ach-badge.unlocked:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(255,215,0,.12) 0%,transparent 70%);pointer-events:none}.ach-icon{font-size:1.25rem;line-height:1}.ach-name{font-size:.58rem;font-weight:600;color:#ffffffb3;line-height:1.2}.achievement-toast{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;align-items:center;gap:12px;padding:14px 18px;background:#060816f5;border:1px solid rgba(255,215,0,.45);border-radius:14px;box-shadow:0 4px 24px #0000008c,0 0 0 1px #ffd7001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:toastSlideIn .4s cubic-bezier(.34,1.56,.64,1) forwards;max-width:300px;cursor:pointer;will-change:transform,opacity}.achievement-toast.hiding{animation:toastSlideOut .3s ease forwards}.achievement-toast-icon{font-size:2rem;line-height:1;flex-shrink:0}.achievement-toast-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffd700d9;margin-bottom:2px}.achievement-toast-name{font-size:.95rem;font-weight:700;color:#fff}.achievement-toast-desc{font-size:.75rem;color:#ffffff8c;margin-top:1px}@keyframes toastSlideIn{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(110%);opacity:0}}#game{position:relative;width:100vw;height:100dvh;overflow:hidden}#three-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}#score-panel{position:absolute;top:0;left:0;width:clamp(220px,22vw,340px);height:100%;background:#060816e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-right:1px solid rgba(255,255,255,.08);z-index:30;display:flex;flex-direction:column;overflow:hidden;box-shadow:4px 0 32px #0006}#players-tabs{display:none}#scorecard{flex:1;overflow-y:auto;overflow-x:hidden}#scorecard::-webkit-scrollbar{width:4px}#scorecard::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.score-table{display:grid;width:100%;min-height:100%}.score-header-row{display:contents}.score-header-cell{position:sticky;top:0;z-index:2;background:#060a1afa;padding:10px 4px 8px;text-align:center;font-size:.7rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:2px solid rgba(255,255,255,.08)}.score-header-cell:first-child{text-align:left;padding-left:8px;color:#ffffff59;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase}.score-header-cell.current-player{border-bottom-color:var(--skin-color, #ffd700);color:var(--skin-color, #ffd700);background:#ffd7000a}.score-header-cell{display:flex;flex-direction:column;align-items:center;gap:3px;padding-top:6px;padding-bottom:6px}.score-header-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;flex-shrink:0;transition:box-shadow .3s,transform .3s}.score-header-avatar.current{box-shadow:0 0 0 2.5px #fff9,0 0 14px #ffd70073;transform:scale(1.08)}.score-header-name{font-size:.72rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.score-header-cell .player-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--skin-color, #ffd700);margin-right:4px;vertical-align:middle;animation:dot-pulse 1.4s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}.score-section-row{display:contents}.score-section-cell{font-size:.58rem;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;padding:6px 8px 2px;background:#ffffff05}.score-section-cell:not(:first-child){border-bottom:none}.score-data-row{display:contents}.score-data-row:hover .score-cell:not(.bonus-label-cell):not(.bonus-value-cell){background:#ffffff0a}.score-cell{padding:6px 4px;font-size:.75rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.04);transition:background .12s;display:flex;align-items:center;justify-content:center;min-height:30px}.score-cell:first-child{text-align:left;justify-content:flex-start;padding-left:10px;color:#fffc;font-size:.73rem}.score-cell.scored{color:#ffffff80}.score-cell.scored span{font-weight:700;color:gold}.score-cell.available{cursor:pointer;background:#ffd7000f}.score-cell.available:hover{background:#ffd70033;color:gold}.score-cell.available span{font-size:.7rem;color:#ffd700bf;font-weight:700}.score-cell.empty{color:#fff3}.score-total-row{display:contents}.score-total-cell{padding:5px 4px;font-size:.72rem;font-weight:700;text-align:center;color:gold;border-top:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}.score-total-cell:first-child{text-align:left;justify-content:flex-start;padding-left:8px;font-size:.68rem;color:#ffffff80;font-weight:600}.bonus-label-cell{color:#ffffff8c!important;font-style:italic;background:#4caf500f!important;border-top:1px dashed rgba(76,175,80,.25)!important;border-bottom:1px dashed rgba(76,175,80,.25)!important;cursor:default!important}.bonus-value-cell{background:#4caf500f!important;border-top:1px dashed rgba(76,175,80,.25)!important;border-bottom:1px dashed rgba(76,175,80,.25)!important;cursor:default!important;font-size:.7rem;color:#ffffff59}.bonus-value-cell{color:#ffffff40}.bonus-value-cell.bonus-earned{color:#4caf50;font-weight:800}#turn-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:8px 20px 8px 8px;border-radius:999px;background:#060818d6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,255,255,.13);box-shadow:0 6px 32px #0000008c,0 1px #ffffff12 inset;pointer-events:none;z-index:10;transition:border-color .4s,box-shadow .4s;white-space:nowrap}#turn-banner.my-turn{border-color:#ffd7008c;box-shadow:0 6px 32px #ffd70040,0 0 0 2px #ffd7001a;animation:banner-pulse 2s ease-in-out infinite}@keyframes banner-pulse{0%,to{box-shadow:0 6px 32px #ffd70040,0 0 0 2px #ffd7001a}50%{box-shadow:0 6px 42px #ffd70080,0 0 0 4px #ffd70033}}@keyframes banner-enter{0%{transform:translate(-50%) translateY(-18px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}#turn-banner.banner-change{animation:banner-enter .4s cubic-bezier(.34,1.56,.64,1) both}#turn-banner.my-turn.banner-change{animation:banner-enter .4s cubic-bezier(.34,1.56,.64,1) both,banner-pulse 2s ease-in-out infinite .4s}#turn-avatar{width:44px;height:44px;border-radius:50%;border:2.5px solid rgba(255,255,255,.25);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;letter-spacing:0;color:#000c;box-shadow:0 2px 10px #0006}#turn-label{display:flex;flex-direction:column;gap:2px}#turn-label .banner-player{font-size:1rem;font-weight:700;color:#fff;letter-spacing:.01em;line-height:1.1}#turn-label .banner-player em{font-style:normal;font-weight:800;color:gold}#turn-label .banner-sub{font-size:.7rem;font-weight:500;color:#ffffff73;letter-spacing:.02em}#turn-label>em{font-style:normal;font-weight:800;color:gold}.turn-mode-badge{font-size:.62rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#fff6;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:2px 8px;margin-left:4px}#hud{position:absolute;bottom:0;left:0;right:0;height:100px;display:flex;align-items:center;justify-content:center;gap:1.6rem;background:linear-gradient(to top,rgba(3,5,16,.92) 0%,rgba(3,5,16,.6) 55%,transparent 100%);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:20;padding:0 240px 0 230px}#roll-info{display:flex;flex-direction:column;align-items:center;gap:7px}#current-player-name{font-weight:700;font-size:1rem;color:gold;letter-spacing:.01em;text-shadow:0 0 14px rgba(255,215,0,.3)}#roll-pips{display:flex;gap:6px;align-items:center}.roll-pip{width:14px;height:14px;border-radius:4px;border:2px solid rgba(255,255,255,.3);background:transparent;transition:background .25s,border-color .25s,transform .2s,box-shadow .25s}.roll-pip.active{background:#fffffff2;border-color:#fffffff2;transform:scale(1.1);box-shadow:0 0 8px #ffffff80}#rolls-left{font-size:.72rem;color:#ffffff73;letter-spacing:.03em}#btn-roll{font-size:1.15rem;padding:0 2.6rem;height:52px;border-radius:16px;background:linear-gradient(135deg,gold,#ffb300 60%,#ff9500);color:#1a1a2e;font-weight:800;box-shadow:0 4px 28px #ffd70073,0 2px #ffffff4d inset;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none;letter-spacing:.04em;transition:transform .12s,box-shadow .15s,background .2s}#btn-roll:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 8px 36px #ffd7008c,0 2px #ffffff4d inset}#btn-roll:not(:disabled):active{transform:translateY(0) scale(.97);box-shadow:0 2px 14px #ffd7004d}#btn-roll:after{content:"";position:absolute;bottom:0;left:0;height:4px;width:calc(var(--charge-pct, 0) * 100%);background:linear-gradient(90deg,#22c55e,#eab308,#ef4444);transition:none;border-radius:0 0 14px 14px}#btn-roll:disabled{background:linear-gradient(135deg,#3a3a4a,#2a2a3a);color:#ffffff47;box-shadow:none;cursor:not-allowed;opacity:.6}#btn-roll:disabled:after{display:none}.kept-die-token{display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;cursor:pointer;transition:transform .2s,box-shadow .2s;border:3px solid #ffd700;border-radius:10px;background:transparent;padding:0}#broken-dice-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;pointer-events:all}.broken-dice-card{background:#140a0aeb;border:2px solid #c0392b;border-radius:14px;padding:18px 28px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 4px 32px #0009}.broken-dice-card p{margin:0;font-size:1.2rem;font-weight:700;color:#e74c3c;letter-spacing:.04em}.broken-dice-card button{background:#c0392b;color:#fff;border:none;border-radius:8px;padding:9px 22px;font-size:1rem;cursor:pointer;font-weight:600;transition:background .15s}.broken-dice-card button:hover{background:#e74c3c}#yahtzee-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:300}#yahtzee-overlay.hidden{display:none}.yahtzee-text{font-size:clamp(3rem,10vw,7rem);font-weight:900;letter-spacing:.06em;color:gold;text-shadow:0 0 30px rgba(255,215,0,.8),0 0 60px rgba(255,140,0,.5);animation:yahtzeeAnim 3.2s cubic-bezier(.22,1,.36,1) forwards;font-family:Syne,sans-serif;will-change:transform,opacity}@keyframes yahtzeeAnim{0%{transform:scale(0) rotate(-20deg);opacity:0}14%{transform:scale(1.4) rotate(5deg);opacity:1}24%{transform:scale(.9) rotate(-2deg);opacity:1}34%{transform:scale(1.1) rotate(1.5deg);opacity:1}44%{transform:scale(.97) rotate(0);opacity:1}55%{transform:scale(1) rotate(0);opacity:1}78%{transform:scale(1) rotate(0);opacity:1}92%{transform:scale(1.8) rotate(0);opacity:.3}to{transform:scale(2.4) rotate(0);opacity:0}}#casse-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:300}#casse-overlay.hidden{display:none}.casse-text{font-size:clamp(2rem,7vw,4.5rem);font-weight:900;letter-spacing:.08em;color:#f44;text-shadow:0 0 24px rgba(255,68,68,.7),0 0 48px rgba(255,0,0,.4);animation:casseAnim 2.4s ease-out forwards;font-family:Syne,sans-serif;will-change:transform,opacity}@keyframes casseAnim{0%{transform:scale(.2) translateY(30px) rotate(-8deg);opacity:0}12%{transform:scale(1.3) translateY(-6px) rotate(3deg);opacity:1}22%{transform:scale(.9) translateY(2px) rotate(-1deg);opacity:1}32%{transform:scale(1.08) translateY(-2px) rotate(0);opacity:1}46%{transform:scale(1) translateY(0) rotate(0);opacity:1}68%{transform:scale(1) translateY(0) rotate(0);opacity:1}88%{transform:scale(1.2) translateY(-14px) rotate(1deg);opacity:.45}to{transform:scale(1.6) translateY(-35px) rotate(2deg);opacity:0}}#victory-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:100;background:#000000bf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.victory-card{background:linear-gradient(160deg,#0c1230fa,#060818fc);border:1px solid rgba(255,215,0,.35);border-radius:26px;padding:2.8rem 3rem;width:min(460px,92vw);text-align:center;box-shadow:0 0 100px #ffd7002e,0 0 0 1px #ffd70014,0 40px 80px #000000b3;position:relative;overflow:hidden;animation:card-enter .6s cubic-bezier(.34,1.56,.64,1) both}.victory-card:before{content:"";position:absolute;top:0;left:5%;right:5%;height:2px;background:linear-gradient(90deg,transparent,rgba(255,215,0,.7),transparent);border-radius:0 0 50% 50%}.victory-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:140px;background:radial-gradient(ellipse at bottom,rgba(255,215,0,.06) 0%,transparent 70%);pointer-events:none}#victory-title{font-family:Syne,sans-serif;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:800;letter-spacing:.04em;color:gold;margin-bottom:1.8rem;text-shadow:0 0 32px rgba(255,215,0,.5),0 2px 0 rgba(0,0,0,.5)}#victory-rankings{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem;text-align:left}#victory-rankings li{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;font-weight:600;font-size:.92rem;transition:background .2s;animation:rank-enter .4s cubic-bezier(.34,1.56,.64,1) both}#victory-rankings li:nth-child(1){animation-delay:.1s}#victory-rankings li:nth-child(2){animation-delay:.2s}#victory-rankings li:nth-child(3){animation-delay:.3s}#victory-rankings li:nth-child(4){animation-delay:.4s}@keyframes rank-enter{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}#victory-rankings li:first-child{background:#ffd70024;border-color:#ffd70059;font-size:1.05rem;padding:.85rem 1rem;box-shadow:0 0 24px #ffd7001f}#victory-rankings li:nth-child(2){background:#c8c8e60f;border-color:#c8c8e624}#victory-rankings li:nth-child(3){background:#d282500f;border-color:#d2825024}.rank-medal{font-size:1.5rem;flex-shrink:0}.rank-name{flex:1}.rank-score{margin-left:auto;font-weight:700;font-size:.95rem;color:gold;font-variant-numeric:tabular-nums;letter-spacing:.02em}.rank-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;color:#1a1a2e;flex-shrink:0;box-shadow:0 2px 8px #0006}#btn-new-game{width:100%;padding:1rem;background:linear-gradient(135deg,gold,#ffb300 60%,#f0a500);color:#1a1a2e;font-weight:800;font-size:1.08rem;border-radius:14px;box-shadow:0 4px 28px #ffd70066,0 2px #ffffff40 inset;transition:transform .15s,box-shadow .15s;letter-spacing:.03em;position:relative;z-index:1}#btn-new-game:hover{transform:translateY(-2px);box-shadow:0 10px 36px #ffd7008c}.confetti-particle{position:absolute;width:9px;height:9px;border-radius:2px;animation:confetti-fall 1.8s ease-in forwards}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0) scaleX(1);opacity:1}to{transform:translateY(380px) rotate(800deg) scaleX(.4);opacity:0}}.mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.mode-btn{display:flex;flex-direction:column;align-items:center;gap:.28rem;padding:.85rem .5rem .75rem;border-radius:14px;border:1.5px solid rgba(255,255,255,.1);background:#ffffff0a;color:#ffffff80;cursor:pointer;transition:background .18s,border-color .18s,transform .18s,box-shadow .18s}.mode-icon{font-size:1.55rem;line-height:1}.mode-name{font-size:.9rem;font-weight:700;letter-spacing:.02em;color:#ffffffbf;transition:color .18s}.mode-desc{font-size:.72rem;letter-spacing:.01em;opacity:.65;color:#ffffff59}.mode-btn:hover:not(:disabled){background:#ffffff17;border-color:#ffffff47;transform:translateY(-2px)}.mode-btn.active{background:var(--mode-glow, rgba(255,215,0,.14));border-color:var(--mode-color, #ffd700);box-shadow:0 0 22px var(--mode-glow, rgba(255,215,0,.18));transform:translateY(-2px)}.mode-btn.active .mode-name{color:var(--mode-color, #ffd700)}.mode-btn.active .mode-desc{color:color-mix(in srgb,var(--mode-color, #ffd700) 60%,rgba(255,255,255,.4))}.btn-rules-mode{grid-column:1 / -1;padding:.45rem;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:#ffffff59;font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;letter-spacing:.02em}.btn-rules-mode:hover{background:#ffffff14;color:#ffffffb3;border-color:#ffffff40}#token-panel{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem .6rem;display:flex;flex-direction:column;gap:.6rem}#token-panel::-webkit-scrollbar{width:4px}#token-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.token-phase{text-align:center}.phase-badge{display:inline-block;padding:.3rem .9rem;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:.04em}.phase-charge{background:#dc32322e;border:1px solid rgba(220,50,50,.45);color:#ff7070}.phase-decharge{background:#32c85a2e;border:1px solid rgba(50,200,90,.45);color:#5ddb80}.token-pot{display:flex;justify-content:space-between;align-items:center;background:#ffffff0f;border-radius:10px;padding:.5rem .9rem}.token-pot-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73}.token-pot-value{font-size:1.3rem;font-weight:800;color:gold}.token-players{display:flex;flex-direction:column;gap:.35rem}.token-player{display:flex;justify-content:space-between;align-items:center;padding:.4rem .7rem;border-radius:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);font-size:.8rem;transition:background .15s,border-color .15s}.token-player-active{background:#ffd70014;border-color:#ffd7004d}.token-player-name{color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.token-player-count{font-weight:700;color:gold;flex-shrink:0}.token-submissions-title{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;padding:4px 2px 2px}.token-submissions{display:flex;flex-direction:column;gap:.25rem}.token-submission-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem .6rem;background:#ffffff0a;border-radius:7px;font-size:.75rem}.token-submission-combo{color:gold;font-weight:600;font-size:.7rem}#btn-lock-combo{font-size:1rem;padding:.75rem 1.6rem;border-radius:14px;background:linear-gradient(135deg,#4caf50,#1b7a2e);color:#fff;box-shadow:0 4px 20px #4caf5059}#btn-lock-combo:hover:not(:disabled){box-shadow:0 6px 26px #4caf5080}.current-combo-display{font-size:.82rem;color:#ffffffa6;white-space:nowrap;align-self:center}#round-result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000009e;display:flex;align-items:center;justify-content:center;z-index:90;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;animation:result-fade-in .25s ease-out}#round-result-overlay.hidden{display:none!important}@keyframes result-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.round-result-card{background:#0a1428f5;border:1.5px solid rgba(255,255,255,.15);border-radius:18px;padding:1.8rem 2.2rem;min-width:300px;max-width:480px;display:flex;flex-direction:column;gap:.9rem;box-shadow:0 8px 40px #0009;pointer-events:all}.phase-transition-card{text-align:center}.phase-transition-card h3{font-size:1.6rem;color:gold;margin-bottom:.4rem}.phase-transition-card p{color:#ffffffb3;font-size:.9rem}.round-result-title{font-size:1.1rem;font-weight:700;color:#fff;text-align:center;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.6rem}.round-result-table{display:flex;flex-direction:column;gap:.4rem}.round-result-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#ffffff0a;border-radius:8px;font-size:.82rem}.round-result-name{color:#fffc;font-weight:600;min-width:80px}.round-result-dice{font-size:1rem;letter-spacing:.1em}.round-result-combo{color:gold;font-weight:700;font-size:.78rem;text-align:right}.round-result-changes{display:flex;flex-direction:column;gap:.3rem;border-top:1px solid rgba(255,255,255,.08);padding-top:.6rem}.token-change-bad{color:#ff7070;font-size:.8rem;padding:.2rem .4rem}.token-change-good{color:#5ddb80;font-size:.8rem;padding:.2rem .4rem}.combo-ref-section{margin-top:.75rem;border-top:1px solid rgba(255,255,255,.08);padding-top:.5rem}.combo-ref-toggle{background:none;border:1px solid rgba(255,255,255,.15);color:#94a3b8;border-radius:6px;font-size:.72rem;padding:.2rem .6rem;cursor:pointer;width:100%;text-align:left}.combo-ref-toggle:hover{background:#ffffff0f}.combo-ref-list{margin-top:.4rem;display:flex;flex-direction:column;gap:2px}.combo-ref-row{display:grid;grid-template-columns:1rem 1fr 1.8fr;gap:.3rem;font-size:.68rem;color:#94a3b8;padding:.15rem .2rem;border-radius:4px}.combo-ref-special{color:#fbbf24;background:#fbbf2412}.combo-ref-worst{color:#f87171;background:#f8717112}.combo-ref-rank{color:#475569;font-size:.6rem;padding-top:.05rem}.combo-ref-name{font-weight:600}.combo-ref-desc{color:#64748b;font-size:.62rem}.combo-ref-special .combo-ref-desc{color:#d97706}.combo-ref-worst .combo-ref-desc{color:#ef4444}.round-result-tie-msg{text-align:center;font-size:.85rem;color:#94a3b8;margin:.25rem 0 .5rem}.btn-rules-inline{min-width:36px;padding:.4rem .6rem;background:#ffffff14;border:1px solid rgba(255,255,255,.2);color:#ffffffb3;font-weight:800;font-size:1rem;border-radius:8px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-rules-inline:hover{background:#ffd70026;color:gold;border-color:#ffd70080}.btn-rules-hud{position:absolute;bottom:18px;right:16px;width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#ffffffb3;font-weight:800;font-size:1rem;cursor:pointer;padding:0;transition:background .15s,color .15s;z-index:50}.btn-rules-hud:hover{background:#ffd70033;color:gold}#rules-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center}#rules-modal.hidden{display:none!important}.rules-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rules-card{position:relative;background:#16213e;border:1px solid rgba(255,255,255,.15);border-radius:18px;box-shadow:0 24px 80px #000000b3;width:min(680px,95vw);max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.rules-close{position:absolute;top:12px;right:14px;background:none;border:none;color:#ffffff80;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;z-index:1;transition:color .15s,background .15s}.rules-close:hover{color:#fff;background:#ffffff1a}.rules-tabs{display:flex;gap:.5rem;padding:1rem 1.2rem .6rem;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.rules-tab{padding:.4rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#fff9;font-size:.9rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.rules-tab:hover{background:#ffffff1a;color:#fff}.rules-tab.active{background:#ffd70026;border-color:#ffd70080;color:gold;font-weight:700}.rules-body{overflow-y:auto;padding:1.2rem 1.4rem 1.6rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;display:flex;flex-direction:column;gap:.9rem}.rules-intro{font-size:.95rem;color:#fffc;line-height:1.6;background:#ffffff0a;border-left:3px solid #ffd700;padding:.7rem 1rem;border-radius:0 8px 8px 0}.rules-intro strong{color:gold}.rules-intro em{color:#7ecfff;font-style:normal}.rules-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff6;margin-top:.4rem}.rules-tip{font-size:.88rem;color:#ffffffb3;line-height:1.55;background:#ffffff0a;border-radius:8px;padding:.6rem .9rem}.rules-tip strong{color:#fff}.rules-tip em{color:#7ecfff;font-style:normal}.rules-table{width:100%;border-collapse:collapse;font-size:.85rem}.rules-table thead th{text-align:left;padding:.4rem .6rem;color:#fff6;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid rgba(255,255,255,.1)}.rules-table tbody tr:hover td{background:#ffffff0a}.rules-table tbody td{padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,.05);color:#ffffffbf;vertical-align:top}.combo-name{font-weight:700;color:#f0e6d3!important;white-space:nowrap}.combo-pts{color:gold!important;font-weight:600;white-space:nowrap;text-align:right}#turn-score-display{display:flex;align-items:baseline;gap:.35rem;background:#ffd70014;border:1px solid rgba(255,215,0,.2);border-radius:8px;padding:.3rem .75rem}#turn-score-locked{font-size:1.3rem;font-weight:800;color:gold}#turn-score-label{font-size:.75rem;color:#fff9}#btn-bank-score{background:#4caf50;color:#fff;font-weight:700}#btn-bank-score:hover:not(:disabled){background:#43a047;box-shadow:0 6px 20px #4caf5066}#btn-bank-score:disabled{background:#4caf5059;color:#ffffff80}.farkle-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;display:flex;align-items:center;justify-content:center;background:#dc14148c;animation:farkle-flash .3s ease-out forwards}.farkle-overlay.hidden{display:none!important}@keyframes farkle-flash{0%{opacity:0}30%{opacity:1}to{opacity:1}}.farkle-card{background:#1a1a2e;border:3px solid #ff6b6b;border-radius:18px;padding:2rem 3rem;text-align:center;font-size:2.2rem;font-weight:800;color:#ff6b6b;animation:farkle-shake .4s ease-out,farkle-in .25s ease-out;box-shadow:0 0 60px #ff6b6b80}.farkle-subtitle{display:block;font-size:1rem;font-weight:400;color:#ffffffb3;margin-top:.5rem}@keyframes farkle-shake{0%{transform:translate(0)}20%{transform:translate(-12px)}40%{transform:translate(12px)}60%{transform:translate(-8px)}80%{transform:translate(8px)}to{transform:translate(0)}}@keyframes farkle-in{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}#farkle-score-panel{padding:.75rem .5rem}.farkle-panel-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#fff6;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:.5rem}.farkle-player-row{display:flex;align-items:center;gap:.4rem;padding:.3rem .2rem;border-radius:6px;transition:background .15s}.farkle-player-row.farkle-player-active{background:#ffd70014}.farkle-player-medal{font-size:.9rem;width:1.4rem;text-align:center;flex-shrink:0}.farkle-player-name{flex:1;font-size:.8rem;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.farkle-player-me .farkle-player-name{color:gold}.farkle-player-score{font-size:.85rem;font-weight:700;color:#f0e6d3;flex-shrink:0}.farkle-player-active .farkle-player-score{color:gold}.farkle-progress-bar{height:3px;background:#ffffff14;border-radius:2px;margin:0 .2rem .4rem;overflow:hidden}.farkle-progress-fill{height:100%;background:#ff7675;border-radius:2px;transition:width .4s ease}.farkle-scoring-info{font-size:.75rem;color:#ffffffa6;margin-top:.25rem;min-height:1.1em}.scoring-label{color:#4caf50;font-weight:700}.turn-score-inline{color:gold;font-weight:700}.hot-dice-badge{display:inline-block;background:linear-gradient(135deg,#ff7675,#ffa726);color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .7rem;border-radius:999px;margin-top:.3rem;animation:hot-pulse 1s ease-in-out infinite}@keyframes hot-pulse{0%,to{box-shadow:0 0 #ff767580}50%{box-shadow:0 0 0 6px #ff767500}}.final-round-badge{display:inline-block;background:#ffa72626;border:1px solid #ffa726;color:#ffa726;font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:6px;margin-bottom:.5rem;letter-spacing:.04em}.kept-die-token.scoring{border-color:#4caf50;box-shadow:0 0 6px #4caf5080}.perudo-dice-panel{padding:.6rem .5rem;display:flex;flex-direction:column;gap:.35rem}.perudo-panel-title{font-size:.7rem;font-weight:700;color:#ffffff73;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem;padding:0 .2rem}.perudo-player-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem .5rem;border-radius:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);transition:background .15s}.perudo-player-row.perudo-player-active{background:#e170551f;border-color:#e1705566}.perudo-player-row.perudo-player-me .perudo-player-name{color:gold}.perudo-player-row.perudo-player-eliminated{opacity:.4}.perudo-player-name{flex:1;font-size:.78rem;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.perudo-player-dice{display:flex;gap:.12rem;flex-shrink:0}.die-icon{font-size:.85rem;color:#e17055;line-height:1}.die-icon.die-icon-lost{color:#ffffff26}.perudo-bid-panel{position:absolute;bottom:calc(var(--layout-hud-height, 88px) + .5rem);left:50%;transform:translate(-50%);z-index:var(--z-scorePanel, 30);background:#16213eeb;border:1px solid rgba(225,112,85,.35);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:14px;padding:.85rem 1.2rem;display:flex;flex-direction:column;gap:.6rem;min-width:280px;max-width:360px;box-shadow:0 8px 32px #00000080}.current-bid-display{text-align:center;font-size:1rem;color:#ffffffb3;min-height:1.4em}.current-bid-display strong{color:gold;font-size:1.15rem}.bid-controls{display:flex;flex-direction:column;gap:.5rem;transition:opacity .2s}.bid-controls.bid-controls-disabled{opacity:.45;pointer-events:none}.bid-quantity-row{display:flex;align-items:center;justify-content:center;gap:.6rem}.bid-qty-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#f0e6d3;border-radius:8px;width:2rem;height:2rem;font-size:1.1rem;cursor:pointer;transition:background .15s;line-height:1;padding:0}.bid-qty-btn:hover{background:#ffffff26}.bid-qty-value{font-size:1.4rem;font-weight:700;color:#f0e6d3;min-width:2rem;text-align:center}.bid-face-row{display:flex;justify-content:center;gap:.4rem}.bid-face-btn{background:#ffffff12;border:2px solid rgba(255,255,255,.14);color:#f0e6d3;border-radius:10px;width:3.2rem;height:3.2rem;font-size:2rem;cursor:pointer;transition:background .15s,border-color .15s,transform .1s,box-shadow .15s;line-height:1;padding:0;display:flex;align-items:center;justify-content:center}.bid-face-btn:hover{background:#e170552e;border-color:#e1705580;transform:translateY(-2px)}.bid-face-btn.active{background:#e170554d;border-color:#e17055;box-shadow:0 0 10px #e1705580,inset 0 0 6px #e1705526;transform:translateY(-1px);color:#fff}.bid-action-row{display:flex;gap:.5rem;justify-content:center}.btn-miser{flex:1;padding:.55rem 1rem;background:linear-gradient(135deg,#e17055,#d35400);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s,box-shadow .15s}.btn-miser:hover:not(:disabled){box-shadow:0 4px 16px #e1705580}.btn-miser:disabled{opacity:.4;cursor:default}.btn-dudo{flex:1;padding:.55rem 1rem;background:linear-gradient(135deg,#ff6b6b,#c0392b);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s,box-shadow .15s}.btn-dudo:hover:not(:disabled){box-shadow:0 4px 16px #ff6b6b80}.btn-dudo:disabled{opacity:.4;cursor:default}.perudo-round-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:var(--z-overlay, 100);pointer-events:none;animation:perudo-banner-fade 2.5s ease-out forwards}.perudo-round-text{background:#16213ee6;border:2px solid #e17055;border-radius:16px;padding:.8rem 2.5rem;font-size:1.8rem;font-weight:800;color:#e17055;letter-spacing:.06em;text-shadow:0 2px 12px rgba(225,112,85,.5);box-shadow:0 8px 40px #0009;white-space:nowrap}@keyframes perudo-banner-fade{0%{opacity:0;transform:translate(-50%,-55%) scale(.85)}15%{opacity:1;transform:translate(-50%,-50%) scale(1)}70%{opacity:1}to{opacity:0;transform:translate(-50%,-45%) scale(.95)}}.perudo-reveal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay, 100);background:#0a0e1ebf;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:perudo-reveal-in .3s ease-out}@keyframes perudo-reveal-in{0%{opacity:0}to{opacity:1}}.perudo-reveal-card{background:#16213ef7;border:1px solid rgba(225,112,85,.4);border-radius:18px;padding:1.5rem 2rem;max-width:460px;width:90%;box-shadow:0 24px 80px #000000b3;display:flex;flex-direction:column;gap:.7rem;align-items:center;text-align:center}.reveal-title{font-size:1.6rem;font-weight:800;color:#e17055;letter-spacing:.04em}.reveal-bid{font-size:1.1rem;color:#ffffffbf}.reveal-bid strong{color:gold;font-size:1.25rem}.reveal-count{font-size:.95rem;color:#ffffffa6}.reveal-count strong{color:#f0e6d3;font-weight:700}.reveal-table{width:100%;border-collapse:collapse;margin:.3rem 0}.reveal-table tr{border-bottom:1px solid rgba(255,255,255,.06)}.reveal-table tr:last-child{border-bottom:none}.reveal-table td{padding:.35rem .5rem;font-size:.85rem}.reveal-player-name{color:#fffc;text-align:left;white-space:nowrap;width:1%}.reveal-dice-cell{text-align:left;letter-spacing:.15em;font-size:1.1rem}.reveal-row-loser{background:#ff6b6b14}.reveal-row-loser .reveal-player-name{color:#ff6b6b;font-weight:700}.reveal-die{display:inline-block;opacity:.5}.reveal-die.reveal-die-match{opacity:1;filter:drop-shadow(0 0 4px rgba(255,215,0,.7))}.reveal-result{font-size:.9rem;font-weight:700;padding:.4rem .8rem;border-radius:8px}.reveal-result-good{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.reveal-result-bad{background:#ff6b6b26;color:#ff6b6b;border:1px solid rgba(255,107,107,.3)}.reveal-loser{font-size:.85rem;color:#ffffff8c}#waiting-hint{display:flex;align-items:center;gap:.4rem;justify-content:center;color:#ffffff73;font-size:.82rem;margin-top:.5rem}.wait-dots span{width:5px;height:5px;background:#ffd70080;border-radius:50%;display:inline-block;animation:dot-pulse-wait 1.4s ease-in-out infinite}.wait-dots span:nth-child(2){animation-delay:.2s}.wait-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse-wait{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}@keyframes screen-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes screen-fade-out{0%{opacity:1}to{opacity:0}}.screen-entering{animation:screen-fade-in .3s ease forwards}.screen-exiting{animation:screen-fade-out .25s ease forwards;pointer-events:none}#victory-overlay:not(.hidden){animation:victory-backdrop-in .4s ease forwards}@keyframes victory-backdrop-in{0%{backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);background:#0000}to{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#00000080}}.hud-player-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#1a1a2e;flex-shrink:0}#current-player-name{display:flex;align-items:center;gap:.4rem}.turn-avatar-circle{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800}.bonus-bar-wrap{position:relative;background:#ffffff12;border-radius:6px;height:18px;width:100%;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.bonus-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#8a6900,gold,#fff7a0);border-radius:6px;transition:width .6s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #ffd7004d}.bonus-bar-label{position:absolute;right:5px;top:50%;transform:translateY(-50%);font-size:.62rem;font-weight:600;color:#fffc;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.5)}.score-col.active-col{background:#ffd7000d}.score-col.active-col .score-cell{background:#ffd7000a}.score-row.subtotal-row td,.score-row.total-row td{background:#00000040!important;font-weight:600}.score-row.total-row td{border-top:1px solid rgba(255,215,0,.3);color:gold;font-size:.95rem}@keyframes yahtzee-shake{0%,to{transform:translate(0)}15%{transform:translate(-6px) rotate(-.5deg)}30%{transform:translate(6px) rotate(.5deg)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}}#game.yahtzee-shake{animation:yahtzee-shake .5s ease}@keyframes casse-shake{0%,to{transform:translate(0)}10%{transform:translate(-10px) rotate(-1deg)}25%{transform:translate(10px) rotate(1deg)}40%{transform:translate(-8px)}55%{transform:translate(8px)}70%{transform:translate(-4px)}85%{transform:translate(4px)}}#game.casse-shake{animation:casse-shake .6s ease}.casse-flash{position:fixed;top:0;right:0;bottom:0;left:0;background:#dc323259;pointer-events:none;z-index:9998;animation:casse-flash-anim .5s ease forwards}@keyframes casse-flash-anim{0%{opacity:1}to{opacity:0}}.lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:.75rem;padding:1rem .5rem .5rem}.lb-podium-col{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex:1}.lb-podium-col .lb-podium-bar{width:100%;border-radius:8px 8px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:.5rem;gap:.2rem}.lb-podium-col:nth-child(1) .lb-podium-bar{height:70px;background:#c0c0c033;border:1px solid rgba(192,192,192,.3)}.lb-podium-col:nth-child(2) .lb-podium-bar{height:95px;background:#ffd70026;border:1px solid rgba(255,215,0,.4)}.lb-podium-col:nth-child(3) .lb-podium-bar{height:55px;background:#cd7f3226;border:1px solid rgba(205,127,50,.3)}.lb-podium-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#1a1a2e;margin-top:-.5rem}.lb-podium-medal{font-size:1.4rem;line-height:1}.lb-podium-name{font-size:.72rem;font-weight:600;text-align:center;color:#ffffffe6}.lb-podium-wins{font-size:.65rem;color:#ffffff80}.profile-stat-bar-wrap{height:5px;background:#ffffff12;border-radius:99px;overflow:hidden}.profile-stat-bar-fill{height:100%;background:linear-gradient(90deg,#c8890a,gold,#ffe066);border-radius:99px;transition:width .6s ease}.profile-stat-nums{font-size:.72rem;color:#fff9}.profile-stat-best{grid-column:2 / -1;font-size:.68rem;color:#ffd700b3}@media (max-width: 600px){.lobby-card{width:100%;min-height:100dvh;border-radius:0;padding:1.5rem 1rem}#btn-roll,#btn-lock-combo,#btn-bank-score{min-height:48px;font-size:.95rem}.side-panel{width:100%!important;right:0!important;border-radius:1rem 1rem 0 0;top:auto!important;bottom:0;max-height:85dvh}@keyframes slideInMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.side-panel:not(.hidden){animation:slideInMobile .35s cubic-bezier(.34,1.2,.64,1) forwards}#score-panel{position:fixed;bottom:0;left:0;right:0;max-height:60dvh;border-radius:1rem 1rem 0 0;overflow-y:auto;transform:translateY(100%);transition:transform .3s ease;z-index:50;width:100%}#score-panel.open{transform:translateY(0)}#score-toggle-btn{display:flex;position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:#ffd70026;border:1px solid rgba(255,215,0,.3);border-radius:20px;padding:.3rem .9rem;font-size:.75rem;color:gold;z-index:51;cursor:pointer}}@media (min-width: 601px){#score-toggle-btn{display:none}}.auth-forms-wrap{position:relative;overflow:hidden}.auth-form{transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s ease}.auth-form.slide-out-left{transform:translate(-100%);opacity:0;position:absolute;top:0;width:100%}.auth-form.slide-out-right{transform:translate(100%);opacity:0;position:absolute;top:0;width:100%}.auth-form.slide-in-left{animation:slide-from-left .28s cubic-bezier(.4,0,.2,1) forwards}.auth-form.slide-in-right{animation:slide-from-right .28s cubic-bezier(.4,0,.2,1) forwards}@keyframes slide-from-left{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slide-from-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.input-icon-wrap{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.75rem;font-size:.9rem;pointer-events:none;opacity:.5}.input-icon-wrap input{padding-left:2.2rem!important}#player-name:focus{outline:none;border-color:gold;box-shadow:0 0 0 3px #ffd70033}.btn-icon{position:relative}.btn-icon:after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#141428f2;color:#fff;font-size:.68rem;white-space:nowrap;padding:.25rem .5rem;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .15s ease}.btn-icon:hover:after{opacity:1}.victory-podium{display:flex;align-items:flex-end;justify-content:center;gap:.6rem;margin:.5rem 0 1rem}.victory-podium-col{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1}.victory-podium-bar{width:100%;border-radius:8px 8px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:.4rem .2rem}.victory-podium-col:nth-child(1) .victory-podium-bar{height:75px;background:#c0c0c02e;border:1px solid rgba(192,192,192,.32)}.victory-podium-col:nth-child(2) .victory-podium-bar{height:105px;background:#ffd70029;border:1px solid rgba(255,215,0,.45);box-shadow:0 0 18px #ffd7001a}.victory-podium-col:nth-child(3) .victory-podium-bar{height:55px;background:#cd7f3229;border:1px solid rgba(205,127,50,.32)}.victory-podium-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#1a1a2e;margin-top:-.5rem;box-shadow:0 2px 8px #0006}.victory-podium-medal{font-size:1.3rem}.victory-podium-name{font-size:.67rem;font-weight:600;color:#ffffffe6;text-align:center}.victory-podium-score{font-size:.62rem;color:#ffffff80}.broken-dice-card{background:linear-gradient(135deg,#b41414f2,#640a0afa);border:2px solid rgba(255,80,80,.5);border-radius:16px;padding:1.5rem 2rem;text-align:center;box-shadow:0 0 40px #ff32324d,0 8px 32px #0009;animation:broken-card-in .35s cubic-bezier(.34,1.56,.64,1)}@keyframes broken-card-in{0%{transform:scale(.6) rotate(-4deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.broken-dice-card p{font-size:1.3rem;font-weight:700;color:#ff8080;margin-bottom:.75rem}#btn-reroll-broken{background:#ff505033;border:1px solid rgba(255,80,80,.5);color:#ff8080;border-radius:8px;padding:.5rem 1.5rem;font-weight:600;cursor:pointer;transition:background .15s}#btn-reroll-broken:hover{background:#ff505059}.auth-bg-dice{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.auth-card{position:relative;z-index:1}.auth-die{position:absolute;left:var(--dx);top:var(--dy);width:var(--s);height:var(--s);animation:auth-die-float var(--dur) ease-in-out var(--delay) infinite alternate}@keyframes auth-die-float{0%{transform:translateY(0) rotate(0);opacity:.7}50%{transform:translateY(-18px) rotate(8deg);opacity:1}to{transform:translateY(4px) rotate(-5deg);opacity:.6}}@media (max-width: 600px){#three-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%!important;height:100%!important}#score-panel{z-index:60}#hud{z-index:70}#turn-banner{z-index:65}}
