.chess-game-page{background:var(--bg-primary);width:100%;height:100%;display:flex;position:relative}.chess-avatars-column{width:220px;height:100%;padding:var(--space-lg) var(--space-md);border-right:1px solid var(--border-subtle);background:var(--bg-secondary);flex-direction:column;justify-content:space-between;display:flex}.chess-style-avatar-container{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.chess-style-avatar{border-radius:var(--radius-md);width:160px;height:160px;box-shadow:var(--shadow-card);border:2px solid #0000;padding:4px}.chess-style-avatar-inner{border-radius:calc(var(--radius-md) - 4px);justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.chess-style-avatar-img{object-fit:contain;width:100%;height:100%;transform:translateY(10%)}.chess-style-avatar-label{flex-direction:column;align-items:center;display:flex}.chess-style-avatar-name{font-family:var(--font-display);color:var(--text-primary);font-size:.85rem;font-weight:700}.chess-style-avatar-role{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.65rem}.chess-board-wrapper{padding:var(--space-lg);flex:1;justify-content:center;align-items:center;display:flex}.chess-move-log .move-log-table{font-size:.85rem}.chess-move-log .move-log-cell{font-family:var(--font-body);font-size:.9rem;font-weight:500}.chess-move-log .move-log-num{width:36px}.chess-theme-selector{gap:var(--space-md);flex-direction:column;width:100%;display:flex}.chess-theme-swatch-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);flex-direction:column;display:flex}.chess-theme-swatch-btn:hover{border-color:var(--border-active)}.chess-theme-swatch-btn.selected{border-color:var(--accent-2);background:#4ecdc414}.chess-theme-swatch{border:1px solid #ffffff1a;border-radius:4px;grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;width:48px;height:48px;display:grid;overflow:hidden}@media (width<=1200px){.chess-avatars-column{display:none}}.content-page{background:radial-gradient(ellipse at 15% 0%, #6c5ce71a 0%, transparent 45%), radial-gradient(ellipse at 85% 10%, #4ecdc412 0%, transparent 50%), var(--bg-primary);width:100%;height:100%;color:var(--text-primary);font-family:var(--font-body);overflow:hidden auto}.content-nav{z-index:10;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border-subtle);background:#07070fb8;position:sticky;top:0}.content-nav-inner{max-width:900px;padding:14px var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap;margin:0 auto;display:flex}.content-nav-brand{font-family:var(--font-display);letter-spacing:.02em;color:var(--text-primary);align-items:center;gap:10px;font-size:1.05rem;font-weight:800;text-decoration:none;display:flex}.content-nav-logo-grid{grid-template-columns:repeat(2,1fr);gap:3px;width:22px;height:22px;display:grid}.content-nav-logo-grid span{border-radius:50%;width:100%;height:100%}.content-nav-links{gap:var(--space-lg);flex-wrap:wrap;display:flex}.content-nav-links a{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.92rem;font-weight:500;text-decoration:none}.content-nav-links a:hover,.content-nav-links a.is-active{color:var(--text-primary)}.content-main{max-width:820px;padding:var(--space-2xl) var(--space-lg) var(--space-xl);margin:0 auto}.content-article{color:var(--text-primary);font-size:1.02rem;line-height:1.75}.content-title{font-family:var(--font-display);margin-bottom:var(--space-md);background:linear-gradient(135deg,#fff 0%,#b9b9d6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2rem,5vw,2.9rem);font-weight:800;line-height:1.1}.content-lead{color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:1.18rem;line-height:1.6}.content-article h2{font-family:var(--font-display);margin:var(--space-2xl) 0 var(--space-sm);color:var(--text-primary);font-size:1.5rem;font-weight:700}.content-article h3{margin:var(--space-xl) 0 var(--space-xs);color:var(--text-primary);font-size:1.18rem;font-weight:600}.content-article p{margin-bottom:var(--space-md);color:#c9c9de}.content-article ul,.content-article ol{margin:0 0 var(--space-md) 1.3em;color:#c9c9de}.content-article li{margin-bottom:var(--space-xs)}.content-article a{color:var(--accent-2);text-underline-offset:2px;text-decoration:underline}.content-article a:hover{color:#7ee0d8}.content-article strong{color:var(--text-primary);font-weight:600}.content-article hr{border:none;border-top:1px solid var(--border-subtle);margin:var(--space-2xl) 0}.content-updated{color:var(--text-muted);margin-bottom:var(--space-xl);font-size:.9rem}.content-note{background:var(--bg-glass);border:1px solid var(--border-subtle);border-left:3px solid var(--accent-glow);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);margin:var(--space-lg) 0}.content-note p:last-child{margin-bottom:0}.content-cta{margin-top:var(--space-lg);border-radius:var(--radius-full);color:#07070f;background:linear-gradient(135deg, var(--accent-1), var(--accent-2));padding:12px 26px;font-weight:600;text-decoration:none;display:inline-block}.guides-section{width:100%;max-width:1000px;padding:var(--space-xl) var(--space-lg) 0;margin:0 auto}.site-footer{border-top:1px solid var(--border-subtle);margin-top:var(--space-2xl);background:#05050c99}.site-footer-inner{max-width:900px;padding:var(--space-2xl) var(--space-lg) var(--space-xl);margin:0 auto}.site-footer-cols{gap:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.site-footer-heading{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.78rem;font-weight:700}.site-footer-col{flex-direction:column;gap:8px;display:flex}.site-footer-col a{color:var(--text-secondary);transition:color var(--transition-fast);font-size:.95rem;text-decoration:none}.site-footer-col a:hover{color:var(--text-primary)}.site-footer-bottom{margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid var(--border-subtle);flex-direction:column;gap:6px;display:flex}.site-footer-brand{font-family:var(--font-display);color:var(--text-primary);font-weight:800}.site-footer-copy{color:var(--text-muted);font-size:.85rem}.home-page .site-footer{margin-top:var(--space-2xl)}@media (width<=600px){.content-nav-inner{justify-content:center}.content-main{padding-top:var(--space-xl)}}.home-intro{text-align:center;width:100%;max-width:760px;color:var(--text-secondary);font-size:1.02rem;line-height:1.7}.home-intro p{margin-bottom:var(--space-md)}.home-intro strong{color:var(--text-primary)}.home-intro a{color:var(--accent-2);text-underline-offset:2px;text-decoration:underline}.game-card-guide-link{margin-top:var(--space-sm);color:var(--accent-2);font-size:.85rem;font-weight:600;text-decoration:none;display:inline-block}.game-card-guide-link:hover{text-decoration:underline}.home-why{width:100%;max-width:900px}.home-section-title{font-family:var(--font-display);text-align:center;margin-bottom:var(--space-lg);color:var(--text-primary);font-size:1.5rem;font-weight:700}.home-why-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.home-why-item{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg)}.home-why-item h3{margin-bottom:var(--space-xs);color:var(--text-primary);font-size:1.05rem;font-weight:600}.home-why-item p{color:var(--text-secondary);font-size:.92rem;line-height:1.6}:root{--bg-primary:#07070f;--bg-secondary:#0d0d1a;--bg-card:#0f0f1ed9;--bg-card-hover:#141428f2;--bg-glass:#ffffff08;--bg-glass-border:#ffffff0f;--text-primary:#e8e8f0;--text-secondary:#8888a8;--text-muted:#555570;--accent-1:#ff6b6b;--accent-2:#4ecdc4;--accent-glow:#6c5ce7;--border-subtle:#ffffff0f;--border-active:#ffffff26;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Outfit", "Inter", sans-serif;--shadow-card:0 4px 24px #0006, 0 1px 4px #0000004d;--shadow-glow:0 0 40px #6c5ce726;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{width:100%;height:100%;position:relative}.lobby-screen{background:radial-gradient(ellipse at 20% 50%, #ff6b6b0f 0%, transparent 50%), radial-gradient(ellipse at 80% 50%, #4ecdc40f 0%, transparent 50%), var(--bg-primary);flex-direction:column;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:auto}.lobby-content{z-index:1;width:100%;max-width:520px;padding:80px var(--space-xl) var(--space-2xl);align-items:center;gap:var(--space-xl);flex-direction:column;margin:auto 0;display:flex;position:relative}.lobby-header{text-align:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.logo-dots{margin-bottom:var(--space-sm);grid-template-columns:1fr 1fr;gap:8px;display:grid}.logo-dot{border-radius:50%;width:16px;height:16px;box-shadow:0 0 12px}.lobby-title{font-family:var(--font-display);letter-spacing:.2em;background:linear-gradient(135deg, var(--accent-1), var(--accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:4rem;font-weight:800;line-height:1}.lobby-subtitle{color:var(--text-secondary);letter-spacing:.15em;text-transform:uppercase;font-size:.9rem;font-weight:500}.lobby-players{align-items:center;gap:var(--space-md);flex-direction:column;width:100%;display:flex}.player-input-group{align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color var(--transition-normal);display:flex}.player-input-group:hover{border-color:var(--border-active)}.input-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 8px}.player-name-input{font-family:var(--font-body);color:var(--text-primary);padding:var(--space-sm) 0;background:0 0;border:none;outline:none;flex:1;font-size:1rem;font-weight:500}.player-name-input::placeholder{color:var(--text-muted)}.vs-divider{align-items:center;gap:var(--space-md);color:var(--text-muted);font-family:var(--font-display);letter-spacing:.2em;font-size:.8rem;font-weight:700;display:flex}.vs-divider:before,.vs-divider:after{content:"";background:var(--border-subtle);width:60px;height:1px}.grid-selection{width:100%}.section-label{text-transform:uppercase;letter-spacing:.15em;color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.75rem;font-weight:600}.grid-presets{gap:var(--space-sm);grid-template-columns:repeat(4,1fr);display:grid}.grid-preset-btn{padding:var(--space-md) var(--space-sm);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-normal);font-family:var(--font-body);flex-direction:column;align-items:center;gap:2px;display:flex}.grid-preset-btn:hover{border-color:var(--border-active);background:var(--bg-card-hover)}.grid-preset-btn.selected{border-color:var(--accent-2);color:var(--text-primary);background:#4ecdc414}.preset-size{font-size:.95rem;font-weight:700;font-family:var(--font-display)}.preset-desc{text-transform:uppercase;letter-spacing:.1em;opacity:.6;font-size:.65rem}.how-to-play{width:100%}.rules-summary-card{align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-xl);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex}.rules-summary-icons{gap:var(--space-sm);flex-shrink:0;display:flex}.rules-summary-icons .rule-icon{color:var(--accent-2);width:auto;font-size:1.1rem}.rules-summary-card p{color:var(--text-secondary);margin:0;font-size:.85rem;line-height:1.4}@media (width<=480px){.rules-summary-card{gap:var(--space-sm);text-align:center;padding:var(--space-md);flex-direction:column}}.btn{font-family:var(--font-display);cursor:pointer;transition:all var(--transition-normal);border:none;outline:none;font-weight:700}.btn-start{width:100%;padding:var(--space-lg) var(--space-xl);letter-spacing:.1em;text-transform:uppercase;color:var(--bg-primary);background:linear-gradient(135deg, var(--accent-2), #45b7aa);border-radius:var(--radius-lg);font-size:1.1rem;box-shadow:0 4px 24px #4ecdc440}.btn-start:hover{box-shadow:0 8px 40px #4ecdc459}.game-page{background:var(--bg-primary);width:100%;height:100%;display:flex;position:relative}.game-board-area{background:radial-gradient(circle at center, #6c5ce708 0%, transparent 60%), var(--bg-primary);min-width:0;min-height:0;margin:var(--space-md);border-radius:var(--radius-xl);border:1px solid #ffffff14;flex:1;position:relative;overflow:hidden;box-shadow:0 0 0 1px #ffffff05,0 10px 40px #00000080,inset 0 0 80px #6c5ce70d}.game-board-container{width:100%;height:100%}.game-sidebar{background:var(--bg-secondary);border-left:1px solid var(--border-subtle);width:280px;height:100%;padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;display:flex;overflow-y:auto}.sidebar-header{text-align:center;padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle)}.sidebar-title{font-family:var(--font-display);letter-spacing:.15em;background:linear-gradient(135deg, var(--accent-1), var(--accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:800}.player-hud{gap:var(--space-md);flex-direction:column;display:flex}.player-card{padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-normal);flex-direction:column;justify-content:space-between;min-height:125px;display:flex}.player-card.active{box-shadow:0 0 20px var(--player-glow)}.player-indicator-row{align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);display:flex}.player-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.player-info{flex-direction:column;gap:2px;min-width:0;display:flex}.player-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.turn-badge{letter-spacing:.1em;border-radius:var(--radius-full);text-transform:uppercase;width:fit-content;padding:2px 8px;font-size:.6rem;font-weight:800;display:inline-block}.player-turn-info{height:25px}.player-score-section{align-items:baseline;gap:var(--space-sm);display:flex}.player-score{font-family:var(--font-display);font-size:2rem;font-weight:800;line-height:1}.score-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.move-counter{align-items:baseline;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);display:flex}.move-count{font-family:var(--font-display);color:var(--text-primary);font-size:1.4rem;font-weight:700}.move-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.move-log{gap:var(--space-sm);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);flex-direction:column;display:flex;overflow:hidden}.move-log-header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--bg-glass-border);background:#ffffff05;justify-content:space-between;align-items:center;display:flex}.move-log-title{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-size:.7rem;font-weight:700}.move-log-count{color:var(--text-muted);opacity:.6;font-size:.65rem}.move-log-table-wrapper{scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;max-height:180px;overflow-y:auto}.move-log-table-wrapper::-webkit-scrollbar{width:4px}.move-log-table-wrapper::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.move-log-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.75rem}.move-log-th{padding:4px var(--space-sm);text-align:left;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:var(--bg-secondary);z-index:1;font-size:.65rem;font-weight:700;position:sticky;top:0}.move-log-num{width:28px;color:var(--text-muted);opacity:.5;text-align:center}.move-log-row:nth-child(odd){background:#ffffff04}.move-log-row:hover{background:#ffffff0a}.move-log-td{padding:3px var(--space-sm);vertical-align:middle}.move-log-cell{font-family:var(--font-display);color:var(--text-secondary);letter-spacing:.05em;border:1px solid #0000;border-radius:4px;padding:1px 5px;font-size:.78rem;font-weight:600;transition:all .15s;display:inline-block}.move-log-last{background:#ffffff0f;font-weight:800}.game-controls{gap:var(--space-sm);flex-direction:column;display:flex}.control-btn{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-normal);font-size:.85rem;font-weight:500;display:flex}.control-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-active)}.control-btn:disabled{opacity:.3;cursor:not-allowed}.control-btn:disabled:hover{background:var(--bg-glass);color:var(--text-secondary);border-color:var(--bg-glass-border)}.reset-btn:hover{color:var(--accent-1);border-color:#ff6b6b4d}.sidebar-footer{padding-top:var(--space-md);border-top:1px solid var(--border-subtle);margin-top:auto}.sidebar-hint{color:var(--text-muted);text-align:center;font-size:.7rem;line-height:1.6}.game-over-overlay{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#07070fd9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.chess-game-page .game-over-overlay{inset:auto;bottom:var(--space-xl);left:var(--space-xl);-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:none;z-index:200;background:0 0;position:absolute}.chess-game-page .game-over-card{pointer-events:auto;max-width:320px;padding:var(--space-lg);box-shadow:0 10px 40px #000c,0 0 0 1px #ffffff1a}.chess-game-page .game-over-title{font-size:1.6rem}.chess-game-page .winner-name{font-size:1rem}.chess-game-page .game-over-actions{flex-direction:row}.chess-game-page .game-over-actions button{padding:var(--space-sm) var(--space-md);font-size:.8rem}.game-over-card{width:100%;max-width:420px;padding:var(--space-2xl) var(--space-xl);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-xl);text-align:center;align-items:center;gap:var(--space-lg);box-shadow:var(--shadow-card), var(--shadow-glow);flex-direction:column;display:flex;position:relative;overflow:hidden}.victory-glow{pointer-events:none;z-index:0;position:absolute;inset:-50%}.trophy-icon{z-index:1;position:relative}.game-over-title{z-index:1;font-family:var(--font-display);letter-spacing:.05em;color:var(--text-primary);font-size:2.4rem;font-weight:800;position:relative}.winner-name{z-index:1;font-family:var(--font-display);font-size:1.2rem;font-weight:600;position:relative}.draw-text{color:var(--text-secondary)}.final-scores{z-index:1;gap:var(--space-sm);flex-direction:column;width:100%;display:flex;position:relative}.final-score-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);display:flex}.final-score-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.final-score-name{color:var(--text-secondary);text-align:left;flex:1;font-size:.9rem}.final-score-value{font-family:var(--font-display);font-size:1.6rem;font-weight:800}.game-over-actions{z-index:1;gap:var(--space-sm);flex-direction:column;width:100%;display:flex;position:relative}.btn-primary{width:100%;padding:var(--space-md) var(--space-lg);letter-spacing:.05em;text-transform:uppercase;color:var(--bg-primary);background:linear-gradient(135deg, var(--accent-2), #45b7aa);border-radius:var(--radius-md);font-size:.95rem;box-shadow:0 4px 16px #4ecdc433}.btn-secondary{width:100%;padding:var(--space-md) var(--space-lg);letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);font-size:.85rem}.btn-secondary:hover{background:var(--bg-card-hover);color:var(--text-primary)}.home-page{background:var(--bg-primary);width:100%;height:100%;position:relative;overflow:hidden auto}.home-content{z-index:1;max-width:960px;padding:var(--space-2xl) var(--space-xl) var(--space-xl);align-items:center;gap:var(--space-2xl);flex-direction:column;min-height:100%;margin:0 auto;display:flex;position:relative}.home-header{text-align:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.home-logo{align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.home-logo-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.home-logo-dot{border-radius:50%;width:12px;height:12px;box-shadow:0 0 10px}.home-title{font-family:var(--font-display);letter-spacing:.15em;background:linear-gradient(135deg,#ff6b6b,#a78bfa,#4ecdc4);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.6rem;font-weight:800;line-height:1}.home-subtitle{color:var(--text-secondary);font-size:1rem;font-weight:400}.games-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));width:100%;display:grid}.game-card{gap:var(--space-md);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-xl);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.game-card:not(.coming-soon):hover{border-color:var(--card-accent,var(--border-active));box-shadow:0 8px 32px #0000004d, 0 0 24px color-mix(in srgb, var(--card-accent) 15%, transparent)}.game-card.coming-soon{opacity:.5}.game-card-glow{pointer-events:none;z-index:0;position:absolute;inset:0}.game-card-header{z-index:1;justify-content:space-between;align-items:flex-start;display:flex;position:relative}.game-card-icon{background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);justify-content:center;align-items:center;width:56px;height:56px;display:flex}.game-card-meta{align-items:flex-end;gap:var(--space-xs);flex-direction:column;display:flex}.game-card-players{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.7rem;font-weight:600}.game-card-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:var(--radius-full);color:var(--text-muted);border:1px solid var(--bg-glass-border);background:#ffffff0d;padding:3px 8px;font-size:.6rem;font-weight:700}.game-card-body{z-index:1;gap:var(--space-xs);flex-direction:column;flex:1;display:flex;position:relative}.game-card-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.02em;font-size:1.5rem;font-weight:800}.game-card-subtitle{text-transform:uppercase;letter-spacing:.1em;color:var(--card-accent,var(--text-secondary));opacity:.8;font-size:.8rem;font-weight:600}.game-card-desc{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.85rem;line-height:1.55}.game-card-action{z-index:1;margin-top:auto;position:relative}.game-card-play-btn{padding:var(--space-sm) var(--space-lg);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--bg-primary);border-radius:var(--radius-md);transition:box-shadow var(--transition-normal);font-size:.8rem;font-weight:700;display:inline-block;box-shadow:0 2px 12px #0003}.game-card:not(.coming-soon):hover .game-card-play-btn{box-shadow:0 4px 20px color-mix(in srgb, var(--card-accent) 35%, transparent)}.lobby-back-link{top:var(--space-lg);left:var(--space-xl);z-index:10;align-items:center;gap:var(--space-sm);color:var(--text-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:all var(--transition-normal);font-size:.85rem;font-weight:500;text-decoration:none;display:flex;position:absolute}.lobby-back-link:hover{color:var(--text-primary);background:var(--bg-glass)}.home-footer{padding-top:var(--space-lg);border-top:1px solid var(--border-subtle);text-align:center;width:100%}.home-footer p{color:var(--text-muted);font-size:.8rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}@media (width<=768px){.game-page{height:100%;display:block;overflow:hidden auto}.game-board-area{aspect-ratio:1;border-left:none;border-right:none;border-radius:0;flex:none;width:100vw;max-width:100%;margin:0}.game-sidebar{border-left:none;border-top:1px solid var(--border-subtle);width:100%;height:auto;padding:var(--space-md);gap:var(--space-sm);flex-direction:column}.sidebar-header{display:none}.player-hud{gap:var(--space-xs);grid-template-columns:1fr 1fr;width:100%;display:grid}.player-card{padding:var(--space-xs) var(--space-sm);min-height:unset;justify-content:center;gap:var(--space-2xs,4px)}.player-info .player-name{font-size:.85rem}.player-score-section .player-score{font-size:1rem!important}.player-turn-info .turn-badge{padding:2px 4px;font-size:.6rem}.move-counter{grid-column:1/-1;justify-content:center}.game-controls{gap:var(--space-sm);flex-direction:row;width:100%}.game-controls .control-btn{flex:1}.sidebar-footer{display:none}.lobby-title{font-size:2.8rem}.grid-presets{grid-template-columns:repeat(2,1fr)}.home-title{font-size:1.8rem}.games-grid{grid-template-columns:1fr}.home-content{padding:var(--space-xl) var(--space-md)}}.mode-select-grid{gap:var(--space-lg);width:100%;max-width:700px;margin-top:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.mode-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-normal);color:var(--text-primary);outline:none;flex-direction:column;align-items:center;display:flex}.mode-card:focus-visible,.mode-card:hover{background:var(--bg-card-hover);border-color:#ffffff26;box-shadow:0 10px 30px #0003}.mode-card-icon{width:80px;height:80px;margin-bottom:var(--space-lg);background:#ffffff08;border-radius:50%;justify-content:center;align-items:center;display:flex}.mode-card-title{font-family:var(--font-heading);margin:0 0 var(--space-sm);letter-spacing:.02em;font-size:1.5rem;font-weight:700}.mode-card-desc{color:var(--text-secondary);margin:0;font-size:.95rem;line-height:1.5}.online-tabs{border-radius:var(--radius-md);margin-bottom:var(--space-xl);background:#0000004d;width:100%;padding:4px;display:flex}.online-tab{color:var(--text-secondary);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex:1;font-size:.95rem;font-weight:600;transition:all .2s}.online-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 2px 10px #0003}.online-tab-content{gap:var(--space-xl);flex-direction:column;width:100%;display:flex}.room-code-input-group{gap:var(--space-sm);flex-direction:column;display:flex}.room-code-input{border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);font-size:1.5rem;font-family:var(--font-mono);color:var(--text-primary);text-align:center;letter-spacing:.2em;text-transform:uppercase;background:#0003;outline:none;font-weight:700;transition:all .2s}.room-code-input:focus{border-color:#4ecdc4;box-shadow:0 0 0 2px #4ecdc433}.room-code-input::placeholder{color:#ffffff1a}.waiting-spinner{margin-bottom:var(--space-xl);justify-content:center;display:flex}.waiting-title{font-family:var(--font-heading);margin:0 0 var(--space-sm);text-align:center;font-size:1.8rem}.waiting-subtitle{color:var(--text-secondary);text-align:center;margin:0 0 var(--space-2xl)}.room-code-display-group{border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-xl);background:#0000004d;align-items:center;display:flex}.room-code-display{color:var(--text-primary);font-size:1.5rem;font-family:var(--font-mono);letter-spacing:.15em;text-align:center;background:0 0;border:none;outline:none;width:100%;font-weight:700}.copy-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:48px;height:48px;color:var(--text-secondary);cursor:pointer;background:#ffffff0d;justify-content:center;align-items:center;transition:all .2s;display:flex}.copy-btn:hover{color:var(--text-primary);background:#ffffff1a}.waiting-cancel-btn{width:auto;min-width:160px;margin:0 auto}.online-error{color:#ff6b6b;padding:var(--space-md);border-radius:var(--radius-sm);text-align:center;width:100%;margin-bottom:var(--space-lg);cursor:pointer;background:#ff6b6b26;border:1px solid #ff6b6b4d;font-weight:500}.online-status-banner{margin:0 var(--space-md) var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;font-size:.9rem;font-weight:500}.online-status-banner.warning{color:#fbbf24;background:#fbbf2426;border:1px solid #fbbf244d}.online-status-banner.error{color:#ff6b6b;background:#ff6b6b26;border:1px solid #ff6b6b4d}.sidebar-room-code{font-family:var(--font-mono);color:var(--text-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);margin-top:var(--space-xs);background:#0000004d;padding:4px 8px;font-size:.85rem}.sidebar-room-code span{color:var(--text-primary);letter-spacing:.05em;font-weight:700}
