.home-page{padding-top:1rem}.hero{text-align:center;padding:4rem 0 3rem}.hero-badge{margin-bottom:1.2rem}.hero-title{letter-spacing:-.04em;margin-bottom:1.2rem;font-size:clamp(2.4rem,6vw,4rem);font-weight:800;line-height:1.12}.hero-sub{color:var(--text-secondary);max-width:540px;margin:0 auto;font-size:clamp(1rem,2.5vw,1.15rem);line-height:1.7}.games-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem;margin-bottom:4rem;display:grid}.game-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;transition:var(--transition);flex-direction:column;gap:.6rem;padding:1.75rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.game-card-glow{opacity:0;background:radial-gradient(ellipse at top left, var(--card-color), transparent 70%);pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.game-card:hover{border-color:var(--card-color);box-shadow:0 8px 40px color-mix(in srgb, var(--card-color) 25%, transparent), var(--shadow-card);transform:translateY(-5px)}.game-card:hover .game-card-glow{opacity:.12}.game-card-icon{filter:drop-shadow(0 0 10px color-mix(in srgb, var(--card-color) 60%, transparent));margin-bottom:.25rem;font-size:2.4rem;line-height:1}.game-card-name{letter-spacing:-.02em;font-size:1.2rem;font-weight:700}.game-card-desc{color:var(--text-secondary);flex:1;font-size:.875rem;line-height:1.55}.game-card-modes{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.game-card-arrow{color:var(--text-muted);transition:var(--transition);font-size:1.2rem;position:absolute;top:1.5rem;right:1.5rem}.game-card:hover .game-card-arrow{color:var(--card-color);transform:translate(4px)}.home-footer{text-align:center;color:var(--text-muted);padding-bottom:2rem;font-size:.85rem}.lobby-page{justify-content:center;align-items:flex-start;padding-top:3rem;display:flex}.lobby-card{width:100%;max-width:800px;padding:2.5rem}.lobby-header{text-align:center;margin-bottom:2.5rem}.lobby-icon{margin-bottom:.5rem;font-size:3rem;display:block}.lobby-title{letter-spacing:-.03em;font-size:2rem;font-weight:800}.lobby-sub{color:var(--text-secondary);margin-top:.4rem}.mode-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=600px){.mode-grid{grid-template-columns:1fr}}.mode-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff08;flex-direction:column;gap:.6rem;padding:1.75rem 1.5rem;display:flex}.mode-icon{font-size:2rem}.mode-panel h2{font-size:1.15rem;font-weight:700}.mode-panel p{color:var(--text-secondary);font-size:.875rem;line-height:1.55}.difficulty-row{flex-wrap:wrap;gap:.5rem;display:flex}.or-divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:.25rem 0;font-size:.8rem;display:flex}.or-divider:before,.or-divider:after{content:"";border-top:1px solid var(--border);flex:1}.join-row{gap:.5rem;display:flex}.lobby-error{color:var(--danger);margin-top:.5rem;font-size:.85rem}.lobby-warn{color:var(--warning);border-radius:var(--radius-sm);background:#f59e0b14;border:1px solid #f59e0b40;padding:.5rem .75rem;font-size:.8rem}.room-created{text-align:center}.room-created-icon{margin-bottom:.75rem;font-size:3rem}.room-created h2{margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.room-created p{color:var(--text-secondary);font-size:.9rem}.room-code-label{color:var(--text-secondary);margin-top:.5rem;font-size:.85rem}.room-code-label strong{color:var(--accent-1);font-family:monospace}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-panel{border-radius:var(--radius-xl);box-shadow:var(--shadow-lift), 0 0 60px #8b5cf626;text-align:center;background:#0d0d2bf2;border:1px solid #ffffff1f;width:100%;max-width:420px;padding:2.5rem}.modal-title{margin-bottom:1rem;font-size:1.6rem;font-weight:700}.modal-body{color:var(--text-secondary);font-size:.95rem}.game-wrapper{flex-direction:column;align-items:center;gap:1.25rem;display:flex}.game-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;width:100%;max-width:480px;display:flex}.ttt-grid{grid-template-columns:repeat(3,1fr);gap:10px;width:min(360px,90vw);display:grid}.ttt-cell{aspect-ratio:1;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);color:var(--text-primary);background:#ffffff0d;border:2px solid #ffffff1a;font-size:clamp(1.8rem,8vw,2.8rem);font-weight:800}.ttt-cell:hover:not(:disabled){border-color:var(--accent-1);background:#8b5cf626;transform:scale(.96)}.ttt-cell.ttt-x{color:#8b5cf6}.ttt-cell.ttt-o{color:#ec4899}.ttt-cell.ttt-win{border-color:var(--accent-1);background:#8b5cf640;animation:1.5s ease-in-out infinite pulse-glow}.ttt-cell:disabled{cursor:default}.chess-wrap{align-items:flex-start;gap:4px;display:flex}.chess-rank-labels{flex-direction:column;width:18px;display:flex}.chess-file-labels{display:flex}.chess-label{width:clamp(38px,7vw,60px);height:clamp(38px,7vw,60px);color:var(--text-muted);justify-content:center;align-items:center;font-size:.7rem;font-weight:600;display:flex}.chess-board{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);border:3px solid #ffffff26;grid-template-columns:repeat(8,1fr);display:grid;overflow:hidden}.chess-cell{cursor:pointer;justify-content:center;align-items:center;width:clamp(38px,7vw,60px);height:clamp(38px,7vw,60px);transition:background .12s;display:flex;position:relative}.chess-light{background:#f0d9b5}.chess-dark{background:#b58863}.chess-cell:hover{filter:brightness(1.1)}.chess-sel{opacity:.85;background:#f6f669!important}.chess-legal{background:#00000026!important}.chess-light.chess-legal{background:#0000001f!important}.chess-dark.chess-legal{background:#00000040!important}.chess-piece{-webkit-user-select:none;user-select:none;z-index:1;font-size:clamp(1.4rem,4.5vw,2rem);line-height:1;transition:transform .1s}.chess-piece:hover{transform:scale(1.1)}.chess-w{filter:drop-shadow(0 1px 2px #0009)}.chess-b{filter:drop-shadow(0 1px 2px #000c)invert()hue-rotate(180deg)brightness(.1)}.chess-dot{pointer-events:none;background:#00000040;border-radius:50%;width:28%;height:28%}.chess-capture-ring{pointer-events:none;border:4px solid #00000040;border-radius:50%;position:absolute;inset:0}.promo-dialog{text-align:center;padding:1.25rem 1.75rem}.promo-piece{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:#ffffff14;padding:.5rem;font-size:2rem}.promo-piece:hover{border-color:var(--accent-1);background:#8b5cf633;transform:scale(1.1)}.checkers-board{border-radius:var(--radius-md);width:min(480px,90vw);box-shadow:var(--shadow-card);border:3px solid #ffffff26;grid-template-columns:repeat(8,1fr);display:grid;overflow:hidden}.ck-cell{aspect-ratio:1;cursor:default;justify-content:center;align-items:center;transition:background .15s;display:flex;position:relative}.ck-light{background:#e8d9b5}.ck-dark{cursor:pointer;background:#8b6340}.ck-dark:hover{background:#9a7248}.ck-selected{background:#b8860b!important}.ck-target{background:#8b5cf659!important}.ck-piece{z-index:1;border-radius:50%;justify-content:center;align-items:center;width:72%;height:72%;font-size:1.4rem;transition:transform .15s;display:flex;box-shadow:inset 0 2px 4px #ffffff4d,0 3px 8px #0006}.ck-piece:hover{transform:scale(1.08)}.ck-red{background:radial-gradient(circle at 35% 35%,#f87171,#b91c1c)}.ck-black{color:#e2e8f0;background:radial-gradient(circle at 35% 35%,#64748b,#0f172a)}.ck-king{box-shadow:inset 0 2px 4px #ffffff4d,0 3px 8px #0006,0 0 12px gold}.ck-dot{width:30%;height:30%;box-shadow:0 0 8px var(--accent-1);pointer-events:none;background:#8b5cf6cc;border-radius:50%}.bs-boards{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.bs-grid-wrap{flex-direction:column;align-items:center;gap:.5rem;display:flex}.bs-grid-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:.85rem;font-weight:600}.bs-grid,.bs-place-grid{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-sm);background:#00001e80;border:1px solid #ffffff1a;grid-template-columns:repeat(10,1fr);gap:3px;padding:6px;display:grid}.bs-cell{background:#0ea5e91a;border:1px solid #0ea5e926;border-radius:3px;width:clamp(22px,4vw,36px);height:clamp(22px,4vw,36px);transition:background .15s,transform .1s}.bs-interactive{cursor:crosshair}.bs-interactive:hover{background:#0ea5e94d;transform:scale(1.1)}.bs-ship{background:#64748b99;border-color:#64748bcc}.bs-placed{background:#6366f180;border-color:#6366f1cc}.bs-preview{background:#6366f14d;border-color:#6366f199}.bs-hit{background:radial-gradient(circle,#fbbf24,#f59e0b);border-color:#f59e0b;box-shadow:0 0 8px #f59e0b99}.bs-miss{background:#64748b4d;border-color:#64748b80}.bs-miss:after{content:"•";color:#fff6;justify-content:center;align-items:center;height:100%;font-size:.7rem;display:flex}.bs-placement{flex-direction:column;align-items:center;gap:.75rem;display:flex}.bs-placing-label{color:var(--text-secondary);font-weight:600}.bs-sunk{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.bs-sunk-label{color:var(--text-secondary);font-size:.85rem}.c4-board{flex-direction:column;gap:6px;display:flex}.c4-col-btns{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.c4-col-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:4px 0;font-size:.75rem}.c4-col-btn:not(:disabled):hover,.c4-col-btn.hovered{color:var(--accent-1);transform:translateY(-2px)}.c4-col-btn:disabled{cursor:default}.c4-grid{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#1e1e5099;border:1px solid #ffffff1a;grid-template-columns:repeat(7,1fr);gap:6px;padding:12px;display:grid}.c4-cell{aspect-ratio:1;cursor:pointer;background:#0006;border:2px solid #ffffff0f;border-radius:50%;width:clamp(38px,7vw,60px);transition:background .2s,box-shadow .2s}.c4-cell.c4-p1{background:radial-gradient(circle at 35% 35%,#f87171,#dc2626);box-shadow:0 0 12px #dc262680}.c4-cell.c4-p2{background:radial-gradient(circle at 35% 35%,#fde68a,#f59e0b);box-shadow:0 0 12px #f59e0b80}.c4-cell.c4-hover{background:#8b5cf633}.c4-cell.c4-win{animation:1s ease-in-out infinite pulse-glow;box-shadow:0 0 20px}.dab-board{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;padding:1rem;display:inline-block}.dab-row,.dab-vrow{align-items:center;display:flex}.dab-dot{background:#ffffffb3;border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 6px #fff6}.dab-hline{cursor:pointer;border:none;border-radius:6px;flex-shrink:0;width:50px;height:12px;transition:background .15s,transform .1s}.dab-vline{cursor:pointer;border:none;border-radius:6px;flex-shrink:0;width:12px;height:50px;transition:background .15s}.dab-empty{background:#ffffff1a}.dab-empty:not(:disabled):hover{background:#8b5cf680;transform:scaleY(1.2)}.dab-filled{cursor:default}.dab-p1{background:linear-gradient(90deg,#8b5cf6,#6366f1);box-shadow:0 0 6px #8b5cf680}.dab-p2{background:linear-gradient(90deg,#f43f5e,#ec4899);box-shadow:0 0 6px #f43f5e80}.dab-vline.dab-p1{background:linear-gradient(#8b5cf6,#6366f1)}.dab-vline.dab-p2{background:linear-gradient(#f43f5e,#ec4899)}.dab-box{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.2rem;transition:background .3s;display:flex}.dab-box-p1{color:#8b5cf6;background:#8b5cf626}.dab-box-p2{color:#f43f5e;background:#f43f5e26}@media (width<=480px){.dab-hline{width:36px}.dab-vline{height:36px}.dab-box{width:36px;height:36px;font-size:.875rem}.dab-dot{width:10px;height:10px}}.sdk-board{border-radius:var(--radius-sm);box-shadow:var(--shadow-card), 0 0 40px #8b5cf61a;border:3px solid #ffffff4d;flex-direction:column;gap:2px;display:flex;overflow:hidden}.sdk-row{gap:2px;display:flex}.sdk-box-border-b{border-bottom:3px solid #ffffff4d;margin-bottom:2px;padding-bottom:2px}.sdk-cell{cursor:pointer;width:clamp(36px,6vw,56px);height:clamp(36px,6vw,56px);color:var(--text-primary);-webkit-user-select:none;user-select:none;background:#ffffff08;border-radius:3px;justify-content:center;align-items:center;font-size:clamp(.85rem,2vw,1.2rem);font-weight:600;transition:background .12s,color .12s;display:flex}.sdk-cell.sdk-box-border-r{border-right:3px solid #ffffff4d;margin-right:2px;padding-right:2px}.sdk-cell:hover{background:#8b5cf626}.sdk-cell.sdk-fixed{color:#ffffffd9;cursor:default;font-weight:700}.sdk-cell.sdk-fixed:hover{background:#ffffff08}.sdk-cell.sdk-selected{color:#fff;box-shadow:inset 0 0 0 2px var(--accent-1);background:#8b5cf659!important}.sdk-cell.sdk-highlight{background:#8b5cf614}.sdk-cell.sdk-same-num{background:#8b5cf62e}.sdk-cell.sdk-invalid{color:#f87171!important}.sdk-cell:not(.sdk-fixed){color:#a78bfa}.sdk-numpad{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.sdk-num-btn{width:clamp(38px,8vw,50px);height:clamp(38px,8vw,50px);padding:0;font-size:1rem;font-weight:700}.gamepage{z-index:1;flex-direction:column;flex:1;padding:1.5rem 1rem 3rem;display:flex;position:relative}.gamepage-inner{width:100%;max-width:900px;margin:0 auto}.gamepage-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60vh;display:flex}.game-wrapper{flex-direction:column;gap:1.25rem;display:flex}.game-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.game-title{letter-spacing:-.03em;font-size:1.6rem;font-weight:800}.site-header{z-index:100;-webkit-backdrop-filter:blur(20px);background:#070714cc;border-bottom:1px solid #ffffff0f;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:.9rem 1.5rem;display:flex}.logo{color:var(--text-primary);letter-spacing:-.03em;align-items:center;gap:.5rem;font-size:1.35rem;font-weight:800;text-decoration:none;display:flex}.logo-icon{filter:drop-shadow(0 0 8px #8b5cf699);font-size:1.5rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#070714;--bg-surface:#0d0d2b;--bg-card:#ffffff0a;--bg-card-hover:#ffffff14;--border:#ffffff1a;--border-glow:#8b5cf680;--accent-1:#8b5cf6;--accent-2:#6366f1;--accent-3:#ec4899;--accent-grad:linear-gradient(135deg, #8b5cf6, #6366f1);--accent-grad2:linear-gradient(135deg, #ec4899, #8b5cf6);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-glow:0 0 40px #8b5cf626;--shadow-card:0 8px 32px #0006;--shadow-lift:0 20px 60px #00000080;--transition:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1)}html,body{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Outfit,system-ui,sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20%,#8b5cf614 0%,#0000 50%),radial-gradient(at 80% 20%,#6366f10f 0%,#0000 50%),radial-gradient(at 60% 80%,#ec48990d 0%,#0000 50%);position:fixed;inset:0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#8b5cf666;border-radius:99px}.page{z-index:1;flex:1;padding:2rem 1rem;position:relative}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:var(--transition)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-glow);box-shadow:var(--shadow-glow), var(--shadow-card);transform:translateY(-3px)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);white-space:nowrap;letter-spacing:.02em;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.5rem;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent-grad);color:#fff;box-shadow:0 4px 20px #8b5cf666}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #8b5cf68c}.btn-secondary{color:var(--text-primary);border:1px solid var(--border);background:#ffffff12}.btn-secondary:hover{border-color:var(--accent-1);background:#ffffff1f;transform:translateY(-2px)}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 20px #ef444459}.btn-danger:hover{opacity:.9;transform:translateY(-2px)}.btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border);background:#ffffff0a}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-lg{border-radius:var(--radius-md);padding:.85rem 2rem;font-size:1rem}.btn-sm{padding:.4rem 1rem;font-size:.8rem}.input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);transition:var(--transition);background:#ffffff0d;outline:none;width:100%;padding:.65rem .9rem;font-family:Outfit,sans-serif;font-size:.95rem}.input:focus{border-color:var(--accent-1);box-shadow:0 0 0 3px #8b5cf633}.input::placeholder{color:var(--text-muted)}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:99px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-ai{color:var(--accent-1);background:#8b5cf633;border:1px solid #8b5cf659}.badge-multi{color:var(--success);background:#10b98126;border:1px solid #10b98159}.badge-coop{color:var(--accent-3);background:#ec489926;border:1px solid #ec489959}.grad-text{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.grad-text2{background:var(--accent-grad2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.divider{border:none;border-top:1px solid var(--border);margin:1rem 0}.status-bar{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);text-align:center;background:#ffffff0a;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500}.status-bar.my-turn{color:var(--accent-1);background:#8b5cf614;border-color:#8b5cf680;animation:2s ease-in-out infinite pulse-glow}.status-bar.win{color:var(--success);background:#10b98114;border-color:#10b98180}.status-bar.lose{color:var(--danger);background:#ef444414;border-color:#ef444480}.status-bar.draw{color:var(--warning);background:#f59e0b14;border-color:#f59e0b80}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #8b5cf64d}50%{box-shadow:0 0 20px 6px #8b5cf633}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{to{transform:rotate(360deg)}}.anim-fadeInUp{animation:.5s both fadeInUp}.anim-fadeIn{animation:.4s both fadeIn}.anim-scaleIn{animation:.3s cubic-bezier(.34,1.56,.64,1) both scaleIn}.spinner{border:3px solid #8b5cf633;border-top-color:var(--accent-1);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.copy-group{align-items:center;gap:.5rem;display:flex}.copy-group .input{font-family:Courier New,monospace;font-size:.85rem}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.grid{display:grid}.w-full{width:100%}@media (width<=640px){.btn-lg{padding:.75rem 1.5rem;font-size:.9rem}}
