:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-card: #1e2a45;--bg-card-hover: #253352;--bg-board: #0f3460;--accent: #b1624d;--accent-hover: #c97a66;--accent-light: rgba(177, 98, 77, .15);--red-piece: #e74c3c;--red-piece-bg: #2c1810;--black-piece: #1a1a2e;--black-piece-text: #ecf0f1;--text-primary: #ecf0f1;--text-secondary: #8892a4;--text-muted: #5a6478;--border: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--success: #2ecc71;--danger: #e74c3c;--warning: #f39c12;--font-main: "Inter", "Noto Sans SC", system-ui, sans-serif;--font-chinese: "Noto Sans SC", "SimHei", sans-serif;--radius: 12px;--radius-sm: 8px;--radius-xs: 4px;--transition: all .2s ease;--transition-slow: all .4s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:12px}.logo{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;letter-spacing:-.3px}.logo-icon{display:flex;align-items:center;color:var(--accent);filter:drop-shadow(0 0 8px rgba(177,98,77,.4))}.logo-text .accent{color:var(--accent)}.nav-links{display:flex;gap:4px}.nav-btn{background:transparent;border:1px solid var(--border-light);color:var(--text-secondary);padding:8px 18px;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-main);font-size:.88rem;font-weight:500;transition:var(--transition)}.nav-btn:hover{background:var(--bg-card);color:var(--text-primary)}.nav-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 12px #b1624d4d}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}.nav-btn,.btn-control,.btn-small{display:inline-flex;align-items:center;gap:6px}.nav-btn span,.btn-control span,.btn-small span{line-height:1}.btn-lang{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-light);color:var(--text-secondary);padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-main);font-size:.82rem;font-weight:600;transition:var(--transition);letter-spacing:.5px}.btn-lang:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--accent)}.btn-lang .icon{opacity:.8}.sidebar-section h3{font-size:.82rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:12px;font-weight:600;display:flex;align-items:center;gap:6px}.game-container{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto 1fr auto;gap:0;max-width:1100px;margin:0 auto;padding:8px 16px;height:calc(100vh - 48px);overflow:auto}.player-bar{display:flex;align-items:center;gap:12px;padding:6px 12px;background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:4px;border:1px solid var(--border);grid-column:1}.player-bar-top{grid-row:1}.player-bar-bottom{grid-row:3;margin-bottom:0;margin-top:4px}.player-info{display:flex;align-items:center;gap:8px;flex:1}.player-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-chinese);font-size:.95rem;font-weight:700;border:2px solid;flex-shrink:0}.red-avatar{background:linear-gradient(135deg,#8b2500,#c0392b);border-color:#e74c3c;color:gold;text-shadow:0 1px 3px rgba(0,0,0,.5)}.black-avatar{background:linear-gradient(135deg,#1a1a2e,#2c3e50);border-color:#5a6478;color:#ecf0f1;text-shadow:0 1px 3px rgba(0,0,0,.5)}.player-details{display:flex;flex-direction:column}.player-name{font-weight:600;font-size:.85rem}.player-level{font-size:.7rem;color:var(--text-muted)}.captured-pieces{display:flex;gap:2px;flex-wrap:wrap;flex:1;font-family:var(--font-chinese);font-size:.75rem;color:var(--text-secondary)}.captured-piece{opacity:.6;font-size:.8rem}.timer{font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;padding:4px 10px;background:var(--bg-primary);border-radius:var(--radius-xs);border:1px solid var(--border);min-width:65px;text-align:center}.timer.active-timer{color:var(--accent);border-color:var(--accent);box-shadow:0 0 12px #b1624d33}.board-wrapper{position:relative;display:flex;align-items:center;justify-content:center;grid-row:2;grid-column:1;min-height:0;overflow:hidden}#boardCanvas{border-radius:var(--radius);box-shadow:0 8px 32px #0006,0 0 0 1px var(--border);cursor:pointer}.game-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;border-radius:var(--radius);z-index:10}.game-overlay.show{display:flex;animation:fadeIn .3s ease}.overlay-content{text-align:center;padding:40px}.overlay-content h2{font-size:2rem;margin-bottom:8px;background:linear-gradient(135deg,var(--accent),#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.overlay-content p{color:var(--text-secondary);margin-bottom:24px;font-size:1.1rem}.sidebar{grid-row:1 / 4;grid-column:2;width:240px;display:flex;flex-direction:column;gap:8px;margin-left:12px;max-height:100%;overflow-y:auto}.sidebar-section{background:var(--bg-card);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border)}.sidebar-section h3{font-size:.75rem;margin-bottom:8px}.control-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.btn{border:none;border-radius:var(--radius-sm);padding:8px 12px;font-family:var(--font-main);font-size:.75rem;font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:4px}.btn-primary{background:var(--accent);color:#fff;padding:10px 24px;font-size:.9rem;border-radius:var(--radius)}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #b1624d4d}.btn-control{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);font-size:.72rem;padding:6px 8px}.btn-control:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-light)}.difficulty-selector{display:flex;gap:3px}.diff-btn{flex:1;padding:6px 2px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-xs);font-family:var(--font-main);font-size:.7rem;font-weight:500;cursor:pointer;transition:var(--transition)}.diff-btn:hover{border-color:var(--accent);color:var(--text-primary)}.diff-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.moves-section{flex:1;display:flex;flex-direction:column;min-height:0}.move-list{flex:1;overflow-y:auto;max-height:180px;font-size:.78rem;font-variant-numeric:tabular-nums}.move-list::-webkit-scrollbar{width:4px}.move-list::-webkit-scrollbar-track{background:transparent}.move-list::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}.move-row{display:flex;padding:4px 8px;border-radius:var(--radius-xs);gap:8px}.move-row:hover{background:var(--accent-light)}.move-num{color:var(--text-muted);min-width:24px}.move-red,.move-black{flex:1;padding:2px 6px;border-radius:3px;cursor:pointer}.move-red:hover,.move-black:hover{background:var(--bg-card-hover)}.move-red{color:#e88}.move-black{color:var(--text-secondary)}.move-empty{color:var(--text-muted);text-align:center;padding:20px;font-style:italic;font-size:.85rem}.eval-bar-container{display:flex;align-items:center;gap:10px}.eval-bar{flex:1;height:10px;background:#333;border-radius:5px;overflow:hidden;position:relative}.eval-fill{height:100%;width:50%;background:linear-gradient(90deg,var(--accent),#e74c3c);border-radius:5px;transition:width .5s ease}.eval-score{font-size:.85rem;font-weight:700;color:var(--text-secondary);min-width:40px;text-align:right}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes glow{0%,to{box-shadow:0 0 8px #e9456033}50%{box-shadow:0 0 20px #e9456080}}@keyframes bounceIn{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.05);opacity:1}to{transform:scale(1)}}.sidebar-section{animation:slideUp .3s ease}.sidebar-section:nth-child(2){animation-delay:.05s}.sidebar-section:nth-child(3){animation-delay:.1s}.sidebar-section:nth-child(4){animation-delay:.15s}.timer.active-timer{animation:glow 2s ease-in-out infinite}.overlay-content{animation:bounceIn .4s ease}.nav-btn:active,.btn:active,.diff-btn:active,.theme-btn:active{transform:scale(.97)}.btn-primary:active{transform:translateY(0) scale(.97)}.move-row{animation:slideIn .15s ease}#boardCanvas{transition:box-shadow .3s ease}#boardCanvas:hover{box-shadow:0 12px 40px #00000080,0 0 0 1px var(--border),0 0 30px #b1624d14}[data-theme=dark]{--bg-primary: #0d0d1a;--bg-secondary: #111128;--bg-card: #1a1a35;--bg-card-hover: #222250;--accent: #ff6b6b;--accent-hover: #ff8e8e;--text-primary: #e8e8f0;--text-secondary: #9090b0}[data-theme=modern]{--bg-primary: #f0ebe3;--bg-secondary: #e8dcc8;--bg-card: #ffffff;--bg-card-hover: #f5f0e8;--accent: #e55039;--accent-hover: #f0704a;--text-primary: #2c2c2c;--text-secondary: #666666;--text-muted: #999999;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .12);--accent-light: rgba(229, 80, 57, .1)}.theme-selector{display:flex;gap:6px}.theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-xs);font-family:var(--font-main);font-size:.7rem;cursor:pointer;transition:var(--transition)}.theme-btn:hover{border-color:var(--accent)}.theme-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.theme-preview{width:28px;height:20px;border-radius:3px;border:1px solid rgba(0,0,0,.15)}.classic-preview{background:#d4a36a}.dark-preview{background:#2a2a3e}.modern-preview{background:#e8dcc8}.history-list{max-height:120px;overflow-y:auto;margin-bottom:8px}.history-list::-webkit-scrollbar{width:3px}.history-list::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:4px 6px;font-size:.75rem;border-radius:var(--radius-xs);gap:6px}.history-item:hover{background:var(--accent-light)}.history-date{color:var(--text-muted);min-width:60px}.history-result{font-weight:600;color:var(--accent)}.history-moves{color:var(--text-secondary)}.history-empty{color:var(--text-muted);text-align:center;padding:12px;font-style:italic;font-size:.8rem}.history-actions{display:flex;gap:6px}.btn-small{padding:5px 10px;font-size:.72rem;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-main);transition:var(--transition);flex:1}.btn-small:hover{background:var(--bg-card-hover);color:var(--text-primary)}.puzzle-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:8px;grid-column:1;display:flex;align-items:center;justify-content:space-between;gap:12px}.puzzle-info.hidden{display:none}.puzzle-header h3{font-size:.95rem;color:var(--accent);margin-bottom:2px}.puzzle-header p{font-size:.8rem;color:var(--text-secondary)}.puzzle-controls{display:flex;align-items:center;gap:8px}#puzzleProgress{font-size:.85rem;font-weight:600;color:var(--text-secondary);min-width:30px;text-align:center}@media(max-width:900px){.game-container{grid-template-columns:1fr;grid-template-rows:auto 1fr auto auto;padding:12px;height:auto;min-height:calc(100vh - 48px)}.sidebar{grid-column:1;grid-row:4;width:100%;margin-left:0;margin-top:12px;flex-direction:row;flex-wrap:wrap;max-height:none;overflow-y:visible}.sidebar-section{flex:1;min-width:200px}.moves-section{width:100%}.move-list{max-height:150px}}@media(max-width:500px){.app-header{padding:6px 12px;flex-direction:column;gap:6px}.game-container{padding:8px;min-height:calc(100vh - 80px)}.logo{font-size:1rem}.nav-links{width:100%;justify-content:center}.nav-btn{padding:6px 10px;font-size:.75rem;flex:1;text-align:center}.player-bar{padding:8px 10px;gap:8px}.player-avatar{width:32px;height:32px;font-size:.9rem}.player-name{font-size:.85rem}.timer{font-size:.95rem;padding:4px 8px;min-width:60px}.sidebar-section{min-width:100%}.sidebar{flex-direction:column}.control-grid{grid-template-columns:1fr 1fr;gap:4px}.btn-control{font-size:.72rem;padding:6px}.puzzle-info{flex-direction:column;text-align:center}.puzzle-controls{width:100%;justify-content:center}.theme-selector{flex-wrap:wrap}}@media(hover:none)and (pointer:coarse){#boardCanvas{touch-action:none;-webkit-tap-highlight-color:transparent}.btn,.nav-btn,.diff-btn,.theme-btn,.btn-small{min-height:44px;min-width:44px}.btn-control{min-height:40px}}body,.app-header,.sidebar-section,.player-bar,.btn,.timer{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.header-actions{display:flex;align-items:center;gap:8px}.user-badge{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:var(--transition)}.user-badge:hover{background:var(--bg-card-hover);border-color:var(--accent)}.user-badge-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;overflow:hidden}.user-badge-avatar img{width:100%;height:100%;object-fit:cover}.user-badge-info{display:flex;flex-direction:column;line-height:1.2}.user-badge-name{font-size:.78rem;font-weight:600;color:var(--text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-badge-rating{font-size:.68rem;color:var(--accent);font-weight:600}.btn-auth{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-main);font-size:.82rem;font-weight:600;transition:var(--transition)}.btn-auth:hover{background:var(--accent-hover)}.btn-auth-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-light)}.btn-auth-outline:hover{background:var(--bg-card);color:var(--text-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal-overlay.hidden{display:none}.modal{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);padding:32px;max-width:380px;width:90%;text-align:center;box-shadow:0 20px 60px #00000080}.modal h2{font-size:1.4rem;margin-bottom:8px;color:var(--text-primary)}.modal p{color:var(--text-secondary);font-size:.9rem;margin-bottom:24px}.modal-buttons{display:flex;flex-direction:column;gap:10px}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:#fff;color:#333;border:1px solid #ddd;border-radius:var(--radius-sm);font-family:var(--font-main);font-size:.95rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-google:hover{background:#f5f5f5;box-shadow:0 2px 8px #00000026}.btn-guest{padding:10px 20px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-main);font-size:.9rem;cursor:pointer;transition:var(--transition)}.btn-guest:hover{background:var(--bg-card-hover);color:var(--text-primary)}.modal-close{margin-top:16px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;font-family:var(--font-main)}.modal-close:hover{color:var(--text-secondary)}.matchmaking-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:150;animation:fadeIn .3s ease}.matchmaking-overlay.hidden{display:none}.matchmaking-content{text-align:center;padding:40px}.matchmaking-spinner{display:inline-block;animation:spin 1.5s linear infinite;color:var(--accent);margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.matchmaking-content h3{font-size:1.3rem;margin-bottom:8px}.matchmaking-content p{color:var(--text-secondary);font-size:.95rem;margin-bottom:24px}.matchmaking-content .btn{min-width:140px}.chat-section{display:flex;flex-direction:column}.chat-messages{max-height:120px;overflow-y:auto;margin-bottom:8px;font-size:.78rem}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.chat-msg{padding:3px 0;color:var(--text-secondary)}.chat-msg-name{font-weight:600;color:var(--accent);margin-right:4px}.chat-msg-system{color:var(--text-muted);font-style:italic;font-size:.75rem}.chat-input-row{display:flex;gap:4px}.chat-input{flex:1;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);padding:6px 10px;font-family:var(--font-main);font-size:.8rem;outline:none}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.btn-send{background:var(--accent);color:#fff;border:none;padding:6px 10px;border-radius:var(--radius-xs);cursor:pointer;display:flex;align-items:center;transition:var(--transition)}.btn-send:hover{background:var(--accent-hover)}.leaderboard-list{max-height:180px;overflow-y:auto}.leaderboard-list::-webkit-scrollbar{width:3px}.leaderboard-list::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.lb-row{display:flex;align-items:center;gap:8px;padding:5px 6px;font-size:.78rem;border-radius:var(--radius-xs)}.lb-row:hover{background:var(--accent-light)}.lb-rank{min-width:22px;font-weight:700;color:var(--text-muted);text-align:center}.lb-rank-1{color:gold}.lb-rank-2{color:silver}.lb-rank-3{color:#cd7f32}.lb-name{flex:1;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-rating{font-weight:600;color:var(--accent);min-width:40px;text-align:right}.lb-record{color:var(--text-muted);font-size:.72rem;min-width:50px;text-align:right}.lb-empty{color:var(--text-muted);text-align:center;padding:16px;font-style:italic;font-size:.8rem}.draw-offer-banner{position:fixed;top:70px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--accent);border-radius:var(--radius);padding:12px 20px;display:flex;align-items:center;gap:12px;z-index:120;box-shadow:0 4px 20px #0006;animation:fadeIn .2s ease}.draw-offer-banner.hidden{display:none}.draw-offer-banner span{font-size:.9rem;color:var(--text-primary)}.draw-offer-banner .btn{padding:6px 14px;font-size:.8rem}.btn-share{display:inline-flex;align-items:center;gap:4px;background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-main);font-size:.75rem;transition:var(--transition)}.btn-share:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--accent)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0006;min-width:180px;z-index:110;animation:fadeIn .15s ease;overflow:hidden}.user-dropdown.hidden{display:none}.user-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--font-main);transition:var(--transition)}.user-dropdown-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.user-dropdown-divider{height:1px;background:var(--border);margin:0}.user-dropdown-stats{padding:10px 14px;display:flex;gap:12px;font-size:.75rem}.user-dropdown-stat{display:flex;flex-direction:column;align-items:center}.user-dropdown-stat-label{color:var(--text-muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.5px}.user-dropdown-stat-value{font-weight:700;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:8px;position:relative}@media(max-width:500px){.user-badge-info{display:none}.user-badge{padding:4px}.header-right{gap:4px}.modal{padding:24px 16px}.matchmaking-content{padding:24px}.draw-offer-banner{top:auto;bottom:20px;flex-wrap:wrap;justify-content:center;max-width:90vw}}
