:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:block;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{margin:0;padding:0;height:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;min-height:100dvh;min-height:var(--app-vh, 100dvh);position:relative;background:#020617;overflow-x:hidden;color:#f8fafc;user-select:none;-webkit-user-select:none}input,textarea{user-select:text;-webkit-user-select:text}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(#0006,#0006),url(/avatars/background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:-1}.material-symbols-rounded{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;font-size:24px;line-height:24px;display:inline-flex;width:1em;justify-content:center;align-items:center;text-align:center;vertical-align:middle}#root{max-width:none;margin:0;padding:0}.page{display:flex;flex-direction:column;gap:1.5rem;align-items:stretch;max-width:1600px;margin:0 auto;padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom) + var(--vv-bottom, 0px))}.game-page{gap:0;max-width:none;margin:0;padding:0;height:100vh;height:100dvh;height:var(--app-vh, 100dvh);width:100vw;width:var(--app-vw, 100vw);display:flex;flex-direction:column;overflow:hidden}h1{margin:0;font-size:2.4rem}.card{background:#0f172ad9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;padding:1.5rem;box-shadow:0 18px 45px #0009;border:1px solid rgba(255,255,255,.1);text-align:left}label{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}input{border-radius:.6rem;border:1px solid rgba(148,163,184,.6);padding:.6rem .8rem;background:#0f172ad9;color:#e5e7eb}input:focus{outline:2px solid #38bdf8;outline-offset:1px}button{border-radius:999px;border:none;padding:.6rem 1.4rem;background:linear-gradient(135deg,#38bdf8,#22c55e);color:#020617;font-weight:600;cursor:pointer;box-shadow:0 10px 30px #38bdf866}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.board-container{position:relative;background:transparent;border:none;outline:none;border-radius:0;box-shadow:none;margin:0 auto;overflow:visible;--mx: 50%;--my: 50%}.board-container:before{content:"";position:absolute;inset:0;pointer-events:none;display:none}.board-links{position:absolute;inset:0;pointer-events:none;z-index:1;filter:drop-shadow(0 0 6px rgba(56,189,248,.25))}.board-links line{stroke:#38bdf82e;stroke-width:4.5;stroke-linecap:round}.board-field{position:absolute;border-radius:50%;background:radial-gradient(circle at 50% 38%,#ffffff12,#fff0 46%),radial-gradient(circle at 50% 50%,#020617f5,#020617eb);border:2px solid rgba(56,189,248,.65);box-shadow:0 10px 18px #00000085,0 0 18px #38bdf838,inset 0 0 14px #38bdf829;display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer;z-index:2;overflow:hidden}.board-field.type-base{background:radial-gradient(circle at 50% 38%,#ffffff0f,#fff0 46%),radial-gradient(circle at 50% 50%,#020617f7,#020617ed);border:1px dashed rgba(255,255,255,.16)}.board-field.type-entry{border:2px solid rgba(255,255,255,.3);background:radial-gradient(circle at 50% 38%,#ffffff14,#fff0 46%),radial-gradient(circle at 50% 50%,#020617f5,#020617e6)}.board-field.type-goal{background:radial-gradient(circle,#facc15,#854d0e);border:3px solid #fef08a;box-shadow:0 0 20px #facc15}.board-field:after{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(120deg,#0000,#38bdf873,#0000);opacity:0;mix-blend-mode:screen;filter:blur(2px);pointer-events:none}.board-field:before{content:"";position:absolute;inset:-32%;border-radius:50%;opacity:0;pointer-events:none;transform:scale(.55);border:2px solid rgba(255,255,255,.18);filter:blur(.4px)}.board-field:hover{background:radial-gradient(circle at var(--mx) var(--my),rgba(56,189,248,.85) 0%,rgba(56,189,248,.18) 46%,rgba(56,189,248,0) 72%);border-color:#38bdf8f2;box-shadow:0 0 28px #38bdf88c,inset 0 0 16px #38bdf838}.board-field:hover:after{opacity:1;animation:laserSweep .7s linear infinite}@keyframes laserSweep{0%{transform:translate(-40%) rotate(12deg)}to{transform:translate(40%) rotate(12deg)}}.board-field.reachable{background:radial-gradient(circle at 50% 50%,#38bdf8f2,#38bdf826 55%,#38bdf800 75%);border:3px solid rgba(56,189,248,.98);box-shadow:0 0 32px #38bdf8bf,inset 0 0 18px #38bdf840;z-index:20}.board-field.barrier.reachable{background:#38bdf8d9;border:3px solid rgba(56,189,248,.98);box-shadow:0 0 36px #38bdf8f2,inset 0 0 20px #38bdf838;z-index:25}.board-field.last-move-from,.board-field.last-move-to{z-index:26}.board-field.last-move-from{background:#a855f759;border:3px solid rgba(168,85,247,.95);box-shadow:0 0 18px #a855f7bf}.board-field.last-move-to{background:#22c55e59;border:3px solid rgba(34,197,94,.95);box-shadow:0 0 18px #22c55ebf}.board-field.barrier{background:#f8fafc;border:2px solid #64748b;box-shadow:0 0 10px #ffffff80;z-index:15}.board-field.placing-barrier{background:#22c55e33;border:2px dashed #22c55e;animation:pulse 1s infinite;z-index:30}.board-barrier-hint{position:fixed;left:50%;bottom:18px;top:auto;transform:translate(-50%);z-index:1800;display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#020617b8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 44px #0009,0 0 0 2px #38bdf824;pointer-events:none;max-width:min(640px,92%);animation:barrierHintPop .22s ease-out both;font-size:16px}.board-barrier-hint-icon{width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#38bdf829;box-shadow:0 0 0 2px #38bdf81f inset;flex:0 0 auto}.board-barrier-hint-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;letter-spacing:.2px;font-size:inherit}@keyframes barrierHintPop{0%{transform:translate(-50%) translateY(6px) scale(.98);opacity:0}to{transform:translate(-50%) translateY(0) scale(1);opacity:1}}.button-group{display:flex;flex-direction:column;gap:.5rem;width:100%}.skip-button{background:linear-gradient(135deg,#64748b,#475569);box-shadow:0 10px 30px #47556966}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.victory-modal{text-align:center;padding:3rem;max-width:400px;animation:modalScale .4s cubic-bezier(.175,.885,.32,1.275)}.winner-announcement{margin:2rem 0}.winner-name{font-size:2.5rem;font-weight:900;display:block;margin-bottom:.5rem;text-shadow:0 0 20px currentColor}@keyframes modalScale{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.dice-value.rolling{animation:diceShake .1s infinite;opacity:.8}.header-left{display:flex;align-items:center;gap:1.5rem}.leave-button{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2);padding:.4rem .8rem;font-size:.8rem;border-radius:6px;cursor:pointer;transition:all .2s;height:fit-content;display:inline-flex;align-items:center;justify-content:center}.leave-button:hover{background:#ef4444;color:#fff}.center-content{display:flex;flex-direction:column;align-items:center;justify-content:center;height:80vh;text-align:center}.secondary-button{background:#334155;color:#fff;padding:.6rem 1.2rem;border-radius:6px;font-weight:600;transition:background .2s}.secondary-button:hover{background:#475569}.mt-4{margin-top:1rem}@keyframes pulse{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 10px #fff0}to{box-shadow:0 0 #fff0}}.board-piece{width:80%;height:80%;border-radius:50%;border:2px solid rgba(0,0,0,.3);box-shadow:0 4px 6px #0000004d;cursor:grab;transition:transform .2s,opacity .2s,filter .2s;transform:translateZ(0)}.board-piece:hover{transform:scale(1.1)}.board-piece.selected{transform:scale(1.2);border-color:#fff;box-shadow:0 0 15px #fff}.board-piece.hint-movable{position:relative;isolation:isolate;filter:drop-shadow(0 0 18px rgba(255,255,255,.55))}.board-piece.hint-movable:before{content:"";position:absolute;inset:-60%;border-radius:999px;background:radial-gradient(circle at 50% 50%,#ffffff57,#38bdf847,#02061700 74%);opacity:.7;transform:scale(.98);filter:blur(.6px);animation:pieceHintGlow .9s ease-in-out infinite;z-index:-1;pointer-events:none}@keyframes pieceHintGlow{0%{opacity:.35;transform:scale(.78)}50%{opacity:1;transform:scale(1.22)}to{opacity:.35;transform:scale(.78)}}@media(prefers-reduced-motion:reduce){.board-piece.hint-movable:before{animation:none;opacity:.8;transform:scale(1.05)}}.board-piece.dragging{opacity:.55;filter:drop-shadow(0 0 14px rgba(255,255,255,.55))}.piece-red{background:#ef4444}.piece-blue{background:#3b82f6}.piece-green{background:#22c55e}.piece-yellow{background:#eab308}.player-base-label{position:absolute;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.35rem;pointer-events:none;z-index:50;max-width:240px}.player-base-avatar{width:86px;height:86px;border-radius:22px;object-fit:cover;flex:0 0 auto;border:3px solid rgba(255,255,255,.14);box-shadow:0 12px 35px #00000073;background:#02061733}.player-base-avatar-placeholder{width:86px;height:86px;border-radius:22px;flex:0 0 auto;border:3px solid rgba(255,255,255,.14);box-shadow:0 12px 35px #00000073}.player-base-name{font-size:.95rem;font-weight:800;padding:.32rem .85rem;border-radius:999px;color:#020617;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 18px #00000059}.player-base-label.color-red .player-base-name{background:#ef4444f2}.player-base-label.color-blue .player-base-name{background:#3b82f6f2}.player-base-label.color-green .player-base-name{background:#22c55ef2}.player-base-label.color-yellow .player-base-name{background:#eab308f2}.player-base-label.active .player-base-avatar,.player-base-label.active .player-base-avatar-placeholder{transform:scale(1.02);border-color:#38bdf899;box-shadow:0 0 0 4px #38bdf82e,0 14px 40px #0000008c}.barrier-icon{font-weight:700;color:#1e293b;font-size:1.2rem}.avatar-selection{display:flex;justify-content:flex-start;gap:1rem;margin:1rem 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-bottom:6px}.avatar-option{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:.5rem;border-radius:8px;border:2px solid transparent;transition:all .2s;width:100px;flex:0 0 auto;scroll-snap-align:center}.avatar-option:hover:not(.occupied){background:#ffffff0d}.avatar-option.selected{border-color:#0ea5e9;background:#0ea5e91a}.avatar-option.occupied{opacity:.5;cursor:not-allowed}.avatar-option img{width:64px;height:64px;border-radius:50%;object-fit:cover;margin-bottom:.5rem;border:2px solid rgba(255,255,255,.1)}.avatar-name{font-size:.8rem;font-weight:600}.occupied-label{font-size:.7rem;color:#ef4444}.player-item{display:flex;align-items:center;gap:.8rem;padding:.5rem;border-radius:6px}.player-avatar-mini{width:32px;height:32px}.player-avatar-mini img{width:100%;height:100%;border-radius:50%;object-fit:cover}.player-item.active{background:#38bdf81a;border:1px solid rgba(56,189,248,.3)}.message-header-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.chat-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.chat-container{display:flex;flex-direction:column;height:100%;padding:0;overflow:hidden;background:#1e293bd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.chat-header{padding:1rem;background:#334155;border-bottom:1px solid rgba(255,255,255,.1)}.chat-header h3{margin:0;font-size:1rem}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.8rem}.chat-messages ul{margin:0;padding-left:1.25rem}.chat-messages li{margin:.4rem 0}.chat-message{max-width:90%;padding:.6rem .8rem;border-radius:8px;background:#334155;align-self:flex-start}.chat-message.own-message{background:#0ea5e9;align-self:flex-end}.message-info{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.2rem;font-size:.75rem}.message-author{font-weight:700;opacity:.9}.message-time{opacity:.6}.message-text{word-break:break-word;line-height:1.4}.chat-input-form{padding:1rem;background:#1e293b;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:.5rem}.chat-input-form input{flex:1;padding:.6rem;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#0f172a;color:#fff;outline:none}.chat-input-form input:focus{border-color:#0ea5e9}.chat-input-form button{padding:.6rem 1rem;background:#0ea5e9;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.chat-input-form button:disabled{opacity:.5;cursor:not-allowed}.no-messages{text-align:center;opacity:.5;margin-top:2rem;font-style:italic}.controls-card{display:flex;flex-direction:column;gap:1.5rem}.dice-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;border-radius:12px;background:#ffffff08;transition:all .3s}.dice-section.active-turn{background:#38bdf81a;box-shadow:0 0 20px #38bdf826;border:1px solid rgba(56,189,248,.2)}.roll-button{width:100%;font-size:1.2rem}.player-list{display:flex;flex-direction:column;gap:.5rem}.player-items-container{display:flex;flex-direction:column;gap:.4rem}@media(max-width:1300px){.player-items-container{flex-direction:row;flex-wrap:wrap;gap:.8rem}}.dot{width:12px;height:12px;border-radius:50%}.dot.color-red{background:#ef4444}.dot.color-blue{background:#3b82f6}.dot.color-green{background:#22c55e}.dot.color-yellow{background:#eab308}.game-layout{display:grid;grid-template-columns:320px minmax(0,1fr) 320px;gap:1rem;align-items:start;width:100%;max-width:100vw;justify-content:center;transition:all .3s ease;padding:0}.controls-card{justify-self:end;width:320px;display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:140px;align-self:start}.board-card{justify-self:center;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:visible;padding:0;margin:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border:0;border-radius:0;box-shadow:none}.chat-card{justify-self:start;width:320px;position:sticky;top:140px;height:calc(100vh - 160px);transition:all .3s ease;align-self:start}.chat-card.collapsed{width:50px}@media(max-width:1300px){.game-layout{grid-template-columns:1fr;justify-items:center;gap:1.5rem}.controls-card{justify-self:center;order:2;width:100%;max-width:600px;flex-direction:column}.dice-section{flex:1;min-width:250px}.board-card{order:1;width:100%}.chat-card{justify-self:center;order:3;width:100%;max-width:600px}.chat-card.collapsed{width:100%;height:auto;min-height:50px}}.board-scale-wrapper{display:flex;justify-content:center;align-items:center;width:100%;height:auto}.game-page .board-scale-wrapper{width:auto;margin:0 auto}.chat-toggle-button{position:absolute;left:-20px;top:10px;z-index:100;width:auto;height:36px;padding:0 12px;border-radius:8px;font-size:.8rem;background:#0ea5e9;color:#fff;box-shadow:0 4px 12px #00000080;white-space:nowrap;border:1px solid rgba(255,255,255,.2)}.chat-card.collapsed .chat-toggle-button{left:5px;width:calc(100% - 10px);padding:10px 4px}.dice-cube{width:80px;height:80px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 10px #0000001a,0 4px 15px #0000004d;position:relative;border:1px solid #ddd}.dice-cube.empty{background:#f1f5f9;color:#94a3b8;font-size:2rem;border:2px dashed #cbd5e1}.dice-dot{width:14px;height:14px;background:#1e293b;border-radius:50%;box-shadow:inset 0 2px 2px #00000080;position:relative;z-index:3}.dot-container{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;padding:10px;box-sizing:border-box;position:relative;z-index:2}.d1 .dice-dot{grid-area:2 / 2}.d2 .dice-dot:nth-child(1){grid-area:1 / 1}.d2 .dice-dot:nth-child(2){grid-area:3 / 3}.d3 .dice-dot:nth-child(1){grid-area:1 / 1}.d3 .dice-dot:nth-child(2){grid-area:2 / 2}.d3 .dice-dot:nth-child(3){grid-area:3 / 3}.d4 .dice-dot:nth-child(1){grid-area:1 / 1}.d4 .dice-dot:nth-child(2){grid-area:1 / 3}.d4 .dice-dot:nth-child(3){grid-area:3 / 1}.d4 .dice-dot:nth-child(4){grid-area:3 / 3}.d5 .dice-dot:nth-child(1){grid-area:1 / 1}.d5 .dice-dot:nth-child(2){grid-area:1 / 3}.d5 .dice-dot:nth-child(3){grid-area:2 / 2}.d5 .dice-dot:nth-child(4){grid-area:3 / 1}.d5 .dice-dot:nth-child(5){grid-area:3 / 3}.d6 .dice-dot:nth-child(1){grid-area:1 / 1}.d6 .dice-dot:nth-child(2){grid-area:1 / 3}.d6 .dice-dot:nth-child(3){grid-area:2 / 1}.d6 .dice-dot:nth-child(4){grid-area:2 / 3}.d6 .dice-dot:nth-child(5){grid-area:3 / 1}.d6 .dice-dot:nth-child(6){grid-area:3 / 3}.dice-cube.rolling{animation:diceShake .1s infinite}@keyframes diceShake{0%{transform:translate(0) rotate(0)}25%{transform:translate(2px,-2px) rotate(5deg)}50%{transform:translate(-2px,2px) rotate(-5deg)}75%{transform:translate(2px,2px) rotate(5deg)}to{transform:translate(0) rotate(0)}}.current-player-display{display:flex;align-items:center;gap:1rem;padding:.5rem 1.5rem;background:#ffffff0d;border-radius:50px;border:1px solid rgba(255,255,255,.1)}.player-avatar-large{width:44px;height:44px}.avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid transparent}.avatar-img.border-red{border-color:#ef4444}.avatar-img.border-blue{border-color:#3b82f6}.avatar-img.border-green{border-color:#22c55e}.avatar-img.border-yellow{border-color:#eab308}.player-details{display:flex;flex-direction:column}.player-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;opacity:.6}.player-name{font-size:1.1rem;font-weight:700}.player-info{text-align:right;font-size:.9rem;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.turn-timer{font-family:Courier New,Courier,monospace;font-size:1.2rem;font-weight:700;color:#38bdf8;background:#38bdf81a;padding:.2rem .8rem;border-radius:4px;border:1px solid rgba(56,189,248,.3)}.turn-timer.low-time{color:#ef4444;background:#ef44441a;border-color:#ef444466;animation:timerPulse 1s infinite}@keyframes timerPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.player-info p{margin:0;line-height:1.4}.avatar-placeholder{width:100%;height:100%;border-radius:50%}.bg-red{background-color:#ef4444}.bg-blue{background-color:#3b82f6}.bg-green{background-color:#22c55e}.bg-yellow{background-color:#eab308}.player-name.color-red,.toast-player.color-red{color:#ef4444}.player-name.color-blue,.toast-player.color-blue{color:#3b82f6}.player-name.color-green,.toast-player.color-green{color:#22c55e}.player-name.color-yellow,.toast-player.color-yellow{color:#eab308}.toast-player{font-weight:900;text-shadow:0 0 18px rgba(0,0,0,.55),0 0 16px currentColor}.error-banner{background:#fee2e2;color:#b91c1c;padding:1rem;border-radius:8px;border:1px solid #f87171}.toast-banner{position:fixed;top:120px;left:50%;transform:translate(-50%);z-index:1200;padding:.75rem 1.1rem;border-radius:999px;background:#020617c7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 55px #0009;color:#f8fafc;font-weight:800;max-width:min(720px,92vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-shell{min-height:calc(100vh - 2rem);display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{width:min(520px,92vw);display:flex;flex-direction:column;gap:.9rem;padding:1.25rem;border-radius:16px;background:#020617a8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);box-shadow:0 22px 80px #0000008c}.auth-logo,.loading-logo{width:100%;max-height:220px;object-fit:contain;display:block}.loading-bar{height:10px;border-radius:999px;background:#ffffff1f;overflow:hidden}.loading-bar-fill{height:100%;background:linear-gradient(90deg,#38bdf8e6,#a855f7e6);border-radius:999px;transition:width 80ms linear}.auth-tabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.auth-tabs button{padding:.55rem .75rem;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0f172a80;color:#f8fafc;font-weight:800;cursor:pointer}.auth-tabs button.active{background:#38bdf840;border-color:#38bdf8a6}.auth-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.lang-toggle{width:56px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0f172a80;color:#f8fafc;cursor:pointer;font-weight:900;box-shadow:none;padding:0;display:inline-flex;align-items:center;justify-content:center}.lang-toggle:disabled{opacity:.55;cursor:not-allowed}.auth-title{margin:0;font-size:1.2rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-weight:700}.auth-card input{padding:.7rem .85rem;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0f172a80;color:#f8fafc}.auth-primary{padding:.75rem 1rem;border-radius:14px;border:1px solid rgba(56,189,248,.6);background:#38bdf82e;color:#f8fafc;font-weight:900;cursor:pointer}.auth-primary:disabled{opacity:.55;cursor:not-allowed}.auth-error{padding:.65rem .85rem;border-radius:12px;background:#ef444429;border:1px solid rgba(239,68,68,.55)}.auth-info{padding:.65rem .85rem;border-radius:12px;background:#22c55e24;border:1px solid rgba(34,197,94,.45)}.auth-captcha{display:flex;justify-content:center}.topbar{position:sticky;top:0;z-index:1200;display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;border-radius:14px;background:#020617a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12)}.topbar-left{display:flex;align-items:center;gap:.75rem}.topbar-logo{width:56px;height:56px;object-fit:contain;display:block}.topbar-title{font-size:1.05rem;font-weight:900;letter-spacing:.02em}.topbar-right{display:flex;align-items:center;gap:.6rem}.topbar-avatar{width:36px;height:36px;border-radius:999px;object-fit:cover;border:1px solid rgba(255,255,255,.16)}.topbar-avatar.placeholder{background:#ffffff1f}.topbar-action{width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#0f172a80;color:#f8fafc;cursor:pointer;font-weight:900}.lobby-page .card{padding:1rem}.rotate-overlay{position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;background:#020617e0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rotate-card{width:min(520px,92vw);padding:1.25rem;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0f172a8c;box-shadow:0 22px 80px #0000008c;display:flex;flex-direction:column;align-items:center;gap:.75rem}.rotate-icon{font-size:2.4rem;font-weight:900}.rotate-text{font-size:1.1rem;font-weight:900;text-align:center}.game-stage{position:relative;margin:0;flex:1 1 auto;width:100%;padding-top:var(--header-h, 64px);padding-bottom:var(--bottom-h, 64px);height:calc(100vh - var(--header-h, 64px) - var(--bottom-h, 64px));display:flex;align-items:center;justify-content:center}.header-right{display:flex;align-items:center;gap:.75rem}.turn-indicator,.turn-name{font-weight:900}.bottom-bar{left:0;right:0;bottom:0;z-index:1500;position:fixed;overflow:hidden;display:flex;justify-content:center;gap:.75rem;padding:.6rem .9rem;background:#020617a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.12)}.bottom-right{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.bottom-neopold-link{display:flex;align-items:center;gap:.5rem;color:#f8fafc;text-decoration:none;font-weight:800;opacity:.85}.bottom-neopold-link:hover{opacity:1;text-decoration:underline}.bottom-neopold-logo{width:40px;height:40px;object-fit:contain;display:block}.bottom-neopold-text{font-weight:800;white-space:nowrap;font-size:.85rem}.dice-cube.rolling{animation:diceWobble .35s infinite ease-in-out}.dice-cube.six{animation:diceSix 1.2s ease-in-out;overflow:hidden;box-shadow:0 0 0 4px #facc1529,0 0 26px #facc15a6,0 18px 48px #0009;border-color:#facc15d9}.dice-cube.six:before{content:"";position:absolute;inset:-35%;z-index:0;background:radial-gradient(circle at 18% 28%,#facc15f2,#facc1500 34%),radial-gradient(circle at 72% 34%,#fbbf24e0,#fbbf2400 38%),radial-gradient(circle at 35% 72%,#fde047c7,#fde04700 40%),radial-gradient(circle at 78% 78%,#f59e0bb8,#f59e0b00 44%),radial-gradient(circle at 50% 50%,#facc152e,#facc1500 60%);mix-blend-mode:screen;opacity:.95;filter:blur(.6px);transform:rotate(0) scale(.92);animation:diceFireworks 1.2s ease-out both}.dice-cube.six:after{content:"";position:absolute;inset:-10% -10% -42%;z-index:1;background:radial-gradient(circle at 50% 98%,#fb923cf2,#fb923c00 62%),radial-gradient(circle at 50% 105%,#ef4444b8,#ef444400 70%),radial-gradient(circle at 50% 92%,#ffffff59,#fff0 55%);mix-blend-mode:screen;opacity:.95;filter:blur(.8px);transform-origin:50% 100%;animation:diceFlame .22s ease-in-out infinite}@keyframes diceWobble{0%{transform:rotate(-6deg) scale(1.02)}50%{transform:rotate(6deg) scale(.98)}to{transform:rotate(-6deg) scale(1.02)}}@keyframes diceSix{0%{transform:scale(.9)}25%{transform:scale(1.15) rotate(6deg)}55%{transform:scale(1.02) rotate(-4deg)}to{transform:scale(1) rotate(0)}}@keyframes diceFireworks{0%{opacity:0;transform:rotate(-8deg) scale(.72);filter:blur(1.2px)}18%{opacity:1}55%{opacity:.95;transform:rotate(22deg) scale(1.06);filter:blur(.6px)}to{opacity:0;transform:rotate(46deg) scale(1.16);filter:blur(1.4px)}}@keyframes diceFlame{0%{transform:translateY(2px) scale(1.02);opacity:.8}50%{transform:translateY(-1px) scale(1.08);opacity:1}to{transform:translateY(2px) scale(1.02);opacity:.82}}.capture-burst{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle at 50% 50%,#ef4444f2,#ef44441f,#0000);animation:captureBurst .9s ease-out forwards;z-index:60}.board-kick-fx{position:absolute;left:0;top:0;width:40px;height:40px;pointer-events:none;z-index:61;transform:translate(var(--x1),var(--y1));animation:kickFxMove 1.6s cubic-bezier(.15,.85,.2,1) forwards;filter:drop-shadow(0 16px 26px rgba(0,0,0,.75)) drop-shadow(0 0 26px rgba(255,255,255,.35))}.board-kick-fx:before{content:"";position:absolute;inset:-85%;border-radius:999px;background:radial-gradient(circle at 50% 50%,#ffffff38,#fff0 55%),radial-gradient(circle at 50% 50%,#ef44442e,#ef444400 70%);opacity:0;transform:scale(.65);mix-blend-mode:screen;animation:kickFxAura 1.6s ease-out forwards;pointer-events:none}.board-kick-fx:after{content:"";position:absolute;inset:-40% -30%;border-radius:999px;background:radial-gradient(circle at 50% 50%,#ffffff59,#fff0 55%),radial-gradient(circle at 50% 50%,#ef444438,#ef444400 70%);opacity:0;transform:scale(.6);animation:kickFxPoof 1.6s ease-out forwards;mix-blend-mode:screen;pointer-events:none}.board-piece.kicked{width:72%;height:72%;cursor:default;transition:none;box-shadow:0 0 0 4px #ffffff2e,0 0 36px #ffffff6b,0 18px 38px #000000a6;animation:kickFxHit 1.6s ease-out forwards}@keyframes kickFxMove{0%{transform:translate(var(--x1),var(--y1)) scale(1);opacity:1}24%{transform:translate(var(--x1),var(--y1)) scale(1.08);opacity:1}70%{transform:translate(calc((var(--x1) + var(--x2)) / 2),calc((var(--y1) + var(--y2)) / 2 - 36px)) scale(1.02);opacity:1}to{transform:translate(var(--x2),var(--y2)) scale(.84);opacity:0}}@keyframes kickFxHit{0%{transform:rotate(0) scale(1);filter:brightness(1) saturate(1);opacity:1}10%{transform:rotate(-28deg) scale(1.14);filter:brightness(2.1) saturate(1.35) contrast(1.15);opacity:1}24%{transform:rotate(18deg) scale(1.08);filter:brightness(1.35) saturate(1.1);opacity:1}60%{transform:rotate(48deg) scale(1.02);filter:brightness(1.1) saturate(1.05);opacity:.95}to{transform:rotate(68deg) scale(.92);filter:brightness(1) saturate(1);opacity:.65}}@keyframes kickFxPoof{0%{opacity:0;transform:scale(.55)}55%{opacity:0;transform:scale(.7)}72%{opacity:.95;transform:scale(1.22)}to{opacity:0;transform:scale(1.55)}}@keyframes kickFxAura{0%{opacity:0;transform:scale(.6)}12%{opacity:.9;transform:scale(1.05)}45%{opacity:.75;transform:scale(1.18)}to{opacity:0;transform:scale(1.45)}}@keyframes captureBurst{0%{transform:scale(.15);opacity:0}10%{opacity:1}70%{transform:scale(1.25);opacity:.75}to{transform:scale(1.6);opacity:0}}.board-piece-ghost{position:absolute;pointer-events:none;z-index:58;display:flex;align-items:center;justify-content:center;animation:moveGhostPop .14s ease-out both}.board-piece-ghost .board-piece{width:70%;height:70%;cursor:default;box-shadow:0 0 20px #ffffff73,0 10px 18px #0000008c}@keyframes moveGhostPop{0%{transform:scale(.65);opacity:0}to{transform:scale(1);opacity:.9}}.board-fly-fx{position:absolute;left:0;top:0;width:16px;height:16px;border-radius:999px;pointer-events:none;z-index:59;transform:translate(var(--x1),var(--y1));animation:flyFxMove .82s cubic-bezier(.2,.85,.2,1) forwards;box-shadow:0 0 18px #ffffff59,0 14px 24px #000000a6}.board-fly-fx.kind-capture{background:radial-gradient(circle at 35% 35%,#fffffff2,#ef4444e6,#ef44441a)}.board-fly-fx.kind-block{border-radius:6px;background:linear-gradient(180deg,#94a3b8f2,#475569e6)}.board-fly-fx.kind-block:after{content:"×";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#0f172ae6;text-shadow:0 2px 10px rgba(0,0,0,.35)}@keyframes flyFxMove{0%{transform:translate(var(--x1),var(--y1)) scale(1);opacity:.15}12%{opacity:1}65%{transform:translate(calc((var(--x1) + var(--x2)) / 2),calc((var(--y1) + var(--y2)) / 2)) scale(1.08)}to{transform:translate(var(--x2),var(--y2)) scale(.92);opacity:0}}.board-field.barrier-move-from{animation:barrierMoveFrom 1.6s ease-out}.board-field.barrier-move-to{animation:barrierMoveTo 1.6s ease-out}.board-field.barrier-move-from:before{opacity:1;border-color:#fb923c59;animation:barrierRingFrom 1.6s ease-out}.board-field.barrier-move-to:before{opacity:1;border-color:#38bdf859;animation:barrierRingTo 1.6s ease-out}@keyframes barrierMoveFrom{0%{transform:translateZ(0) scale(1);box-shadow:0 0 #fb923c00}20%{transform:translateZ(0) translateY(-2px) scale(1.08);box-shadow:0 0 0 3px #fb923c38,0 0 22px #fb923c6b}55%{transform:translateZ(0) translateY(-1px) scale(1.02);box-shadow:0 0 0 2px #fb923c1f,0 0 14px #fb923c40}to{transform:translateZ(0) scale(1);box-shadow:0 0 #fb923c00}}@keyframes barrierMoveTo{0%{transform:translateZ(0) scale(.82);box-shadow:0 0 #38bdf800}26%{transform:translateZ(0) scale(1.14);box-shadow:0 0 0 4px #38bdf838,0 0 26px #38bdf86b}58%{transform:translateZ(0) scale(.96);box-shadow:0 0 0 2px #38bdf824,0 0 16px #38bdf847}to{transform:translateZ(0) scale(1);box-shadow:0 0 #38bdf800}}@keyframes barrierRingFrom{0%{opacity:0;transform:scale(.5)}22%{opacity:.95;transform:scale(1.05)}to{opacity:0;transform:scale(1.35)}}@keyframes barrierRingTo{0%{opacity:0;transform:scale(.55)}28%{opacity:.95;transform:scale(1.12)}to{opacity:0;transform:scale(1.42)}}.dice-float{position:absolute;right:10px;top:50%;transform:translateY(-50%);z-index:1600;pointer-events:none}.dice-float .dice-cube{width:68px;height:68px}.game-event-toast{position:fixed;left:50%;top:50%;bottom:auto;transform:translate(-50%,-50%);z-index:1800;display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#020617b8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#f8fafc;box-shadow:0 18px 44px #0009,0 0 0 2px #38bdf824;pointer-events:none;animation:toastPop .25s ease-out both;max-width:min(720px,calc(100vw - (var(--side-avatar-inset) + var(--side-avatar-size) + 22px) * 2))}.game-event-toast-icon{width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#38bdf829;box-shadow:0 0 0 2px #38bdf81f inset;flex:0 0 auto}.game-event-toast-text{flex:1 1 auto;min-width:0;font-weight:700;letter-spacing:.2px}.event-toast-marquee{display:block;min-width:0;max-width:100%;overflow:hidden;white-space:nowrap}.event-toast-marquee:not(.marquee){text-overflow:ellipsis}.event-toast-marquee-track{display:inline-flex;align-items:center;width:max-content}.event-toast-marquee-content{display:inline}.event-toast-marquee-spacer{display:inline-block;width:48px;flex:0 0 auto}.event-toast-marquee.marquee .event-toast-marquee-track{animation:eventToastMarquee var(--event-toast-marquee-duration, 12s) linear infinite;will-change:transform}@keyframes eventToastMarquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes toastPop{0%{transform:translate(-50%,calc(-50% + 6px)) scale(.98);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.event-toast-marquee.marquee .event-toast-marquee-track{animation:none}.event-toast-marquee{text-overflow:ellipsis}}.bottom-action{width:54px;height:54px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#0f172a80;color:#f8fafc;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:24px;padding:0;transition:transform .14s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease;transform:translateZ(0)}.bottom-action:hover:not(:disabled){background:#0f172aad;border-color:#ffffff38;box-shadow:0 10px 28px #00000059,0 0 0 2px #38bdf81f;transform:translateZ(0) scale(1.03)}.bottom-action:active:not(:disabled){transform:translateZ(0) scale(.98)}.bottom-action:disabled{opacity:.55;cursor:not-allowed}.chat-action.has-unread{box-shadow:0 0 0 4px #38bdf82e,0 0 22px #38bdf88c;border-color:#38bdf8b3}.chat-overlay{position:fixed;inset:0;z-index:2000;background:#020617b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:1rem}.chat-overlay-panel{width:min(840px,96vw);height:min(640px,84vh);border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0f172ab3;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);overflow:hidden;position:relative;display:flex}.chat-overlay-panel .chat-container{flex:1;width:100%;height:100%;border-radius:0}.chat-overlay-close{position:absolute;top:10px;right:10px;width:42px;height:42px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#0206178c;color:#f8fafc;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:24px;z-index:5}.overlay-left,.overlay-right{position:fixed;top:50%;transform:translateY(-50%);z-index:1400;pointer-events:none;display:flex;flex-direction:column;gap:10px}.overlay-left{left:8px}.overlay-right{right:8px}.corner-avatar{width:64px;height:64px;border-radius:18px;overflow:hidden;border:2px solid rgba(56,189,248,.25);background:#020617c7;box-shadow:0 18px 50px #000000a6,0 0 22px #38bdf81f;pointer-events:auto;cursor:pointer}.corner-avatar img{width:100%;height:100%;object-fit:cover;display:block}.corner-avatar-placeholder{width:100%;height:100%}.corner-avatar-empty{opacity:.4}.corner-avatar.active{box-shadow:0 0 0 4px #38bdf82e,0 0 22px #38bdf88c,0 18px 48px #0009;border-color:#38bdf8bf}.lobby-header{display:flex;justify-content:center;align-items:center;padding:2rem 0}.main-logo{max-width:500px;height:auto;width:100%;display:block;filter:drop-shadow(0 0 30px rgba(56,189,248,.3));transition:transform .3s ease}.main-logo:hover{transform:scale(1.02)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.game-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding:.45rem .75rem;background:#020617a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:0;box-shadow:0 4px 6px -1px #0000001a;border:1px solid rgba(255,255,255,.1)}.header-left,.header-center,.header-right{display:flex;align-items:center;gap:.75rem;padding-right:0}.header-center{flex:1;justify-content:center;min-width:0}.game-logo-img{height:56px;width:56px;object-fit:contain;display:block}.game-logo-video{height:48px;width:48px;object-fit:contain;display:block}.game-title{display:flex;align-items:baseline;gap:.6rem;min-width:0}.game-title-name{font-weight:900;font-size:1.15rem;letter-spacing:.02em}.game-title-player{font-weight:900;font-size:1.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:22vw}.turn-center{font-weight:900;font-size:1.15rem;display:flex;align-items:center;justify-content:center;gap:10px;min-width:0;max-width:100%}.turn-marquee{display:block;min-width:0;max-width:100%;overflow:hidden;white-space:nowrap}.turn-marquee:not(.marquee){text-overflow:ellipsis}.turn-marquee-track{display:inline-flex;align-items:center;width:max-content}.turn-marquee-content{display:inline}.turn-marquee-spacer{display:inline-block;width:56px;flex:0 0 auto}.turn-marquee.marquee .turn-marquee-track{animation:turnMarquee var(--turn-marquee-duration, 12s) linear infinite;will-change:transform}@keyframes turnMarquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.turn-marquee.marquee .turn-marquee-track{animation:none}.turn-marquee{text-overflow:ellipsis}}.turn-timer-inline{font-size:.95rem;opacity:.7}.color-red{color:#ef4444}.color-blue{color:#3b82f6}.color-green{color:#22c55e}.color-yellow{color:#facc15}.exit-fixed{position:fixed;top:10px;right:10px;z-index:2200;width:92px;height:72px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#020617a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#f8fafc;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 16px 40px #00000073;padding:0}.exit-fixed-icon{font-size:1.15rem;font-weight:900;line-height:1}.exit-fixed-label{font-size:.7rem;font-weight:900;line-height:1}.leave-button-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:.35rem .7rem;line-height:1}.leave-button-icon{font-size:1rem;font-weight:900}.leave-button-label{font-size:.7rem;font-weight:900}.bottom-action.pulse{animation:actionPulse 1.1s ease-in-out infinite}.bottom-action.pulse.color-red{border-color:#ef4444cc;box-shadow:0 0 0 5px #ef444429,0 0 34px #ef4444b8,0 0 70px #ef444438}.bottom-action.pulse.color-blue{border-color:#3b82f6d9;box-shadow:0 0 0 5px #3b82f629,0 0 34px #3b82f6b8,0 0 70px #3b82f638}.bottom-action.pulse.color-green{border-color:#22c55ed9;box-shadow:0 0 0 5px #22c55e29,0 0 34px #22c55eb8,0 0 70px #22c55e38}.bottom-action.pulse.color-yellow{border-color:#facc15d9;box-shadow:0 0 0 5px #facc1529,0 0 34px #facc15b8,0 0 70px #facc1538}@keyframes actionPulse{0%{transform:translateZ(0) scale(1) rotate(0)}35%{transform:translateZ(0) scale(1.14) rotate(-1.5deg)}70%{transform:translateZ(0) scale(1.07) rotate(1deg)}to{transform:translateZ(0) scale(1) rotate(0)}}.lobby-wait-card{max-width:500px;width:100%;text-align:center}.subtle-text{opacity:.7;margin-bottom:2rem}.info-box{margin-bottom:1.5rem;text-align:left}.info-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.5;margin-bottom:.5rem;display:block}.input-group{display:flex;gap:.5rem}.input-group input{flex-grow:1;text-align:center;font-size:1.1rem}.input-group button{flex-shrink:0}.player-lobby-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.player-lobby-list li{background:#ffffff0d;padding:.8rem 1rem;border-radius:6px}.start-button{width:100%;padding:1rem;font-size:1.2rem;margin-top:1rem}.game-shell{width:100vw;width:var(--app-vw, 100vw);height:100vh;height:100dvh;height:var(--app-vh, 100dvh);display:flex;flex-direction:column;overflow:hidden;position:relative;--side-avatar-top: 94px;--side-avatar-bottom: 48px;--side-avatar-inset: 48px;--side-avatar-size: 64px}.game-shell-main{flex:1 1 auto;min-height:0;background:#020617;display:flex;align-items:stretch;justify-content:stretch;position:relative}.game-top-row{position:fixed;left:12px;right:12px;top:calc(12px + env(safe-area-inset-top));z-index:1700;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;pointer-events:none}.game-top-left,.game-top-right{display:inline-flex;align-items:center;gap:10px;pointer-events:auto}.game-top-center{display:flex;justify-content:center;min-width:0;pointer-events:none}.game-top-actions{display:inline-flex;align-items:center;gap:10px;pointer-events:auto}.game-shell-main:before{content:"";position:absolute;inset:-40%;pointer-events:none;z-index:0;opacity:.75;background-image:radial-gradient(circle,#e2e8f05c 1px,#0000 1.6px),radial-gradient(circle,#e2e8f038 1px,#0000 1.8px),radial-gradient(circle,#e2e8f029 1px,#0000 2px),radial-gradient(900px 520px at 50% 35%,#38bdf81f,#02061700 60%),radial-gradient(720px 520px at 18% 82%,#22c55e16,#02061700 60%),radial-gradient(720px 520px at 82% 78%,#a855f713,#02061700 62%);background-size:180px 180px,260px 260px,360px 360px,auto,auto,auto;background-position:0 0,40px 70px,120px 20px,center,center,center;background-repeat:repeat,repeat,repeat,no-repeat,no-repeat,no-repeat;animation:starClusterDrift 90s linear infinite;filter:saturate(.95) contrast(1.12);transform:translateZ(0)}.game-shell-main:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(circle at 50% 38%,#02061700,#02061740 62%,#020617a6)}@keyframes starClusterDrift{0%{background-position:0 0,40px 70px,120px 20px,center,center,center}to{background-position:-520px 320px,-360px 240px,-260px 160px,center,center,center}}.game-board-anchor{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);will-change:transform;isolation:isolate;z-index:1}.board-corner-avatars{position:fixed;inset:0;z-index:1700;pointer-events:none}.board-corner{position:fixed;pointer-events:auto}.board-corner.tl,.board-corner.bl{left:var(--side-avatar-inset)}.board-corner.tr,.board-corner.br{right:var(--side-avatar-inset)}.board-corner.tl,.board-corner.tr{top:var(--side-avatar-top)}.board-corner.bl,.board-corner.br{bottom:var(--side-avatar-bottom)}.game-float-bottom-actions{--rail-size: 64px;--rail-gap: 12px;--rail-pad-y: 10px;--rail-pad-x: 12px;position:fixed;right:calc(var(--side-avatar-inset) - var(--rail-pad-x));top:calc(50% + (var(--side-avatar-top) - var(--side-avatar-bottom)) / 2);transform:translateY(-50%);z-index:1700;display:flex;flex-direction:column;align-items:center;gap:var(--rail-gap);padding:var(--rail-pad-y) var(--rail-pad-x);border-radius:18px;background:#02061780;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 55px #0000008c;pointer-events:auto}.game-right-rail-dice{pointer-events:auto;touch-action:none;cursor:grab}.game-float-bottom-actions.dragging .game-right-rail-dice{cursor:grabbing}.game-float-bottom-actions .bottom-action{width:var(--rail-size);height:var(--rail-size);border-radius:18px}.game-float-bottom-actions .dice-cube{width:var(--rail-size);height:var(--rail-size)}.game-float-bottom-actions .material-symbols-rounded{font-size:clamp(18px,calc(var(--rail-size) * .42),28px);line-height:1}.game-float-bottom-actions .dot-container{padding:clamp(6px,calc(var(--rail-size) * .16),10px)}.game-float-bottom-actions .dice-dot{width:clamp(8px,calc(var(--rail-size) * .22),14px);height:clamp(8px,calc(var(--rail-size) * .22),14px)}@media(max-height:620px),(max-width:460px){.game-float-bottom-actions{--rail-size: 56px;--rail-gap: 10px;--rail-pad-y: 8px;--rail-pad-x: 10px}}@media(max-height:520px),(max-width:400px){.game-float-bottom-actions{--rail-size: 48px;--rail-gap: 9px;--rail-pad-y: 7px;--rail-pad-x: 9px}}@media(max-height:440px){.game-float-bottom-actions{--rail-size: 42px;--rail-gap: 8px;--rail-pad-y: 6px;--rail-pad-x: 8px}}.game-board-backplate{position:absolute;inset:-22px;border-radius:26px;background:radial-gradient(600px 420px at 50% 35%,#38bdf81f,#02061700 65%),linear-gradient(180deg,#0f172ab8,#0206178c);box-shadow:0 34px 120px #000000bf,0 0 #0000;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);pointer-events:none;z-index:0}.game-board-scale{position:relative;z-index:1}.game-overlay-dice{position:fixed;right:14px;top:50%;transform:translateY(-50%);z-index:1700;pointer-events:none}.game-avatar-tile{width:64px;height:64px;border-radius:18px;overflow:hidden;position:relative;border:2px solid rgba(56,189,248,.25);background:#020617c7;box-shadow:0 18px 50px #000000a6,0 0 22px #38bdf81f;pointer-events:auto;cursor:pointer;padding:0;display:block;transform:translateZ(0);--glow-rgb: 56, 189, 248}.game-avatar-tile.color-red{background:#ef444414;--glow-rgb: 239, 68, 68}.game-avatar-tile.color-blue{background:#3b82f614;--glow-rgb: 59, 130, 246}.game-avatar-tile.color-green{background:#22c55e14;--glow-rgb: 34, 197, 94}.game-avatar-tile.color-yellow{background:#facc1514;--glow-rgb: 250, 204, 21}.game-avatar-tile.color-red{border-color:#ef4444b3}.game-avatar-tile.color-blue{border-color:#3b82f6b3}.game-avatar-tile.color-green{border-color:#22c55eb3}.game-avatar-tile.color-yellow{border-color:#facc15b3}.game-avatar-tile.color-red.active{border-color:#ef4444f2}.game-avatar-tile.color-blue.active{border-color:#3b82f6f2}.game-avatar-tile.color-green.active{border-color:#22c55ef2}.game-avatar-tile.color-yellow.active{border-color:#facc15f2}.game-avatar-tile img{width:100%;height:100%;object-fit:cover;display:block}.game-avatar-tile-empty{opacity:.35}.game-avatar-empty-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:.7}.game-avatar-tile.active{animation:avatarTurnPulse .78s ease-in-out infinite;box-shadow:0 0 0 8px rgba(var(--glow-rgb),.3),0 0 46px rgba(var(--glow-rgb),1),0 0 130px rgba(var(--glow-rgb),.55),0 30px 90px #000c;border-color:rgba(var(--glow-rgb),.95);z-index:2500}.game-avatar-tile.active:before{content:"";position:absolute;inset:-9px;border-radius:26px;background:conic-gradient(from 0deg,rgba(var(--glow-rgb),1),#fffffff2,rgba(var(--glow-rgb),1),#ffffffd9,rgba(var(--glow-rgb),1));filter:blur(.2px);opacity:.95;animation:avatarRingRotate 1.1s linear infinite;-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 10px),#000 calc(100% - 9px));mask:radial-gradient(farthest-side,transparent calc(100% - 10px),#000 calc(100% - 9px));pointer-events:none}.game-avatar-tile.active:after{content:"";position:absolute;inset:-28px;border-radius:40px;background:radial-gradient(circle at 50% 50%,rgba(var(--glow-rgb),.42),rgba(var(--glow-rgb),0) 65%);filter:blur(6px);opacity:.9;animation:avatarHaloPulse .78s ease-in-out infinite;pointer-events:none}@keyframes avatarTurnPulse{0%{transform:translateZ(0) scale(1.02);box-shadow:0 0 0 7px rgba(var(--glow-rgb),.25),0 0 32px rgba(var(--glow-rgb),.85),0 0 92px rgba(var(--glow-rgb),.35),0 24px 70px #000000b8}50%{transform:translateZ(0) scale(1.22);box-shadow:0 0 0 12px rgba(var(--glow-rgb),.4),0 0 60px rgba(var(--glow-rgb),1),0 0 170px rgba(var(--glow-rgb),.62),0 34px 100px #000000d1}to{transform:translateZ(0) scale(1.02);box-shadow:0 0 0 7px rgba(var(--glow-rgb),.25),0 0 32px rgba(var(--glow-rgb),.85),0 0 92px rgba(var(--glow-rgb),.35),0 24px 70px #000000b8}}@keyframes avatarRingRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes avatarHaloPulse{0%{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1)}to{opacity:.55;transform:scale(.92)}}@media(prefers-reduced-motion:reduce){.game-avatar-tile.active{animation:none;transform:translateZ(0) scale(1.16)}.game-avatar-tile.active:before,.game-avatar-tile.active:after{animation:none}}.debug-metrics{position:fixed;left:12px;bottom:12px;z-index:2200;padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.2;background:#0009;border:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none}.winner-banner{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2100;padding:18px 22px;border-radius:18px;background:#020617c7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 55px #0009;text-align:center;max-width:min(720px,92vw);overflow:hidden}.winner-banner>*{position:relative;z-index:2}.winner-banner.winner-fireworks:before{content:"";position:absolute;inset:-50%;z-index:0;background:radial-gradient(circle at 18% 28%,#facc15f2,#facc1500 34%),radial-gradient(circle at 72% 34%,#fbbf24e0,#fbbf2400 38%),radial-gradient(circle at 35% 72%,#fde047c7,#fde04700 40%),radial-gradient(circle at 78% 78%,#f59e0bb8,#f59e0b00 44%),radial-gradient(circle at 50% 50%,#facc1524,#facc1500 60%);mix-blend-mode:screen;opacity:.95;filter:blur(.9px);transform:rotate(0) scale(.9);animation:winnerFireworks 2.4s ease-in-out infinite}.winner-banner.winner-fireworks:after{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 50% 50%,#facc1524,#facc1500 55%),linear-gradient(115deg,#fff0,#facc151a,#fff0);opacity:.75;mix-blend-mode:screen;filter:blur(.6px);transform:translate(-18%);animation:winnerShine 1.8s ease-in-out infinite}.winner-banner-title{font-weight:900;font-size:1.4rem;margin-bottom:6px}.winner-banner-sub{opacity:.75;font-weight:700}@keyframes winnerFireworks{0%{opacity:.15;transform:rotate(-10deg) scale(.86);filter:blur(1.1px)}22%{opacity:.95}55%{opacity:.75;transform:rotate(18deg) scale(1.06);filter:blur(.8px)}78%{opacity:.95}to{opacity:.15;transform:rotate(42deg) scale(.9);filter:blur(1.1px)}}@keyframes winnerShine{0%{opacity:.15;transform:translate(-24%)}50%{opacity:.8;transform:translate(24%)}to{opacity:.15;transform:translate(-24%)}}
