html,body{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}#root{width:100%;height:100%}.hub-body{background:var(--bg-primary);width:100%;height:100%;font-family:var(--font-family);margin:0;padding:0;overflow:hidden}.hub-container{background:var(--bg-primary);width:100%;height:100%;color:var(--text-primary);display:flex;overflow:hidden}.hub-sidebar{background:var(--bg-surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;width:250px;display:flex}.hub-brand{border-bottom:1px solid var(--border);padding:20px}.hub-brand h2{color:var(--accent);margin:10px 0 0;font-size:20px}.game-list{flex:1;margin:0;padding:10px;list-style:none;overflow-y:auto}.game-list li{cursor:pointer;color:var(--text-secondary);border-radius:8px;margin-bottom:4px;padding:12px 16px;font-weight:500;transition:all .2s}.game-list li:hover{background:var(--bg-hover);color:var(--text-primary)}.game-list li.active{background:var(--accent-glow);color:var(--accent);border-left:3px solid var(--accent)}.sidebar-section{border-bottom:1px solid var(--border);padding:10px 0}.sidebar-section:last-child{border-bottom:none}.sidebar-header{text-transform:uppercase;color:var(--text-muted);letter-spacing:1px;padding:0 16px 8px;font-size:11px;font-weight:700}.empty-list-msg{font-style:italic;color:var(--text-muted)!important;cursor:default!important;padding:4px 16px!important;font-size:12px!important}.empty-list-msg:hover{background:0 0!important}.game-list li{justify-content:space-between;align-items:center;display:flex}.game-list li .game-label{flex:1;align-items:center;gap:8px;display:flex}.fav-btn{color:var(--text-muted);opacity:0;border-radius:4px;padding:4px;transition:all .2s}.game-list li:hover .fav-btn,.fav-btn.is-fav{opacity:1}.fav-btn:hover{color:#fbbf24;background:#fbbf241a}.fav-btn.is-fav{color:#fbbf24}.hub-content{flex-direction:column;flex:1;min-width:0;height:100%;min-height:0;display:flex;position:relative}.hub-top-bar{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:9999;flex-shrink:0;justify-content:space-between;align-items:center;width:100%;height:60px;padding:0 20px;position:relative;display:flex!important}.top-bar-left,.top-bar-right{align-items:center;gap:15px;display:flex}.room-status{align-items:center;gap:8px;display:flex}.status-indicator{border-radius:50%;width:10px;height:10px}.status-indicator.global{background:#38bdf8;box-shadow:0 0 8px #38bdf8}.status-indicator.private{background:#10b981;box-shadow:0 0 8px #10b981}.status-text{color:var(--text-primary);font-weight:600}.user-profile{background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;align-items:center;gap:8px;padding:6px 12px;transition:all .2s;display:flex}.user-profile:hover{background:var(--bg-hover);border-color:var(--accent)}.user-avatar{background-position:50%;background-size:cover;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.2rem;display:inline-flex}.user-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.room-actions-top{gap:8px;display:flex}.room-actions-active{align-items:center;gap:12px;display:flex}.pin-badge{color:#10b981;cursor:pointer;background:#10b9811a;border:1px solid #10b9814d;border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-weight:600;transition:all .2s;display:flex}.pin-badge:hover{background:#10b98133}.copy-icon{font-size:1.1rem}.chat-toggle-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:relative}.chat-toggle-btn:hover{background:var(--accent);color:#000}.chat-badge{border:2px solid var(--bg-surface);background:#f43f5e;border-radius:50%;width:10px;height:10px;position:absolute;top:0;right:0}.hub-main{background:var(--bg-primary);flex:1;min-width:0;position:relative;overflow:hidden auto}#game-iframe{border:none;width:100%;height:100%;display:none}#lobby-view{flex-direction:column;align-items:center;padding:40px;display:flex;position:absolute;inset:0;overflow-y:auto}.lobby-welcome{text-align:center;max-width:800px}.lobby-welcome p.subtitle{color:var(--text-secondary);margin-bottom:30px;font-size:1.1rem}.how-to-play{text-align:left;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;max-width:600px;margin:0 auto;padding:24px 32px}.how-to-play h3{color:var(--accent);margin-top:0}.how-to-play ol{color:var(--text-secondary);padding-left:20px;line-height:1.6}.how-to-play li{margin-bottom:12px}.how-to-play strong{color:var(--text-primary)}.lobby-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:40px;display:grid}.game-card{background:var(--bg-surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:30px 20px;transition:transform .2s}.game-card:hover{border-color:var(--accent);transform:translateY(-5px)}.floating-chat-fab{background:var(--accent);color:#000;cursor:pointer;z-index:9000;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #00d4aa66}.floating-chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #00d4aa99}.fab-badge{color:#fff;border:2px solid var(--bg-primary);background:#f43f5e;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 4px;font-size:11px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}@media (width<=768px){.floating-chat-fab{bottom:72px;right:16px}}.floating-chat-window{background:var(--bg-surface);border:1px solid var(--border);z-index:8999;border-radius:16px;flex-direction:column;width:340px;height:460px;display:flex;position:fixed;bottom:92px;right:24px;overflow:hidden;box-shadow:0 12px 40px #0006}@media (width<=768px){.floating-chat-window{width:auto;height:50vh;bottom:140px;left:12px;right:12px}}.floating-chat-header{border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.floating-chat-title{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.floating-chat-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:color .2s,background .2s;display:flex}.floating-chat-close:hover{color:#f43f5e;background:#f43f5e1a}.floating-chat-messages{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.chat-empty-state{height:100%;color:var(--text-muted);text-align:center;opacity:.6;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.chat-msg{background:var(--bg-elevated);word-wrap:break-word;border-radius:10px;align-self:flex-start;max-width:85%;padding:8px 12px;font-size:13px}.chat-msg.self{background:var(--accent);color:#000;align-self:flex-end}.chat-msg .sender{color:var(--text-muted);margin-bottom:3px;font-size:11px;font-weight:600;display:block}.chat-msg.self .sender{color:#0000008c}.floating-chat-input{border-top:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;gap:8px;padding:12px;display:flex}.floating-chat-input input{border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;outline:none;flex:1;padding:9px 12px;font-size:13px}.floating-chat-input input:focus{border-color:var(--accent)}.floating-send-btn{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .2s;display:flex}.floating-send-btn:hover{opacity:.85}.welcome-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;opacity:0;pointer-events:none;background:#000c;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.welcome-overlay.show{opacity:1;pointer-events:auto}.welcome-modal{background:var(--bg-surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:90%;max-width:400px;padding:40px;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translateY(20px);box-shadow:0 20px 40px #00000080}.welcome-overlay.show .welcome-modal{transform:translateY(0)}.welcome-modal h2{color:var(--accent);margin-top:0}.welcome-modal p{color:var(--text-secondary);margin-bottom:20px}.btn-close-modal{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:20px;transition:color .2s;position:absolute;top:15px;right:15px}.btn-close-modal:hover{color:#f43f5e}.floating-call-window{background:var(--bg-surface);border:1px solid var(--border);z-index:50;resize:both;border-radius:12px;flex-direction:column;width:320px;min-width:250px;min-height:200px;display:flex;position:absolute;top:80px;right:20px;overflow:hidden;box-shadow:0 10px 25px #00000080}.call-header{background:var(--bg-elevated);border-bottom:1px solid var(--border);cursor:grab;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 15px;display:flex}.call-header:active{cursor:grabbing}.call-header span{color:var(--text-primary);font-size:14px;font-weight:600}.btn-close-call{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:16px;transition:color .2s}.btn-close-call:hover{color:#f43f5e}#jitsi-container{flex:1;width:100%;height:100%;min-height:200px}.avatar-selection{flex-wrap:wrap;justify-content:center;gap:15px;margin:20px 0;display:flex}.avatar-option{background:var(--bg-elevated);cursor:pointer;background-position:50%;background-size:cover;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:32px;transition:all .2s;display:flex}.avatar-option:hover{transform:scale(1.1)}.avatar-option.selected{border-color:var(--accent);background-color:#00d4ff1a}.avatar-option.custom-upload{border:1px dashed var(--text-muted);font-size:20px}.avatar-option.custom-upload:hover{border-color:var(--accent);color:var(--accent)}.input-group input{background:var(--bg-primary);border:1px solid var(--border);width:100%;color:var(--text-primary);text-align:center;border-radius:8px;padding:12px;font-family:inherit;font-size:16px}.input-group input:focus{outline:1px solid var(--accent)}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover)}.btn-mobile-back{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;padding:5px 10px;font-size:16px;display:flex}.hub-bottom-nav{display:none}.mobile-games-grid{width:100%;margin-top:20px;display:block}.games-grid-container{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px;display:grid}.mobile-game-card{background:var(--bg-surface);border:1px solid var(--border);text-align:center;cursor:pointer;border-radius:12px;padding:15px 10px;transition:transform .2s,border-color .2s;position:relative}.mobile-game-card:hover{border-color:var(--accent)}.mobile-game-card:active{transform:scale(.95)}.mobile-game-card .icon{margin-bottom:8px;font-size:36px;display:block}.mobile-game-card .game-name{color:var(--text-primary);font-size:13px;font-weight:600}.mobile-game-card .fav-btn{cursor:pointer;background:0 0;border:none;padding:2px;font-size:16px;position:absolute;top:5px;right:5px}@media (width<=900px){.hub-container{flex-direction:column}.hub-sidebar,body.mobile-game-active .hub-sidebar{display:none!important}body.mobile-game-active .hub-top-bar{height:50px;padding:0 10px}body.mobile-game-active .room-actions-top,body.mobile-game-active .status-indicator,body.mobile-game-active .status-text{display:none}body.mobile-game-active #btn-mobile-back{display:flex!important}.hub-brand{border-bottom:none;border-right:1px solid var(--border);align-items:center;gap:12px;padding:10px;display:flex}.hub-brand h2{margin:0;font-size:16px}.sidebar-section{border:none;margin:0;padding:0;display:flex}.sidebar-header{display:none}.game-list{gap:8px;padding:5px;display:flex}.game-list li{white-space:nowrap;margin:0;padding:8px 12px}.empty-list-msg{display:none!important}.hub-top-bar{padding:0 10px;overflow-x:auto}.room-actions-active{gap:4px}.room-actions-active .btn{padding:6px 10px;font-size:12px}.pin-badge{padding:6px 8px;font-size:12px}.user-profile{display:none!important}.status-text{display:none}.chat-toggle-btn{display:none!important}.hub-main{padding-bottom:60px}.how-to-play{display:none}.hub-bottom-nav{background:var(--bg-surface);border-top:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:rgba(var(--bg-surface-rgb,15, 23, 42), .95);justify-content:space-around;align-items:center;height:60px;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;height:100%;transition:color .2s;display:flex}.bottom-nav-item .icon{font-size:20px}.bottom-nav-item span:not(.icon){font-size:10px;font-weight:600}.bottom-nav-item.active{color:var(--accent)}body.mobile-game-active .hub-bottom-nav{display:none!important}body.mobile-game-active .hub-main{padding-bottom:0}.bottom-sheet-mobile{border-radius:20px 20px 0 0;width:100%;max-width:100%;margin:0;padding:30px 20px 40px;position:absolute;top:auto;bottom:0;transform:translateY(100%);box-shadow:0 -4px 20px #00000080}.welcome-overlay.show .bottom-sheet-mobile{transform:translateY(0)}.sheet-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 20px}}.toast{color:#fff;z-index:10000;opacity:0;pointer-events:none;background:#334155;border-radius:8px;padding:12px 24px;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);position:fixed;bottom:30px;right:30px;transform:translateY(20px);box-shadow:0 4px 12px #0000004d}.game-header{margin-bottom:30px}.hero-section{margin-bottom:40px}.lobby-card{background:#0f172a;border-radius:16px;padding:24px}.finding-match-box{text-align:center;margin:auto}@keyframes spin{to{transform:rotate(360deg)}}.game-top-bar{box-sizing:border-box;background:#0f172a;border-radius:16px;justify-content:space-between;align-items:center;width:100%;max-width:450px;margin:0 auto 30px;padding:12px;display:flex}.player-badge{flex-direction:column;align-items:center;width:30%;display:flex}.badge-icon{margin-bottom:4px;font-family:Fredoka,sans-serif;font-size:24px}.p1 .badge-icon{color:#38bdf8}.p2 .badge-icon{color:#f43f5e}.score-board{text-align:center;width:40%;font-family:Fredoka,sans-serif;font-size:28px;font-weight:700}.turn-indicator{text-align:center;background:#ffffff0d;border-radius:12px;margin-bottom:30px;padding:12px;font-size:18px;font-weight:600;transition:all .3s}.turn-indicator.my-turn{color:#38bdf8;background:#38bdf833;box-shadow:0 0 10px #38bdf833}.turn-indicator.enemy-turn{color:#94a3b8;background:#f43f5e1a}.board-container{aspect-ratio:1;width:100%;max-width:450px;margin:0 auto 40px;position:relative}.board{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);gap:12px;width:100%;height:100%;display:grid}.cell{cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f172a;border-radius:16px;justify-content:center;align-items:center;font-family:Fredoka,sans-serif;font-size:64px;transition:background .2s;display:flex}.cell:hover{background:#1e293b}.cell.x{color:#38bdf8}.cell.o{color:#f43f5e}.win-line-svg{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0}#win-line{stroke:#10b981;stroke-dasharray:500;stroke-dashoffset:500px;transition:stroke-dashoffset .5s ease-out}.win-line-svg.show #win-line{stroke-dashoffset:0}.game-actions{margin-top:auto}.btn:active{transform:scale(.96)}.chat-container{box-sizing:border-box;background:#0f172a;border:1px solid #334155;border-radius:12px;flex-direction:column;gap:10px;width:100%;max-width:500px;margin-top:20px;padding:12px;display:flex}.badge-icon{font-size:1.5rem}.turn-indicator{text-align:center;border-radius:20px;margin-bottom:15px;padding:8px 20px;font-family:Fredoka,sans-serif;font-size:1.2rem;transition:all .3s}.board-container{aspect-ratio:1;-webkit-user-select:none;user-select:none;touch-action:none;width:100%;max-width:500px;margin-bottom:20px;position:relative}.chess-board{border:4px solid #1e293b;border-radius:8px;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:100%;height:100%;transition:transform .6s ease-in-out;display:grid;overflow:hidden;box-shadow:0 10px 25px #00000080}.chess-board.flipped{transform:rotate(180deg)}.square{cursor:pointer;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.square.light{background-color:#ebecd0}.square.dark{background-color:#739552}.square.selected:after{content:"";pointer-events:none;background-color:#f4d53f80;position:absolute;inset:0}.square.valid-move:after{content:"";pointer-events:none;background-color:#00000026;border-radius:50%;width:30%;height:30%;position:absolute}.square.valid-move.has-piece:after{background-color:#0000;border:4px solid #00000026;width:90%;height:90%}.square.last-move:before{content:"";pointer-events:none;background-color:#f4d53f66;position:absolute;inset:0}.piece{z-index:10;pointer-events:none;background-position:50%;background-repeat:no-repeat;background-size:contain;width:90%;height:90%;transition:transform .2s}.chess-board.flipped .piece{transform:rotate(180deg)}.coord-rank{color:#0009;pointer-events:none;font-size:10px;font-weight:700;position:absolute;top:2px;left:2px}.coord-file{color:#0009;pointer-events:none;font-size:10px;font-weight:700;position:absolute;bottom:2px;right:2px}.square.dark .coord-rank,.square.dark .coord-file{color:#ffffffb3}.chess-board.flipped .coord-rank{inset:auto 2px 2px auto;transform:rotate(180deg)}.chess-board.flipped .coord-file{inset:2px auto auto 2px;transform:rotate(180deg)}.promotion-overlay{z-index:100;opacity:0;pointer-events:none;background:#000c;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.promotion-overlay.show{opacity:1;pointer-events:auto}.promotion-box{text-align:center;background:#1e293b;border:1px solid #334155;border-radius:12px;padding:20px}.promotion-box h3{color:#fff;margin-top:0;margin-bottom:16px}.promotion-pieces{justify-content:center;gap:10px;display:flex}.promo-piece{cursor:pointer;background-color:#ffffff1a;background-size:contain;border-radius:8px;width:60px;height:60px;transition:background-color .2s}.promo-piece:hover{background-color:#ffffff4d}.game-actions{justify-content:center;width:100%;max-width:500px;margin-top:10px;display:flex}body.game-body{color:#f8fafc;background:#0f172a;justify-content:center;align-items:center;height:100vh;margin:0;padding:0;font-family:Inter,sans-serif;display:flex;overflow:hidden}.game-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.game-screen{box-sizing:border-box;flex-direction:column;align-items:center;width:100%;height:100%;padding:24px;display:none;overflow-y:auto}.game-screen.active{display:flex}.game-title{text-align:center;color:#38bdf8;letter-spacing:1px;margin:0;font-family:Fredoka,sans-serif;font-size:38px}.game-title span{color:#f43f5e}.online-badge{color:#10b981;background:#0f172a;border:1px solid #334155;border-radius:20px;align-items:center;gap:4px;margin-top:12px;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-flex}.game-subtitle{text-align:center;color:#94a3b8;margin-top:8px;font-size:14px}.btn{cursor:pointer;box-sizing:border-box;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 20px;font-family:Inter,sans-serif;font-size:16px;font-weight:600;transition:transform .1s,filter .2s,opacity .2s;display:flex}.btn:active:not(:disabled){transform:scale(.96)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#3b82f6}.btn-secondary{color:#fff;background:#334155}.btn-success{color:#fff;background:#10b981}.btn-danger{color:#fff;background:#f43f5e}.btn-large{padding:18px;font-size:18px}.game-header{width:100%;margin-bottom:20px}.back-link{color:#94a3b8;font-weight:500;text-decoration:none}.hero-section{text-align:center;width:100%;margin-bottom:30px}.lobby-card{box-sizing:border-box;background:#0f172a;border-radius:16px;width:100%;padding:24px}.input-group label{color:#cbd5e1;margin-bottom:8px;font-size:14px;display:block}.input-group input{color:#fff;box-sizing:border-box;background:#1e293b;border:1px solid #334155;border-radius:10px;outline:none;width:100%;margin-bottom:24px;padding:14px;font-size:16px}.input-group input:focus{border-color:#3b82f6}.divider{text-align:center;margin:24px 0;position:relative}.divider span{color:#64748b;z-index:2;background:#0f172a;padding:0 12px;font-size:12px;font-weight:700;position:relative}.divider:after{content:"";z-index:1;background:#334155;width:100%;height:1px;position:absolute;top:50%;left:0}.friend-actions{flex-direction:column;gap:12px;display:flex}.join-group{gap:8px;display:flex}.join-group input{color:#fff;text-align:center;letter-spacing:2px;background:#1e293b;border:1px solid #334155;border-radius:10px;outline:none;flex:1;padding:12px;font-family:monospace;font-size:16px}.join-group button{width:auto;padding:12px 24px}.setup-notice{color:#f59e0b;background:#f59e0b1a;border-radius:8px;margin-top:20px;padding:12px;font-size:12px;line-height:1.5}.finding-match-box{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;background:#1e293bb3;border:1px solid #ffffff1a;border-radius:16px;width:100%;margin:auto;padding:40px 20px}.radar-spinner{border:4px solid #334155;border-top-color:#3b82f6;border-radius:50%;width:80px;height:80px;margin:0 auto 24px;animation:1s linear infinite spin}.finding-match-box h2{margin-bottom:8px;font-size:24px}.finding-match-box p{color:#94a3b8;margin-bottom:40px}.pin-display{letter-spacing:4px;color:#38bdf8;background:#0f172a;border-radius:12px;margin:20px 0;padding:16px;font-family:monospace;font-size:40px;font-weight:700}.game-over-overlay{z-index:100;opacity:0;pointer-events:none;background:#0f172ae6;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}.game-over-overlay.show{opacity:1;pointer-events:all}.game-over-box{text-align:center;background:#1e293b;border:1px solid #334155;border-radius:24px;width:85%;padding:40px 24px;transition:transform .3s;transform:translateY(20px);box-shadow:0 20px 40px #00000080}.game-over-overlay.show .game-over-box{transform:translateY(0)}.game-over-box h2{margin:0 0 8px;font-family:Fredoka,sans-serif;font-size:36px}.game-over-box p{color:#94a3b8;margin-bottom:30px;font-size:16px}.rematch-actions{flex-direction:column;gap:12px;display:flex}.rematch-status{color:#f59e0b;min-height:20px;margin-top:16px;font-size:14px}.toast{color:#fff;opacity:0;z-index:1000;text-align:center;background:#333;border-radius:8px;width:80%;padding:12px 24px;font-size:14px;transition:all .3s;position:absolute;bottom:24px;left:50%;transform:translate(-50%,100px)}.toast.show{opacity:1;transform:translate(-50%)}.chat-container{box-sizing:border-box;background:#0f172a;border:1px solid #334155;border-radius:12px;flex-direction:column;flex-shrink:0;gap:10px;width:100%;max-width:500px;margin-top:20px;margin-bottom:20px;padding:12px;display:flex}.chat-messages{background:#1e293b;border-radius:8px;flex-direction:column;gap:6px;height:100px;padding:8px;font-size:13px;display:flex;overflow-y:auto}.chat-message{word-wrap:break-word;border-radius:12px;max-width:80%;padding:6px 10px}.chat-message.system{color:#94a3b8;background:0 0;align-self:center;font-size:11px}.chat-message.self{color:#fff;background:#3b82f6;border-bottom-right-radius:2px;align-self:flex-end}.chat-message.other{color:#fff;background:#334155;border-bottom-left-radius:2px;align-self:flex-start}.chat-message .sender{opacity:.7;margin-bottom:2px;font-size:10px;display:block}.chat-input-form{gap:8px;display:flex}.chat-input-form input{color:#fff;background:#1e293b;border:1px solid #334155;border-radius:8px;outline:none;flex:1;padding:10px;font-size:14px}.game-top-bar{box-sizing:border-box;background:#1e293bb3;border:1px solid #ffffff1a;border-radius:12px;justify-content:space-between;align-items:center;width:100%;max-width:500px;margin:0 auto 10px;padding:10px 15px;display:flex}.player-badge{flex-direction:column;align-items:center;gap:4px;width:30%;font-family:Fredoka,sans-serif;display:flex}.piece-indicator{border:2px solid #fff;border-radius:50%;width:24px;height:24px;box-shadow:0 2px 4px #00000080}.p1-piece{background:#3b82f6}.p2-piece{background:#ef4444}.badge-name{color:#cbd5e1;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:12px;overflow:hidden}.score-board{color:#f8fafc;text-align:center;background:#0000004d;border-radius:8px;width:40%;padding:4px 12px;font-family:Fredoka,sans-serif;font-size:1.5rem;font-weight:700}.turn-indicator{text-align:center;box-sizing:border-box;border-radius:20px;width:100%;margin-bottom:15px;padding:8px 20px;font-family:Fredoka,sans-serif;font-size:1.2rem;transition:all .3s}.turn-indicator.my-turn{color:#34d399;background:#10b98133;border:1px solid #10b98166}.turn-indicator.enemy-turn{color:#fb7185;background:#f43f5e33;border:1px solid #f43f5e66}.board-container{aspect-ratio:1;-webkit-user-select:none;user-select:none;box-sizing:border-box;background:#1e293b;border:4px solid #334155;border-radius:8px;width:100%;max-width:500px;margin-bottom:15px;position:relative}.snakes-board{background-image:url(/assets/images/Ular-tangga.png);background-position:50%;background-repeat:no-repeat;background-size:cover;grid-template-rows:repeat(10,1fr);grid-template-columns:repeat(10,1fr);width:100%;height:100%;display:grid;position:relative}.sq{color:#0000;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;padding:2px;font-size:10px;font-weight:600;display:flex;position:relative}.sq:nth-child(2n),.sq:nth-child(odd){background-color:#0000}.lines-layer{pointer-events:none;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0}.ladder-line{stroke:#fcd34d;stroke-width:8px;stroke-linecap:round;stroke-dasharray:4 8;opacity:.8}.snake-line{stroke:#ef4444;stroke-width:8px;stroke-linecap:round;opacity:.8}.token{z-index:20;border:2px solid #fff;border-radius:50%;width:20px;height:20px;margin-top:-10px;margin-left:-10px;transition:transform .4s ease-in-out;position:absolute;box-shadow:0 4px 6px #00000080}.token.p1{background:#3b82f6}.token.p2{background:#ef4444}.token.p3{background:#10b981}.token.p4{background:#f59e0b}.token.p5{background:#8b5cf6}.token.p6{background:#06b6d4}.token.p7{background:#f97316}.token.p8{background:#ec4899}.token-dot{border:1px solid #fff;border-radius:50%;width:12px;height:12px;margin-right:5px;display:inline-block}.token-dot.p1{background:#3b82f6}.token-dot.p2{background:#ef4444}.token-dot.p3{background:#10b981}.token-dot.p4{background:#f59e0b}.token-dot.p5{background:#8b5cf6}.token-dot.p6{background:#06b6d4}.token-dot.p7{background:#f97316}.token-dot.p8{background:#ec4899}.player-item.active{border:1px solid #fff6;background:#fff3!important}.dice-section{justify-content:center;align-items:center;gap:20px;width:100%;margin-bottom:15px;display:flex}.dice-container{perspective:1000px;width:60px;height:60px}.dice{color:#0f172a;background:#fff;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;font-family:Fredoka,sans-serif;font-size:32px;font-weight:700;transition:transform .3s;display:flex;box-shadow:0 4px 10px #0000004d}.dice.rolling{animation:.5s linear infinite roll}@keyframes roll{0%{transform:rotate(0)scale(1)}50%{transform:rotate(180deg)scale(1.1)}to{transform:rotate(360deg)scale(1)}}.game-actions{width:100%}.onet-container{background-color:#1a1a2e;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:10px;display:flex;position:relative;overflow:hidden}.onet-header{color:#fff;z-index:10;justify-content:space-between;width:100%;max-width:800px;margin-bottom:20px;display:flex}.onet-board-wrapper{display:inline-block;position:relative}.onet-board{background-color:#ffffff1a;border-radius:8px;gap:2px;padding:2px;display:grid}.onet-cell{width:var(--cell-size,40px);height:var(--cell-size,40px);box-sizing:border-box;cursor:pointer;border-radius:6px;transition:all .2s;position:relative}.onet-cell.empty{cursor:default;background-color:#0000}.onet-cell.filled{background-color:#fff;box-shadow:0 4px 6px #0000004d}.onet-cell.filled:hover{transform:translateY(-2px);box-shadow:0 6px 8px #0006}.onet-cell.selected{z-index:2;outline:3px solid #ff4757;transform:scale(1.05)}.onet-tile-image{background-image:url(/assets/images/onet-sprite.webp);background-size:1000% 1000%;border-radius:4px;width:100%;height:100%}.onet-lines-overlay{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0}.onet-line{stroke:#ff4757;stroke-width:4px;stroke-linecap:round;stroke-linejoin:round;fill:none;filter:drop-shadow(0 0 4px #ff4757cc);animation:.1s ease-out forwards drawLine}@keyframes drawLine{0%{stroke-dasharray:0 1000}to{stroke-dasharray:1000 1000}}.onet-lobby{color:#fff;text-align:center;background:#000c;border-radius:12px;max-width:500px;padding:40px}.onet-lobby select{border-radius:6px;margin:10px;padding:10px;font-size:16px}.onet-lobby button{margin-top:20px;padding:12px 24px;font-size:18px;font-weight:700}.bomberman-container{color:#fff;background-color:#2c3e50;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.bomberman-lobby{text-align:center;background:#000000b3;border-radius:12px;padding:30px}.char-select{justify-content:center;gap:20px;margin:20px 0;display:flex}.char-btn{cursor:pointer;background:#34495e;border:2px solid #0000;border-radius:8px;padding:10px;transition:all .2s}.char-btn.selected{background:#2c3e50;border-color:#f1c40f;box-shadow:0 0 15px #f1c40f80}.char-btn img{object-fit:contain;width:80px;height:80px}.bomber-canvas{background-color:#27ae60;border:4px solid #34495e;border-radius:8px;max-width:100%;max-height:80vh;box-shadow:0 10px 30px #00000080}.mobile-controls{pointer-events:none;justify-content:space-between;width:100%;padding:20px;display:none;position:absolute;bottom:0}.mobile-dpad{pointer-events:auto;grid-template-rows:repeat(3,60px);grid-template-columns:repeat(3,60px);gap:5px;display:grid}.dpad-btn{color:#fff;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;display:flex}.dpad-btn:active{background:#fff6}.dpad-up{grid-area:1/2}.dpad-left{grid-area:2/1}.dpad-right{grid-area:2/3}.dpad-down{grid-area:3/2}.action-btn{color:#fff;pointer-events:auto;background:#e74c3cb3;border:2px solid #c0392b;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;display:flex}.action-btn:active{background:#c0392b}@media (width<=768px){.mobile-controls{display:flex}}
