@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}.board-page{background:#d9be93;flex-direction:column;justify-content:center;align-items:center;gap:clamp(20px,4vh,36px);width:100vw;min-height:100dvh;padding:clamp(24px,5vw,48px) clamp(16px,4vw,32px);font-family:Fredoka,sans-serif;display:flex;position:relative;overflow:hidden}.bg-orb{pointer-events:none;filter:blur(100px);z-index:0;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#7f1d3b21 0%,#0000 70%);width:clamp(280px,50vw,560px);height:clamp(280px,50vw,560px);animation:14s ease-in-out infinite alternate orbDrift;top:-30%;left:-15%}.orb-2{background:radial-gradient(circle,#b5451b1a 0%,#0000 70%);width:clamp(220px,40vw,440px);height:clamp(220px,40vw,440px);animation:18s ease-in-out infinite alternate-reverse orbDrift;bottom:-25%;right:-12%}@keyframes orbDrift{0%{transform:translate(0)}to{transform:translate(28px,20px)}}.board-page>:not(.bg-orb){z-index:1;position:relative}.page-header{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.board-title{color:#6b1530;letter-spacing:.04em;font-size:clamp(1.6rem,5vw,3.4rem);font-weight:700;line-height:1.1}.title-sep{color:#6b153059;margin:0 6px;font-size:.7em;animation:3s ease-in-out infinite twinkle;display:inline-block}@keyframes twinkle{0%,to{opacity:.25;transform:scale(.85)rotate(0)}50%{opacity:.65;transform:scale(1.2)rotate(18deg)}}.board-subtitle{letter-spacing:.22em;text-transform:uppercase;color:#6b153061;font-size:clamp(.7rem,1.8vw,.95rem);font-weight:400}.arena{justify-content:center;align-items:center;gap:clamp(20px,4vw,56px);width:100%;max-width:900px;display:flex}.player-slot{flex-direction:column;flex-shrink:0;align-items:center;gap:clamp(6px,1.2vh,10px);width:clamp(72px,10vw,110px);transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .35s;display:flex;position:relative}.player-slot.is-active{transform:translateY(-6px)}.player-slot.is-winner{transform:translateY(-8px)}.player-slot.is-loser{opacity:.38;transform:scale(.95)}.crown{filter:drop-shadow(0 2px 5px #00000029);font-size:clamp(1rem,2.5vw,1.4rem);animation:.55s cubic-bezier(.34,1.56,.64,1) forwards crownDrop;position:absolute;top:-22px}@keyframes crownDrop{0%{opacity:0;transform:translateY(-14px)scale(.3)rotate(-18deg)}to{opacity:1;transform:translateY(0)scale(1)rotate(0)}}.user-avatar-wrap{width:clamp(56px,8vw,88px);height:clamp(56px,8vw,88px)}.user-avatar{object-fit:contain;width:100%;height:100%;transition:transform .3s}.is-active .user-avatar{animation:2.4s ease-in-out infinite avatarFloat}@keyframes avatarFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.is-winner .user-avatar{animation:.5s cubic-bezier(.34,1.56,.64,1) forwards avatarWin}@keyframes avatarWin{0%{transform:scale(1)}45%{transform:scale(1.18)rotate(-5deg)}75%{transform:scale(1.1)rotate(3deg)}to{transform:scale(1.08)rotate(0)}}.player-name{letter-spacing:.05em;color:#6b15307a;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:clamp(.7rem,1.5vw,.85rem);font-weight:500;overflow:hidden}.player-piece-row{align-items:center;gap:5px;display:flex}.player-piece-icon{object-fit:contain;filter:drop-shadow(0 2px 4px #0000001a);width:clamp(18px,2.5vw,26px);height:clamp(18px,2.5vw,26px)}.is-active .player-piece-icon{animation:1.6s ease-in-out infinite alternate pieceWiggle}@keyframes pieceWiggle{0%{transform:rotate(-6deg)scale(.95)}to{transform:rotate(6deg)scale(1.05)}}.score-value{color:#6b1530;font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;line-height:1;display:block}.score-pop{animation:.45s cubic-bezier(.34,1.56,.64,1) scorePop}@keyframes scorePop{0%{transform:scale(1)}38%{color:#b5451b;transform:scale(1.5)}to{transform:scale(1)}}.board-column{flex-direction:column;flex-shrink:0;align-items:center;gap:clamp(12px,2.5vh,20px);min-width:0;display:flex}.status-pill{letter-spacing:.03em;white-space:nowrap;border-radius:50px;align-items:center;gap:7px;min-height:36px;padding:clamp(6px,1vh,9px) clamp(14px,3vw,22px);font-size:clamp(.82rem,2vw,1rem);font-weight:500;transition:background .3s,border-color .3s,box-shadow .3s;display:flex}.pill-turn{color:#6b153099;background:#6b153012;border:1.5px solid #6b15301a}.pill-win{color:#6b1530;background:#6b15301a;border:1.5px solid #6b153047;animation:.4s cubic-bezier(.34,1.56,.64,1) pillPop;box-shadow:0 4px 20px #6b153024}.pill-draw{color:#6b153080;background:#6b15300d;border:1.5px solid #6b15301a}@keyframes pillPop{0%{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}.pill-icon{object-fit:contain;filter:drop-shadow(0 1px 3px #0000001a);flex-shrink:0;width:clamp(16px,2.5vw,22px);height:clamp(16px,2.5vw,22px)}.pill-icon-bounce{animation:1.1s ease-in-out infinite alternate pillBounce}@keyframes pillBounce{0%{transform:rotate(-8deg)scale(.92)}to{transform:rotate(8deg)scale(1.08)}}.pill-emoji{font-size:1em;animation:.5s cubic-bezier(.34,1.56,.64,1) emojiPop}@keyframes emojiPop{0%{transform:scale(0)rotate(-25deg)}to{transform:scale(1)rotate(0)}}.board-wrap{-webkit-backdrop-filter:blur(8px);background:#fffaee6b;border:3px dashed #6b153066;border-radius:30px;padding:clamp(10px,2vw,16px);position:relative;overflow:hidden;box-shadow:inset 0 2px #ffffff80,0 16px 56px #6b15301c,0 4px 16px #6b153012}.tic-board{--board-size:min(330px, calc(100vw - 220px));width:var(--board-size);height:var(--board-size);grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);display:grid;position:relative}.v-line,.h-line{z-index:1;border-radius:999px;position:absolute}.v-line{background:linear-gradient(#0000 0%,#6b15308c 20% 80%,#0000 100%);width:3.5px;top:10px;bottom:10px}.h-line{background:linear-gradient(90deg,#0000 0%,#6b15308c 20% 80%,#0000 100%);height:3.5px;left:10px;right:10px}.v-line.left{left:33.33%;transform:translate(-50%)}.v-line.right{left:66.66%;transform:translate(-50%)}.h-line.top{top:33.33%;transform:translateY(-50%)}.h-line.bottom{top:66.66%;transform:translateY(-50%)}.cell{cursor:pointer;z-index:2;border-radius:14px;justify-content:center;align-items:center;min-width:44px;min-height:44px;transition:background .16s,transform .2s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.cell-empty:hover{background:#6b15300f;transform:scale(1.08)}.cell-ghost{object-fit:contain;opacity:0;pointer-events:none;filter:opacity(.3);width:55%;height:55%;transition:opacity .16s,transform .16s;position:absolute}.cell-empty:hover .cell-ghost{opacity:1;transform:scale(.86)}.cell-symbol{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 4px 10px #00000021);width:72%;height:72%;animation:.38s cubic-bezier(.34,1.56,.64,1) pieceLand}@keyframes pieceLand{0%{opacity:0;transform:scale(.1)rotate(-20deg)}55%{opacity:1;transform:scale(1.16)rotate(4deg)}to{opacity:1;transform:scale(1)rotate(0)}}.cell-win{background:#6b153012;border-radius:14px}.cell-win .cell-symbol{animation:1.9s ease-in-out infinite alternate winGlow}@keyframes winGlow{0%{filter:drop-shadow(0 0 5px #6b153059)drop-shadow(0 0 12px #b5451b2e);transform:scale(1)}to{filter:drop-shadow(0 0 14px #6b1530a6)drop-shadow(0 0 26px #b5451b66);transform:scale(1.08)}}.particle{pointer-events:none;z-index:20;animation:2.2s ease-out forwards particleFly;position:absolute}@keyframes particleFly{0%{opacity:1;transform:scale(0)translate(0)}20%{opacity:1;transform:scale(1.4)translate(0)}to{transform:scale(.3) translate(var(--tx,40px), var(--ty,-60px));opacity:0}}.actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.btn{letter-spacing:.04em;cursor:pointer;white-space:nowrap;border:none;border-radius:50px;align-items:center;gap:6px;min-height:44px;padding:clamp(8px,1.5vh,11px) clamp(16px,3vw,24px);font-family:Fredoka,sans-serif;font-size:clamp(.85rem,2vw,1rem);font-weight:600;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;display:flex;position:relative;overflow:hidden}.btn-icon{color:#6a192b;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;width:18px;height:18px}.btn:after{content:"";background:linear-gradient(110deg,#0000 36%,#ffffff4d 50%,#0000 64%);transition:transform .5s;position:absolute;inset:0;transform:translate(-130%)}.btn:hover:after{transform:translate(130%)}.btn:active{transform:scale(.93)!important}.btn-spin{font-size:1.1em;transition:transform .4s;display:inline-block}.btn-primary:hover .btn-spin{transform:rotate(-180deg)}.btn-primary{color:#f5e6c8;background:#6b1530;box-shadow:inset 0 2px #ffffff1f,0 6px 22px #6b15305c}.btn-primary:hover{transform:translateY(-2px);box-shadow:inset 0 2px #ffffff1f,0 10px 28px #6b153075}.btn-outline{color:#6b1530;background:#fff8e899;border:1.5px solid #6b153047;box-shadow:0 2px 8px #6b15300f}.btn-outline:hover{background:#fff8e8e0;border-color:#6b15307a;transform:translateY(-2px);box-shadow:0 4px 16px #6b153021}.pagination{align-items:center;gap:8px;display:flex}.pagination span{background:#6b153033;border-radius:50%;width:8px;height:8px;transition:background .25s,transform .25s;display:block}.pagination .active{background:#6b1530;transform:scale(1.4);box-shadow:0 0 6px #6b15304d}@media (width<=860px){.arena{gap:clamp(16px,3vw,32px)}.tic-board{--board-size:min(300px, calc(100vw - 200px))}}@media (width<=600px){.board-page{justify-content:center;gap:clamp(14px,3vh,22px);padding:clamp(20px,5vh,36px) 20px}.arena{flex-direction:column;align-items:center;gap:clamp(14px,3vh,22px);width:100%}.arena>.player-slot:first-child{order:1}.arena>.board-column{order:2}.arena>.player-slot:last-child{order:3}.board-column{gap:clamp(10px,2vh,16px);width:100%}.tic-board{--board-size:min(320px, calc(100vw - 40px))}.player-slot{grid-template-rows:auto;grid-template-columns:52px minmax(0,1fr) auto;justify-content:stretch;align-items:center;gap:10px;width:100%;max-width:320px;padding:0 6px;display:grid}.user-avatar-wrap{flex-shrink:0;width:52px;height:52px}.player-slot .player-name{text-align:left;min-width:0;font-size:.88rem}.player-piece-row{justify-self:end;gap:5px}.player-piece-icon{width:20px;height:20px}.score-value{font-size:1.2rem}.crown{display:none}}@media (width<=380px){.board-title{font-size:1.4rem}.board-subtitle{letter-spacing:.14em;font-size:.65rem}.tic-board{--board-size:calc(100vw - 36px)}.status-pill{padding:6px 14px;font-size:.78rem}.btn{padding:8px 16px;font-size:.82rem}.player-slot{grid-template-columns:42px minmax(0,1fr) auto;gap:8px;max-width:300px}.user-avatar-wrap{width:42px;height:42px}.player-slot .player-name{font-size:.8rem}.player-piece-icon{width:16px;height:16px}.score-value{font-size:1rem}}@media (width>=1200px){.tic-board{--board-size:360px}.arena{gap:64px}.user-avatar-wrap{width:96px;height:96px}.score-value{font-size:1.8rem}.player-piece-icon{width:28px;height:28px}}@media (height<=500px) and (orientation:landscape){.board-page{flex-flow:wrap;justify-content:center;align-items:center;gap:16px;padding:12px 20px}.page-header{gap:2px}.board-title{font-size:1.3rem}.board-subtitle{display:none}.arena{flex-direction:row;align-items:center;gap:20px}.tic-board{--board-size:min(260px, calc(100vh - 80px))}.player-slot{gap:6px;width:80px}.user-avatar-wrap{width:48px;height:48px}.score-value{font-size:1.1rem}.board-column{gap:10px}.status-pill{min-height:32px;padding:5px 14px;font-size:.8rem}.btn{min-height:36px;padding:7px 14px;font-size:.8rem}.pagination{display:none}}.fm-overlay{-webkit-backdrop-filter:blur(6px);z-index:100;background:#6b15302e;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.fm-card{flex-direction:column;gap:20px;width:100%;max-width:400px;padding:28px 28px 24px;animation:.3s cubic-bezier(.34,1.56,.64,1) pillPop;display:flex;position:relative}.fm-header{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.fm-close{color:#6b153073;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:1rem;line-height:1;transition:color .2s,background .2s;position:absolute;top:16px;right:16px}.fm-close:hover{color:#6b1530;background:#6b153014}.fm-field{flex-direction:column;gap:6px;display:flex}.fm-label{letter-spacing:.1em;text-transform:uppercase;font-size:.75rem!important}.fm-input{color:#6b1530;background:#fff8e8b3;border:1.5px solid #6b153038;border-radius:14px;outline:none;width:100%;padding:10px 16px;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.fm-input::placeholder{color:#6b15304d}.fm-input:focus{border-color:#6b153080;box-shadow:0 0 0 3px #6b153014}.fm-input-code{text-transform:uppercase;letter-spacing:.18em;text-align:center;font-size:1.1rem}.fm-tabs{background:#6b15300f;border-radius:50px;gap:8px;padding:4px;display:flex}.fm-tab{color:#6b153080;cursor:pointer;background:0 0;border:none;border-radius:50px;flex:1;padding:8px 12px;font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:600;transition:background .2s,color .2s}.fm-tab:hover{color:#6b1530}.fm-tab-active{color:#f5e6c8;background:#6b1530}.fm-section{flex-direction:column;gap:14px;display:flex}.fm-hint{color:#6b153080;text-align:center;font-family:Fredoka,sans-serif;font-size:.85rem;font-weight:400;line-height:1.4}.fm-btn{justify-content:center;width:100%}.fm-error{color:#9e2347;text-align:center;background:#9e234714;border-radius:10px;padding:8px 14px;font-family:Fredoka,sans-serif;font-size:.88rem;font-weight:500}.fm-code-display{flex-direction:column;align-items:center;gap:10px;display:flex}.fm-code-label{letter-spacing:.14em;text-transform:uppercase;font-size:.72rem!important}.fm-code-value{color:#6b1530;letter-spacing:.22em;background:#6b15300f;border:2px dashed #6b153040;border-radius:16px;padding:12px 28px;font-family:Fredoka,sans-serif;font-size:2.6rem;font-weight:700;line-height:1}.fm-copy-btn{font-size:.82rem}.fm-waiting-pill{justify-content:center;gap:10px}.fm-dot{background:#6b153080;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1.2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}.fm-disconnect-banner{animation:.4s cubic-bezier(.34,1.56,.64,1) pillPop}.fm-waiting-text{opacity:.55;font-size:.78em;font-style:italic}@media (width<=480px){.fm-card{gap:16px;padding:22px 18px 20px}.fm-code-value{padding:10px 20px;font-size:2rem}}.fm-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.fm-card{background:#fffaf0!important}
