@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg: #262421;--bg-deep: #1d1b19;--bg-surface: #302e2b;--bg-card: #312e2b;--bg-card-hover: #3d3a36;--bg-elevated: #484541;--green: #E63946;--green-light: #FF6B6B;--green-dark: #C62030;--green-glow: rgba(230, 57, 70, .25);--amber: #e8a93e;--amber-light: #f0c060;--amber-glow: rgba(232, 169, 62, .25);--text: #ffffff;--text-secondary: #b0ada8;--text-muted: #7c7a77;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--success: #4caf50;--warning: #f0c060;--danger: #e74c3c;--info: #5bc0de;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--font-display: "Outfit", sans-serif;--font-body: "Outfit", sans-serif;--board-light: #F0D5CC;--board-dark: #C4554D;--nav-height: 48px;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;color:var(--text);background-color:var(--bg);font-family:var(--font-body);line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{--bg: #f0f0f0;--bg-deep: #e4e4e4;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f5f5f5;--bg-elevated: #e8e8e8;--text: #1a1a1a;--text-secondary: #5a5a5a;--text-muted: #999999;--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background:var(--bg);overflow-x:hidden}a{color:inherit;text-decoration:none}button,input,textarea,select{font-family:inherit;border:none;outline:none;background:none}h1,h2,h3,h4,h5{font-family:var(--font-display);letter-spacing:-.01em;margin-top:0;color:var(--text)}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{display:flex;flex-direction:row;min-height:100vh;min-height:100dvh}.rc-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width, 220px);z-index:900;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent;transition:width .25s cubic-bezier(.4,0,.2,1)}.rc-sidebar::-webkit-scrollbar{width:4px}.rc-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.rc-sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 0 0;flex-shrink:0}.rc-sidebar-brand{display:flex;align-items:center;gap:10px;padding:14px 12px 10px;cursor:pointer;color:var(--text);flex-shrink:0;border:none;background:none;font-family:inherit;text-align:left;min-width:0}.rc-sidebar-brand:hover{opacity:.85}.rc-collapse-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;border:none;background:none;transition:all .2s;flex-shrink:0}.rc-collapse-btn:hover{color:var(--text);background:#e639461f}.rc-crown{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--green);border-radius:8px;color:#fff;flex-shrink:0}.rc-crown-logo{height:48px;width:auto;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(230,57,70,.35))}.rc-brand-text{font-family:var(--font-display);font-size:17px;font-weight:800;letter-spacing:.04em;white-space:nowrap}.rc-sidebar-nav{display:flex;flex-direction:column;padding:4px 8px;gap:1px;flex:1}.rc-sidebar-link{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--radius);color:var(--text-secondary);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;border:none;background:none;font-family:inherit;width:100%;text-align:left}.rc-sidebar-link:hover{color:var(--text);background:#e6394614}.rc-sidebar-link.active{color:#fff;background:#e6394626;position:relative}.rc-sidebar-link.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--green);border-radius:0 3px 3px 0}.rc-sidebar-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:.7;flex-shrink:0}.rc-sidebar-link:hover .rc-sidebar-icon,.rc-sidebar-link.active .rc-sidebar-icon{opacity:1}.rc-sidebar-label{overflow:hidden;text-overflow:ellipsis}.rc-sidebar-bottom{padding:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px;flex-shrink:0;margin-top:auto}.rc-install-btn{background:linear-gradient(135deg,#5b8af526,#5b8af50d);border:1px dashed var(--accent, #5b8af5);border-radius:var(--radius-sm);animation:pwa-pulse 2s ease-in-out infinite}@keyframes pwa-pulse{0%,to{opacity:1}50%{opacity:.7}}.rc-lang-select{padding:7px 10px;border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:500;border:1px solid var(--border);cursor:pointer;width:100%;margin-bottom:4px}.rc-lang-select:hover{border-color:var(--border-strong)}.rc-sidebar-profile{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);color:var(--text-secondary);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .2s;border:none;background:none;font-family:inherit;width:100%;text-align:left}.rc-sidebar-profile:hover{color:var(--text);background:#e6394614}.shell-content{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width, 220px);min-height:100vh;min-height:100dvh;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.shell-main{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.sidebar-collapsed{--sidebar-width: 60px}.sidebar-collapsed .rc-brand-text,.sidebar-collapsed .rc-sidebar-label{display:none}.sidebar-collapsed .rc-sidebar-brand{justify-content:center;padding:12px 0 8px}.sidebar-collapsed .rc-crown-logo{height:40px;width:auto}.sidebar-collapsed .rc-sidebar-top{justify-content:center;padding:4px 0 0}.sidebar-collapsed .rc-collapse-btn{margin:4px auto 0}.sidebar-collapsed .rc-sidebar-link,.sidebar-collapsed .rc-sidebar-profile{justify-content:center;padding:10px 0;gap:0}.sidebar-collapsed .rc-sidebar-profile .rc-sidebar-label{display:none}.sidebar-collapsed .rc-lang-select{font-size:10px;padding:5px 2px;text-align:center}.logo-mobile{display:none}@media(max-width:768px){.logo-desktop{display:none}.logo-mobile{display:block}:root{--sidebar-width: 56px}.rc-brand-text,.rc-sidebar-label{display:none}.rc-sidebar-brand{justify-content:center;padding:12px 0 8px}.rc-crown-logo.logo-mobile{height:40px}.home-hero-logo.logo-mobile{height:80px}.auth-modal-logo-img.logo-mobile{height:60px}.rc-sidebar-top{justify-content:center;padding:4px 0 0}.rc-collapse-btn{display:none}.rc-sidebar-link,.rc-sidebar-profile{justify-content:center;padding:10px 0;gap:0}.rc-sidebar-profile .rc-sidebar-label{display:none}.rc-lang-select{font-size:10px;padding:5px 4px;text-align:center}.shell-main{padding:16px}}@media(min-width:769px)and (max-width:1024px){.logo-desktop{display:none}.logo-mobile{display:block}.rc-crown-logo.logo-mobile{height:44px}.home-hero-logo.logo-mobile{height:90px}.auth-modal-logo-img.logo-mobile{height:70px}}.page{animation:pageIn .3s ease}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-loader{display:flex;align-items:center;justify-content:center;min-height:40vh}.page-loader-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.notfound-page{display:flex;align-items:center;justify-content:center;min-height:60vh}.notfound-content{text-align:center;max-width:420px}.notfound-piece{font-size:72px;line-height:1;margin-bottom:8px;opacity:.6;animation:notfoundFloat 3s ease-in-out infinite}@keyframes notfoundFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.notfound-code{font-size:64px;font-weight:800;color:var(--green);margin:0;line-height:1.1}.notfound-title{font-size:20px;font-weight:600;margin:8px 0;color:var(--text)}.notfound-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.notfound-actions{display:flex;gap:12px;justify-content:center}.skeleton-pulse{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes clockPulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-card{border-radius:var(--radius);overflow:hidden;background:var(--bg-surface);border:1px solid var(--border)}.skeleton-row{display:flex;align-items:center;gap:12px;padding:10px 0}.skeleton-lines{width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;border:none;white-space:nowrap}.btn.primary{background:var(--green);color:#fff}.btn.primary:hover{background:var(--green-light)}.btn.gold{background:var(--amber);color:#262421;font-weight:700}.btn.gold:hover{background:var(--amber-light)}.btn.outline{background:transparent;color:var(--text);border:1px solid var(--border-strong)}.btn.outline:hover{background:#e6394614;border-color:var(--green-light)}.btn.ghost{background:transparent;color:var(--text-secondary);padding:8px 14px}.btn.ghost:hover{color:var(--text);background:#e6394614}.btn.danger{background:#dc2626;color:#fff}.btn.danger:hover{background:#ef4444}.btn.sm{padding:6px 14px;font-size:13px}.btn.lg{padding:14px 28px;font-size:16px}.input{width:100%;padding:10px 14px;border-radius:var(--radius);background:var(--bg-surface);color:var(--text);font-size:14px;border:1px solid var(--border);transition:all .2s}.input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow)}.input::placeholder{color:var(--text-muted)}.link-btn{background:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:4px 0}.link-btn:hover{color:var(--amber-light)}.muted{color:var(--text-muted)}.chip{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .2s}.chip:hover{background:#e6394614;color:var(--text)}.chip.active{background:var(--green);border-color:var(--green);color:#fff}.pill{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary)}.pill:hover{color:var(--text);border-color:var(--border-strong)}.pill.subtle{background:transparent}.pill.pill-active,.pill-active{background:var(--green);border-color:var(--green);color:#fff}.field{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--text-secondary)}.field span{font-weight:500}.input-row{display:flex;gap:8px;align-items:center}.input-row .input{flex:1}.form-grid{display:flex;flex-direction:column;gap:12px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px;padding-top:14px;border-top:1px solid var(--border)}.helper{font-size:13px;padding:8px 12px;border-radius:var(--radius-sm);margin-top:4px}.helper.error{color:var(--danger);background:#e74c3c14}.helper.success{color:var(--success);background:#e6394614}.helper.info{color:var(--info);background:#5bc0de14}.rc-hero-eyebrow{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:4px}.rc-stats-row{display:flex;gap:12px;margin:8px 0}.rc-stat-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px;background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border)}.rc-stat-card strong{font-size:22px;font-family:var(--font-display);color:var(--amber-light)}.rc-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.mode-label{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.glass{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.glass-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s}.glass-card:hover{border-color:var(--border-strong);background:var(--bg-card-hover)}.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000c;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}}.auth-modal-card{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:40px 32px;max-width:420px;width:90%;text-align:center;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-lg),var(--shadow);animation:resultPop .3s cubic-bezier(.34,1.56,.64,1)}.auth-modal-logo{margin-bottom:12px;display:flex;align-items:center;justify-content:center}.auth-modal-logo-img{height:80px;width:auto;object-fit:contain;filter:drop-shadow(0 3px 10px rgba(230,57,70,.35))}.auth-modal-or{color:var(--text-muted);font-size:13px;padding:4px 0}.auth-modal-options{display:flex;flex-direction:column;gap:8px}.home-page{display:flex;flex-direction:column;gap:28px}.home-hero{display:flex;gap:24px;align-items:stretch}.home-board{flex:0 0 auto;width:min(50%,420px);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.home-sidebar{flex:1;display:flex;flex-direction:column;gap:12px;padding:8px 0}.home-hero-brand{display:flex;align-items:center;gap:14px}.home-hero-logo{height:100px;width:auto;max-width:100%;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 4px 16px rgba(230,57,70,.45));margin-bottom:4px}.home-sidebar h1{font-size:28px;font-weight:800;margin-bottom:2px;line-height:1.2}.home-sidebar p{color:var(--text-secondary);font-size:14px;margin-bottom:6px}.home-btns{display:flex;flex-direction:column;gap:8px}.home-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;border-radius:var(--radius);font-size:16px;font-weight:700;cursor:pointer;transition:all .15s;text-align:left}.home-btn.main{background:var(--green);color:#fff}.home-btn.main:hover{background:var(--green-light)}.home-btn.sub{background:var(--bg-card);border:1px solid var(--border);color:var(--text);font-weight:600;font-size:15px}.home-btn.sub:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}.home-btn-icon{font-size:20px;width:24px;text-align:center;flex-shrink:0}@media(max-width:768px){.home-hero{flex-direction:column;align-items:center}.home-board{width:100%;max-width:360px}}.home-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.home-stats{display:flex;gap:8px}.home-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.home-stat-val{font-size:20px;font-weight:800;font-family:var(--font-display);color:var(--text)}.home-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}@media(max-width:600px){.home-stats{gap:6px}.home-stat{padding:8px 4px}.home-stat-val{font-size:16px}}.home-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .2s}.home-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-3px)}.home-card-board{width:100%;aspect-ratio:16 / 10;overflow:hidden}.home-card-board svg{width:100%;height:100%;display:block}.home-card-info{padding:14px 16px}.home-card-tag{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--green);text-transform:uppercase}.home-card-info h3{font-size:15px;font-weight:600;margin:4px 0 2px}.home-card-info p{font-size:13px;color:var(--text-muted);margin:0}.modes-page{display:flex;flex-direction:column;gap:24px}.modes-header{text-align:center;padding:20px 0}.modes-header h1{font-size:28px;font-weight:800}.modes-header p{color:var(--text-secondary);margin-top:6px}.modes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.mode-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--green);opacity:0;transition:opacity .3s}.mode-card:hover:before{opacity:1}.mode-card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow)}.mode-card-icon{font-size:40px;margin-bottom:14px;line-height:1}.mode-card-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:#e639461a;padding:3px 10px;border-radius:20px;margin-bottom:8px;width:fit-content}.mode-card h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:6px}.mode-card p{font-size:13px;color:var(--text-muted);margin:0 0 16px}.mode-card-options{display:flex;flex-direction:column;gap:8px;margin-top:auto}.mode-option-btn{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius);background:var(--bg-surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all .2s;font-size:13px;font-weight:500}.mode-option-btn:hover{background:var(--bg-elevated);border-color:var(--green)}.mode-option-btn .mode-option-time{color:var(--amber);font-weight:600}.mode-setup{display:flex;flex-direction:column;gap:14px}.mode-setup label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary);font-weight:500}.mode-setup select{padding:8px 12px;border-radius:var(--radius);background:var(--bg-surface);color:var(--text);border:1px solid var(--border);font-size:14px}.mode-setup select:focus{border-color:var(--green)}.mode-actions{display:flex;gap:10px;margin-top:8px}.gp-page{display:flex;align-items:flex-start;justify-content:center;gap:20px}.gp-board-col{display:flex;flex-direction:column;align-items:center;gap:8px}.gp-player-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px}.gp-player-bar.active-turn{border-color:var(--amber);box-shadow:0 0 12px var(--amber-glow)}.gp-player-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.gp-player-info{flex:1;display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}.gp-player-name{font-weight:600;font-size:14px;white-space:nowrap}.gp-player-rating{font-size:12px;color:var(--text-muted)}.gp-player-captured{font-size:14px;color:var(--text-secondary);letter-spacing:1px;display:flex;gap:1px;flex-shrink:1;min-width:0;overflow:hidden;flex-wrap:nowrap}.gp-material-diff{font-size:11px;font-weight:700;color:var(--amber);flex-shrink:0}.gp-clock{font-family:var(--font-display);font-size:20px;font-weight:700;padding:4px 12px;border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text);min-width:72px;text-align:center}.gp-clock.running{background:var(--amber);color:#262421}@keyframes clockPulse{0%,to{opacity:1}50%{opacity:.7}}.gp-side-panel{width:300px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - var(--nav-height) - 48px)}.gp-moves-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex:1;display:flex;flex-direction:column}.gp-moves-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.gp-move-row{display:flex;align-items:center;padding:3px 8px;border-radius:4px}.gp-move-row:hover{background:#e639460f}.gp-move-num{width:28px;font-size:12px;color:var(--text-muted);font-weight:600;flex-shrink:0}.gp-move-san{padding:2px 8px;font-size:13px;font-weight:500;cursor:pointer;border-radius:4px;width:50%;color:var(--text)}.gp-move-san:hover{background:#e639461a}.gp-move-san.current{background:#e8a93e26;color:var(--amber-light)}.gp-action-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.gp-action-btn{width:64px;height:64px;object-fit:contain;border-radius:14px;filter:drop-shadow(0 3px 8px rgba(230,57,70,.35));border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:16px}.gp-action-btn:hover{color:var(--text);background:#e639461a}.gp-action-btn:disabled{opacity:.3;cursor:not-allowed}.gp-controls{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.gp-result-overlay{position:fixed;inset:0;z-index:950;display:flex;align-items:center;justify-content:center;background:#000c;animation:fadeIn .3s ease}.gp-result-card{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:36px 32px;text-align:center;max-width:380px;width:90%;box-shadow:var(--shadow-lg),var(--shadow);animation:resultPop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes resultPop{0%{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.gp-result-icon{font-size:48px;margin-bottom:12px}.gp-result-title{font-family:var(--font-display);font-size:24px;font-weight:800;margin-bottom:8px}.gp-result-sub{color:var(--text-secondary);font-size:14px;margin-bottom:20px}.gp-result-actions{display:flex;flex-direction:column;gap:8px}.gp-result-actions .btn{width:100%;justify-content:center}.gp-rematch-incoming{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--amber);border-radius:var(--radius);font-size:13px;color:var(--text);flex-wrap:wrap}.gp-rematch-incoming span:first-child{flex:1;min-width:100px}.gp-rematch-incoming .btn-sm{padding:4px 12px;font-size:12px}.gp-clock.low-time{animation:clockPulse 1s ease-in-out infinite;border-color:var(--danger)!important;color:var(--danger)!important}.gp-connection{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:var(--text-muted)}.gp-conn-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0}.gp-conn-dot.disconnected{background:var(--danger)}.gp-conn-dot.connecting{background:var(--warning);animation:clockPulse 1s infinite}.gp-hint-guide{padding:12px;background:#e8a93e14;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;color:var(--amber-light);display:flex;align-items:center;gap:8px}@media(max-width:900px){.gp-page{flex-direction:column;align-items:center;gap:12px}.gp-board-col{width:100%;order:-1}.gp-side-panel{width:100%;max-width:560px}.gp-player-bar{max-width:100%}}@media(max-width:500px){.gp-player-bar{padding:8px 10px}.gp-player-avatar{width:30px;height:30px;font-size:15px}.gp-clock{font-size:16px;min-width:60px;padding:3px 8px}.gp-player-name{font-size:13px}}.gp-player-details{display:flex;flex-direction:column;flex-shrink:0}.gp-player-badge{font-size:10px;font-weight:700;color:var(--amber);letter-spacing:.06em}.gp-thinking-dot{font-size:14px;margin-left:4px}.gp-status-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.gp-status-pill{font-size:13px;font-weight:600;color:var(--green-light)}.gp-status-seat{margin-left:auto;font-size:13px;color:var(--text-muted)}.gp-moves-tabs{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}.gp-tab{font-size:13px;font-weight:600;color:var(--text-secondary)}.gp-tab.active{color:var(--text)}.gp-tab-btn{margin-left:auto;font-size:12px;font-weight:600;color:var(--green);cursor:pointer;background:none;border:none;padding:2px 8px;border-radius:var(--radius-sm)}.gp-tab-btn:hover{background:#e639461a}.gp-moves-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:24px 0}.gp-move-nav{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;border-top:1px solid var(--border)}.gp-nav-play{color:var(--green)}.gp-action-bar .gp-action-btn{width:auto;gap:6px;padding:6px 12px;font-size:13px}.gp-action-icon{font-size:16px}.gp-action-resign:hover{color:var(--danger)}.gp-action-new{color:var(--green);font-weight:600}.gp-action-disabled{opacity:.5;cursor:not-allowed}.gp-confirm-bar{display:flex;align-items:center;gap:8px;width:100%;padding:4px 0}.gp-confirm-text{flex:1;font-size:13px;font-weight:600;color:var(--text)}.gp-confirm-bar .btn-sm{padding:4px 14px;font-size:12px;white-space:nowrap}.btn.danger{background:var(--danger);color:#fff;border:none}.btn.danger:hover{opacity:.85}.gp-opening-badge{font-size:11px;font-weight:600;color:var(--amber-light);background:#e8a93e1f;padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.gp-result-opening{font-size:14px;font-weight:600;color:var(--amber-light);margin:8px 0 4px}.gp-result-moves{font-size:12px;margin-bottom:12px}.gp-coach-toggle{display:flex;align-items:center;gap:4px;margin-left:auto}.gp-coach-btn{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:12px;cursor:pointer;color:var(--text-muted);transition:all .25s;display:flex;align-items:center;gap:4px}.gp-coach-btn.active{background:#e8a93e1f;border-color:#e8a93e66;color:var(--amber-light);box-shadow:0 0 12px #e8a93e1a}.gp-coach-btn:hover{background:#e8a93e14;color:var(--text);border-color:#e8a93e40}.gp-speak-btn{font-size:15px;padding:4px 8px}.coach-bubble-wrap{display:flex;flex-direction:row;align-items:flex-start;gap:12px;padding:14px;background:transparent;border-radius:0;animation:coachSlideIn .35s cubic-bezier(.34,1.56,.64,1);transition:opacity .3s,transform .3s;box-shadow:none;position:relative;overflow:visible}.coach-bubble-wrap.compact{padding:10px;gap:10px}.coach-bubble-wrap.fading{opacity:0;transform:translateY(-10px) scale(.97)}@keyframes coachSlideIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.coach-avatar-col{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}.coach-avatar-img{width:64px;height:64px;border-radius:50%;object-fit:cover;box-shadow:0 2px 8px #00000040;transition:transform .25s}.coach-avatar-img:hover{transform:scale(1.05)}.compact .coach-avatar-img{width:48px;height:48px}.coach-name{font-size:9px;font-weight:800;color:#fff9;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.coach-speech{flex:1;position:relative;background:#fff;border-radius:8px;padding:10px 14px;min-width:0;box-shadow:0 1px 4px #0000001a}.coach-speech-arrow{position:absolute;left:-7px;top:16px;width:0;height:0;border:7px solid transparent;border-right-color:#fff}.coach-quality-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:10px;margin-bottom:4px}.badge-info{background:#5a8fd41f;color:#3a7bd5}.badge-success{background:#27ae601f;color:#1e8c4c}.badge-warning{background:#e8a93e26;color:#b88420}.badge-danger{background:#e85d4a1f;color:#c63d2c}.badge-brilliant{background:#1baa9b1f;color:#148f82}.coach-bubble-text{font-size:14px;line-height:1.5;color:#312e2b;margin:0}.coach-bubble-close{position:absolute;top:4px;right:6px;background:none;border:none;color:#00000047;cursor:pointer;font-size:13px;padding:2px 5px;border-radius:4px;transition:all .2s}.coach-bubble-close:hover{color:#0000008c;background:#0000000f}.coach-play-page{width:100%;height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:4px 12px;overflow:hidden;box-sizing:border-box}.coach-setup{display:flex;gap:20px;align-items:flex-start;justify-content:center;width:100%;max-width:980px;height:100%}.coach-setup-board-col{flex:0 1 auto;display:flex;flex-direction:column;max-height:100%;align-self:center;overflow:visible;padding:2px}.coach-setup-board-col .board-wrapper{pointer-events:none;opacity:.88}.coach-setup-panel{flex:0 1 300px;min-width:240px;max-width:320px;max-height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:10px;background:#262522;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px 14px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.coach-setup-title{font-size:17px;font-weight:800;color:#fff;letter-spacing:.01em;margin:0;text-align:left;flex-shrink:0}.coach-setup-panel .coach-bubble-wrap{padding:8px;gap:8px;flex-shrink:0}.coach-setup-panel .coach-avatar-img{width:48px;height:48px}.coach-setup-panel .coach-speech{padding:8px 10px}.coach-setup-panel .coach-bubble-text{font-size:12.5px;line-height:1.4}.coach-setup-panel .coach-name{font-size:8px}.coach-player-bar{display:flex;align-items:center;gap:6px;padding:3px 8px;background:#1e1e1ceb;border-radius:5px;flex-shrink:0}.coach-player-bar.top{margin-bottom:2px}.coach-player-bar.bottom{margin-top:2px}.coach-player-bar.active-turn{background:#e8a93e1f;border:1px solid rgba(232,169,62,.25)}.coach-player-avatar{font-size:16px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff0f}.coach-avatar-icon{background:linear-gradient(135deg,#3a7bd5,#2c5fa8)}.coach-player-name{font-weight:600;font-size:12.5px;color:#ffffffeb;flex:1}.coach-player-rating{font-size:11.5px;color:#ffffff80;font-weight:500}.coach-thinking{animation:coachPulse 1.2s ease-in-out infinite;font-size:15px}@keyframes coachPulse{0%,to{opacity:.4}50%{opacity:1}}.coach-clock{font-family:JetBrains Mono,Fira Code,monospace;font-size:15px;font-weight:700;padding:3px 8px;border-radius:6px;background:#ffffff0f;color:#fffc;min-width:58px;text-align:center}.coach-clock.running{background:#e8a93e26;color:var(--amber-light, #f5ce7e)}.coach-clock.low-time{background:#e850442e;color:#f08c7e;animation:coachClockBlink 1s ease-in-out infinite}@keyframes coachClockBlink{0%,to{opacity:1}50%{opacity:.55}}.coach-material-diff{font-size:11px;font-weight:700;color:var(--amber-light, #f5ce7e);background:#e8a93e1f;padding:1px 5px;border-radius:4px}.coach-level-section{display:flex;flex-direction:column;gap:4px;flex:1 1 0%;min-height:0;overflow:hidden}.coach-level-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.coach-level-title{font-weight:700;font-size:13px;color:#ffffffd9}.coach-level-arrow{color:#fff6}.coach-level-list{display:flex;flex-direction:column;gap:3px;overflow-y:auto;flex:1 1 0%;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(232,169,62,.25) transparent}.coach-level-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:pointer;transition:all .2s;color:#ffffffbf;font-size:13px;flex-shrink:0}.coach-level-item:hover{background:#e8a93e14;border-color:#e8a93e33;transform:translate(2px)}.coach-level-item.selected{background:#e8a93e24;border-color:#e8a93e73;color:#fff;box-shadow:0 2px 10px #e8a93e1a}.coach-level-name{font-weight:600}.coach-level-rating{font-size:12px;color:#ffffff73;font-weight:500;white-space:nowrap}.coach-color-section{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.coach-color-label{font-weight:600;font-size:11.5px;color:#fff9}.coach-color-options{display:flex;gap:5px}.coach-color-btn{flex:1;padding:6px;font-size:18px;text-align:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:pointer;transition:all .2s}.coach-color-btn:hover{background:#e8a93e14;border-color:#e8a93e33}.coach-color-btn.selected{background:#e8a93e26;border-color:#e8a93e73;box-shadow:0 0 12px #e8a93e26}.coach-play-btn{padding:10px 18px;font-size:15px;font-weight:800;color:#1e1c18;background:linear-gradient(135deg,var(--amber, #e8a93e) 0%,var(--amber-light, #f5ce7e) 100%);border:none;border-radius:10px;cursor:pointer;transition:all .25s;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.coach-play-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #e8a93e59}.coach-play-btn:active{transform:translateY(0)}.coach-voice-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;flex-shrink:0}.coach-voice-btn:hover{background:#ffffff1a}.coach-voice-btn.active{background:#e8a93e26;border-color:#e8a93e59}.coach-game-layout{display:flex;gap:12px;max-width:1060px;width:100%;height:100%;align-items:center;justify-content:center}.coach-board-col{flex:0 1 auto;display:flex;flex-direction:column;max-height:100%;align-self:center;overflow:visible;padding:2px}.coach-side-panel{flex:0 1 280px;min-width:240px;max-width:300px;height:100%;max-height:100%;overflow:hidden;display:flex;flex-direction:column;gap:0;background:#262522;border-radius:8px}.coach-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.coach-panel-title{font-size:15px;font-weight:800;color:#fff;letter-spacing:.01em}.coach-opening-row{flex-shrink:0;padding:6px 14px;border-bottom:1px solid rgba(255,255,255,.06)}.coach-opening-badge{display:inline-block;font-size:11.5px;color:#ffffffb3;background:#ffffff0f;padding:4px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.08);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coach-game-controls{display:flex;align-items:center;gap:8px}.coach-moves-panel{background:transparent;border-top:1px solid rgba(255,255,255,.06);border-radius:0;overflow:hidden;flex:1;min-height:0;display:flex;flex-direction:column}.coach-moves-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#fff6;padding:8px 14px 4px;flex-shrink:0}.coach-moves-scroll{flex:1;min-height:0;overflow-y:auto;padding:3px 14px 6px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.coach-move-row{display:flex;align-items:center;gap:4px;padding:2px 0}.coach-move-num{font-size:12px;color:#ffffff4d;min-width:26px;text-align:right}.coach-move-btn{padding:2px 7px;font-size:13px;font-weight:600;color:#fffc;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s;min-width:46px;text-align:center}.coach-move-btn:hover{background:#e8a93e1a;border-color:#e8a93e26}.coach-move-btn.active{background:#e8a93e2e;border-color:#e8a93e59;color:var(--amber-light, #f5ce7e)}.coach-live-btn{width:100%;padding:5px;font-size:11px;font-weight:700;color:#27ae60;background:#27ae6014;border:none;border-top:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .2s;flex-shrink:0}.coach-live-btn:hover{background:#27ae6024}.coach-end-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0;padding:8px 14px}.coach-analyze-btn{padding:10px 16px;font-size:13px;font-weight:700;color:#ffffffe6;background:#5a8fd426;border:1px solid rgba(90,143,212,.3);border-radius:10px;cursor:pointer;transition:all .25s}.coach-analyze-btn:hover{background:#5a8fd440;border-color:#5a8fd480}.coach-resign-btn{margin:0 14px 10px;padding:8px 14px;font-size:12px;font-weight:600;color:#ffffff80;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;flex-shrink:0}.coach-resign-btn:hover{color:#fffc;background:#e8504424;border-color:#e8504459}@media(max-width:900px){.coach-play-page{height:auto;min-height:calc(100vh - 56px);overflow-y:auto}.coach-setup{flex-direction:column;align-items:center;gap:14px;height:auto}.coach-setup-board-col{flex:none;width:100%;max-width:440px;align-items:center}.coach-setup-panel{flex:none;width:100%;max-width:440px;max-height:none;overflow-y:visible}}@media(max-width:768px){.coach-play-page{height:auto;min-height:calc(100vh - 56px);overflow-y:auto}.coach-game-layout{flex-direction:column;align-items:center;height:auto}.coach-board-col{flex:none;width:100%;max-width:500px;align-items:center}.coach-side-panel{flex:none;max-width:500px;width:100%;max-height:none;overflow-y:visible}}.analysis-coach-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:linear-gradient(135deg,#1e1e1cf2,#282622f2);border:1px solid rgba(232,169,62,.12);border-radius:10px}.analysis-critical-moments{padding:14px;background:linear-gradient(135deg,#1e1e1cf2,#282622f2);border:1px solid rgba(232,169,62,.12);border-radius:10px}.analysis-critical-moments h3{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--amber-light);text-transform:uppercase;letter-spacing:.05em}.critical-moments-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(232,169,62,.3) transparent}.critical-moment-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px;cursor:pointer;transition:all .25s;text-align:left;width:100%}.critical-moment-item:hover{background:#e8a93e14;border-color:#e8a93e40;transform:translate(2px)}.critical-blunder{border-left:3px solid #e85d4a}.critical-mistake{border-left:3px solid #e58f2a}.critical-brilliant{border-left:3px solid #1baa9b}.critical-turning_point{border-left:3px solid var(--amber)}.critical-moment-icon{font-size:20px;flex-shrink:0}.critical-moment-info{display:flex;flex-direction:column;gap:2px;min-width:0}.critical-moment-move{font-size:13px;font-weight:600;color:#ffffffeb}.critical-moment-label{font-size:11px;color:#ffffff80}.gp-controls-btns{display:flex;gap:8px;width:100%}.gp-hint-tokens{font-size:13px;font-weight:600;color:var(--amber-light)}.gp-hint-cd{font-size:12px;color:var(--text-muted)}.gp-clock-icon{margin-right:4px;font-size:14px}.gp-clock-time{font-variant-numeric:tabular-nums}.pz-page{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.pz-board-col{display:flex;flex-direction:column;align-items:center;gap:12px}.pz-side{display:flex;flex-direction:column;gap:14px}.pz-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.pz-header-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}.pz-header-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--amber);display:flex;align-items:center;justify-content:center;font-size:20px;color:#262421}.pz-header h2{font-family:var(--font-display);font-size:20px;font-weight:700;margin:0}.pz-stat-badge{font-size:13px;color:var(--amber);font-weight:600;margin-left:auto}.pz-progress{height:6px;border-radius:3px;background:var(--bg-surface);overflow:hidden}.pz-progress-fill{height:100%;border-radius:3px;background:var(--green);transition:width .3s ease}.pz-action-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s}.pz-action-card:hover{border-color:var(--green-light);background:var(--bg-card-hover)}.pz-action-icon{font-size:24px;flex-shrink:0}.pz-action-text{display:flex;flex-direction:column}.pz-action-title{font-weight:600;font-size:14px}.pz-action-sub{font-size:12px;color:var(--text-muted)}.pz-filters{display:flex;gap:6px;flex-wrap:wrap}.pz-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .2s}.pz-chip:hover,.pz-chip.active{background:#e639461f;border-color:var(--green);color:var(--green-light)}.pz-list{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.pz-list-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;font-size:13px}.pz-list-item:hover{background:#e639460f}.pz-list-item.active{background:#e8a93e1a}.pz-list-num{width:24px;color:var(--text-muted);font-weight:600}.pz-list-fen{flex:1;color:var(--text-secondary);font-family:monospace;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pz-list-status{font-size:14px}.pz-diff-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pz-diff-dot.easy{background:#43a047}.pz-diff-dot.medium{background:#f9a825}.pz-diff-dot.hard{background:#e53935}.pz-nav-row{display:flex;align-items:center;justify-content:space-between;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.pz-msg{padding:14px;border-radius:var(--radius);font-size:14px;font-weight:600;text-align:center}.pz-msg.success,.pz-msg.ok{background:#34d3991a;border:1px solid rgba(52,211,153,.2);color:var(--success)}.pz-msg.error,.pz-msg.bad{background:#f871711a;border:1px solid rgba(248,113,113,.2);color:var(--danger)}@media(max-width:900px){.pz-page{grid-template-columns:1fr}.pz-board-col{order:-1}.pz-side{order:2}}.pz-action-cards{display:flex;flex-direction:column;gap:6px}.pz-sidebar-info{display:flex;justify-content:center;margin-bottom:4px}.pz-side-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:700}.pz-side-badge.white{background:#ffffff1f;color:#fff}.pz-side-badge.black{background:#0006;color:var(--text-secondary)}.puzzle-feedback{padding:12px;border-radius:var(--radius);font-size:14px;font-weight:600;text-align:center}.puzzle-feedback.ok{background:#34d3991a;border:1px solid rgba(52,211,153,.2);color:var(--success)}.puzzle-feedback.bad{background:#f871711a;border:1px solid rgba(248,113,113,.2);color:var(--danger)}.edu-page{display:flex;flex-direction:column;gap:24px}.edu-header{text-align:center;padding:16px 0}.edu-header h1{font-size:28px;font-weight:800}.edu-tabs{display:flex;gap:4px;padding:4px;background:var(--bg-surface);border-radius:var(--radius);width:fit-content;margin:0 auto}.edu-tab{padding:8px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.edu-tab:hover{color:var(--text)}.edu-tab.active{background:var(--bg-card);color:var(--amber-light);box-shadow:var(--shadow-sm)}.edu-list{display:flex;flex-direction:column;gap:8px}.edu-lesson-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .25s}.edu-lesson-card:hover{border-color:var(--green-light);background:var(--bg-card-hover)}.edu-lesson-card.active{border-color:var(--amber);box-shadow:0 0 12px var(--amber-glow)}.edu-lesson-num{width:40px;height:40px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px;color:#fff;flex-shrink:0}.edu-lesson-info{flex:1}.edu-lesson-title{font-weight:600;font-size:15px}.edu-lesson-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.edu-lesson-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#34d3991f;color:var(--success)}.edu-viewer{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}.edu-board-area{display:flex;flex-direction:column;align-items:center;gap:12px}.edu-step-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:14px}.edu-step-title{font-family:var(--font-display);font-size:16px;font-weight:700}.edu-step-text{font-size:14px;color:var(--text-secondary);line-height:1.6}.edu-step-nav{display:flex;gap:8px;margin-top:auto}.edu-tip-card{padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.edu-tip-card h3{font-size:16px;margin-bottom:8px}.edu-tip-card p{font-size:14px;color:var(--text-secondary);line-height:1.6}.edu-quiz-option{display:block;width:100%;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:14px;text-align:left;transition:all .2s}.edu-quiz-option:hover{border-color:var(--green);background:#e6394614}.edu-quiz-option.correct{border-color:var(--success);background:#34d3991a}.edu-quiz-option.wrong{border-color:var(--danger);background:#f871711a}@media(max-width:900px){.edu-viewer{grid-template-columns:1fr}.edu-board-area{order:-1}.edu-step-panel{order:2}}.edu-tip-icon{font-size:28px;margin-bottom:8px}.edu-step-dots{display:flex;align-items:center;gap:6px}.edu-dot{width:8px;height:8px;border-radius:50%;background:var(--border-strong);cursor:pointer;transition:all .2s}.edu-dot:hover{background:var(--text-muted)}.edu-dot.active{background:var(--green);transform:scale(1.3)}.edu-quiz-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.edu-quiz-score{font-weight:700;color:var(--green-light);font-size:15px}.edu-quiz-options{display:flex;flex-direction:column;gap:8px;margin:16px 0}.edu-quiz-opt{display:block;width:100%;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:14px;text-align:left;transition:all .2s}.edu-quiz-opt:hover{border-color:var(--green);background:#e6394614}.edu-quiz-correct{border-color:var(--success)!important;background:#34d3991a!important}.edu-quiz-wrong{border-color:var(--danger)!important;background:#f871711a!important}.edu-quiz-explain{padding:14px;background:#e639460f;border-radius:var(--radius);margin-top:12px;display:flex;flex-direction:column;gap:10px}.edu-quiz-explain p{font-size:14px;color:var(--text-secondary)}.edu-quiz-result{text-align:center;padding:32px 16px}.edu-quiz-final-score{font-size:36px;font-weight:800;font-family:var(--font-display);color:var(--amber-light);margin:8px 0}.edu-puzzle-info{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.edu-puzzle-hint{font-size:13px;padding:8px 12px;background:#e8a93e14;border-radius:var(--radius-sm)}.pz-chip.primary{background:var(--green);border-color:var(--green);color:#fff}.store-page{display:flex;flex-direction:column;gap:24px}.store-hero{position:relative;border-radius:var(--radius-xl);padding:32px 28px;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.store-hero h1{font-size:28px;margin:0}.store-hero p{color:var(--text-secondary);max-width:500px;margin:4px 0 0}.store-hero-inner{flex:1;min-width:200px}.store-balance{position:relative;display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius);background:#e8a93e1f;border:1px solid var(--border-strong);font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--amber-light);margin-top:12px}.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.store-pack{display:flex;flex-direction:column;align-items:center;padding:20px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s;text-align:center}.store-pack:hover{transform:translateY(-3px);border-color:var(--amber);box-shadow:var(--shadow)}.store-pack-img{width:80px;height:80px;object-fit:contain;margin-bottom:10px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.store-pack-amount{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--amber-light);margin-bottom:4px}.store-pack-label{font-size:12px;color:var(--text-muted)}.store-pack-price{margin-top:10px;padding:6px 16px;border-radius:20px;background:var(--green);color:#fff;font-weight:700;font-size:13px}.store-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.store-section h3{font-size:16px;font-weight:700;margin:0 0 14px}.btn-sm,.btn.btn-sm{padding:6px 14px;font-size:12px}.board-wrapper{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid var(--border-strong);box-sizing:content-box}.board-wrapper.board-locked{opacity:.7;pointer-events:none}.board-backdrop{position:absolute;inset:0;background:var(--bg-surface);z-index:0}.board-grid{display:grid;position:relative;z-index:1}.board-square{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;border:none;-webkit-tap-highlight-color:transparent;transition:background-color .15s}.board-square-selected{box-shadow:inset 0 0 0 2px var(--amber)}.board-piece{width:85%;height:85%;object-fit:contain;pointer-events:none;filter:drop-shadow(1px 2px 3px rgba(0,0,0,.4));transition:transform .15s,opacity .08s}.board-piece-slide{position:absolute;object-fit:contain;pointer-events:none;filter:drop-shadow(1px 2px 3px rgba(0,0,0,.4));z-index:20;will-change:transform;animation:pieceSlide .25s cubic-bezier(.25,.1,.25,1) forwards}@keyframes pieceSlide{0%{transform:translate(var(--slide-from-x),var(--slide-from-y))}to{transform:translate(var(--slide-to-x),var(--slide-to-y))}}@keyframes pieceAppear{0%{transform:scale(.92);opacity:.7}to{transform:scale(1);opacity:1}}.board-square-dragging .board-piece{opacity:.4;transform:scale(.9)}.board-square-dragover{box-shadow:inset 0 0 0 3px var(--amber-light)}.legal-dot{width:26%;height:26%;border-radius:50%;pointer-events:none}.board-square-legal.board-square:not(:has(.board-piece)) .legal-dot{background:#0003}.board-square-hint{box-shadow:inset 0 0 0 2px var(--amber-light),inset 0 0 8px #e8a93e4d}.board-square-highlight{background-color:#e8a93e59!important}.coord-label{position:absolute;font-size:9px;font-weight:700;font-family:var(--font-body);pointer-events:none;opacity:.6;z-index:2}.coord-rank{left:2px;top:1px}.coord-file{right:2px;bottom:0}.promotion-overlay{position:absolute;inset:0;z-index:5;background:#0006}.promotion-popup{position:absolute;z-index:6;display:flex;flex-direction:column;background:var(--bg-card);border:2px solid var(--amber);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}.promotion-option{display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--bg-surface);border:none;transition:background .15s}.promotion-option:hover{background:var(--bg-elevated)}.promotion-piece-img{width:80%;height:80%;object-fit:contain}.settings-overlay{position:fixed;inset:0;z-index:990;background:#000000b3;animation:fadeIn .2s ease}.settings-panel{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:90vw;z-index:991;background:var(--bg-card);border-left:1px solid var(--border-strong);padding:24px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;animation:slideLeft .25s ease}@keyframes slideLeft{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-panel h2{font-family:var(--font-display);font-size:20px;display:flex;align-items:center;justify-content:space-between}.settings-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;color:var(--text-muted);transition:all .2s}.settings-close:hover{background:#e639461a;color:var(--text)}.settings-group{display:flex;flex-direction:column;gap:10px}.settings-group-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.settings-item-label{font-size:14px}.settings-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px;border-bottom:1px solid var(--border)}.settings-header h3{font-family:var(--font-display);font-size:18px;color:var(--text);margin:0}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-section h4{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin:0}.theme-mode-row{display:flex;gap:8px}.theme-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:var(--radius);background:var(--bg-card);color:var(--text-secondary);border:2px solid var(--border);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.theme-mode-btn:hover{border-color:var(--border-strong);color:var(--text)}.theme-mode-btn.active{border-color:var(--green);color:var(--text);background:#e639461a}.settings-toggle{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:14px;color:var(--text-secondary);cursor:pointer}.settings-toggle input[type=checkbox]{display:none}.toggle-track{position:relative;width:42px;height:24px;background:var(--border);border-radius:12px;transition:background .2s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}.settings-toggle input:checked+.toggle-track{background:var(--green)}.settings-toggle input:checked+.toggle-track:after{transform:translate(18px)}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;border-radius:8px;border:2px solid transparent;background:none;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.theme-swatch:hover{background:#e639460f}.theme-swatch.active{border-color:var(--amber);background:#e8a93e14;color:var(--text)}.theme-preview{display:grid;grid-template-columns:1fr 1fr;width:40px;height:40px;border-radius:4px;overflow:hidden}.theme-sq{width:100%;height:100%}.theme-label{font-size:11px}.lang-grid{display:flex;flex-wrap:wrap;gap:6px}.rc-mini-board{width:100%;aspect-ratio:1}.rc-mini-board svg{width:100%;height:100%;display:block;border-radius:4px}.gold-text{color:var(--amber)}.glow-border{border:1px solid var(--border-strong);box-shadow:0 0 20px var(--amber-glow)}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 3s infinite}@keyframes shimmer{0%{left:-100%}to{left:200%}}.badge-new{padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.05em;background:var(--green);color:#fff}.rc-user-btn{display:flex;align-items:center;justify-content:center;padding:0;margin-left:6px;cursor:pointer;background:none;border:none}.rc-user-avatar{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;transition:transform .15s}.rc-user-btn:hover .rc-user-avatar{transform:scale(1.1)}.profile-page{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.profile-header{display:flex;align-items:center;gap:20px;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;flex-shrink:0}.profile-header-info{flex:1}.profile-header-info h1{font-size:24px;font-family:var(--font-display);margin:0}.profile-name-row,.profile-edit-row{display:flex;align-items:center;gap:8px}.profile-edit-row .input{max-width:200px}.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.profile-stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:transform .15s}.profile-stat-card:hover{transform:translateY(-2px)}.profile-stat-card.accent{border-color:var(--green);background:#e639460f}.profile-stat-icon{font-size:20px}.profile-stat-val{font-size:24px;font-weight:700;font-family:var(--font-display)}.profile-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.profile-winrate-section{padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.profile-winrate-section h3{margin:0 0 12px;font-size:16px}.profile-winrate-bar{display:flex;height:24px;border-radius:12px;overflow:hidden;background:var(--bg-surface)}.profile-winrate-fill{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;transition:width .4s ease}.profile-winrate-fill.win{background:var(--green)}.profile-winrate-fill.draw{background:var(--text-muted)}.profile-winrate-fill.loss{background:var(--danger)}.profile-winrate-legend{display:flex;gap:16px;margin-top:8px;font-size:12px;color:var(--text-secondary)}.profile-legend-item{display:flex;align-items:center;gap:6px}.profile-legend-dot{width:10px;height:10px;border-radius:50%}.profile-legend-dot.win{background:var(--green)}.profile-legend-dot.draw{background:var(--text-muted)}.profile-legend-dot.loss{background:var(--danger)}.profile-section{padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.profile-section h3{margin:0 0 14px;font-size:16px}.profile-badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.profile-badge-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border-radius:var(--radius);background:var(--bg-surface);border:1px solid var(--border);text-align:center;transition:transform .15s}.profile-badge-card.earned{border-color:var(--amber)}.profile-badge-card:hover{transform:translateY(-2px)}.profile-badge-icon{font-size:28px}.profile-badge-label{font-size:13px;font-weight:600}.profile-badge-desc{font-size:11px;color:var(--text-muted)}.profile-goals{display:flex;flex-direction:column;gap:10px}.profile-goal-card{padding:12px 16px;background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border)}.profile-goal-header{display:flex;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:8px}.profile-goal-bar{height:6px;border-radius:3px;background:var(--bg-elevated);overflow:hidden}.profile-goal-fill{height:100%;background:var(--green);border-radius:3px;transition:width .4s}.profile-actions{display:flex;gap:10px;flex-wrap:wrap}.skeleton{background:var(--bg-surface);border-radius:var(--radius);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:shimmer 1.5s infinite}.skeleton-line{height:14px;margin-bottom:8px;border-radius:4px}.skeleton-line.w60{width:60%}.skeleton-line.w80{width:80%}.skeleton-line.w40{width:40%}.skeleton-card{height:80px;border-radius:var(--radius)}.board-arrow-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.board-arrow-line{stroke:#e8a93e99;stroke-width:8;stroke-linecap:round;fill:none}.board-arrow-head{fill:#e8a93e99}@keyframes clockPulse{0%,to{opacity:1}50%{opacity:.6}}.gp-clock.low-time{background:var(--danger);color:#fff;animation:clockPulse 1s infinite}@media(max-width:600px){.home-cards,.home-dash-row{grid-template-columns:1fr}.gp-side-panel{display:none}.modes-grid{grid-template-columns:1fr}.store-grid{grid-template-columns:repeat(2,1fr)}.store-hero{padding:20px;flex-direction:column;text-align:center}.edu-tabs{width:100%;overflow-x:auto}.edu-tab{padding:8px 14px;font-size:13px;white-space:nowrap}.pz-header{padding:14px}.profile-stats-grid{grid-template-columns:repeat(2,1fr)}.profile-header{flex-direction:column;text-align:center}.profile-badges-grid{grid-template-columns:repeat(2,1fr)}.opening-content,.coord-mode-cards{grid-template-columns:1fr}.lb-podium{flex-direction:column;align-items:center}.lb-podium-item.first{transform:none}}@media(min-width:601px)and (max-width:900px){.home-cards,.modes-grid{grid-template-columns:repeat(2,1fr)}}@media(max-height:500px){.shell-main{padding:8px 12px}.home-sidebar h1{font-size:20px}.rc-footer{display:none}}.rc-footer{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-deep)}.rc-footer-sep{opacity:.4}.history-page{max-width:800px;margin:0 auto;padding:24px 16px}.history-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.history-header h2{margin:0;font-size:1.5rem}.history-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.history-filter-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.history-filter-btn:hover{border-color:var(--green);color:var(--green)}.history-filter-btn.active{background:var(--green);color:#fff;border-color:var(--green)}.history-list{display:flex;flex-direction:column;gap:10px}.history-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .2s}.history-card:hover{border-color:var(--green);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.history-result-badge{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0}.history-result-badge.win{background:#e6394633;color:var(--green)}.history-result-badge.loss{background:#ca343133;color:#ca3431}.history-result-badge.draw{background:#e8a93e33;color:var(--amber)}.history-card-info{flex:1;min-width:0}.history-card-players{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;font-size:12px;color:var(--text-muted)}.history-mode-chip{background:var(--bg-body);border:1px solid var(--border);border-radius:6px;padding:1px 6px;font-size:11px;text-transform:uppercase}.history-elo-change{font-weight:600;font-size:13px}.history-elo-change.pos{color:var(--green)}.history-elo-change.neg{color:#ca3431}.history-card-date{font-size:12px;color:var(--text-muted);flex-shrink:0}.history-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.history-empty h2{margin-bottom:8px}.history-clear-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:6px 14px;color:var(--text-muted);cursor:pointer;font-size:13px}.history-clear-btn:hover{border-color:#ca3431;color:#ca3431}.analysis-page{max-width:1100px;margin:0 auto;padding:16px}.analysis-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.analysis-header h2{margin:0;font-size:1.3rem}.analysis-header .muted{font-size:13px}.analysis-content{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}@media(max-width:768px){.analysis-content{grid-template-columns:1fr}.analysis-board-col{order:-1}}.analysis-board-col{display:flex;flex-direction:column;align-items:center}.analysis-move-counter{font-size:14px;font-weight:600;color:var(--text-secondary);min-width:70px;text-align:center}.analysis-current-move{display:flex;align-items:center;gap:10px;margin-top:8px;padding:8px 16px;background:var(--bg-card);border-radius:10px;border:1px solid var(--border)}.analysis-quality-badge{padding:4px 12px;border-radius:20px;color:#fff;font-weight:600;font-size:13px;white-space:nowrap}.analysis-side{display:flex;flex-direction:column;gap:16px}.analysis-summary{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.analysis-summary h3{margin:0 0 12px;font-size:14px}.analysis-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.analysis-summary-col{display:flex;flex-direction:column;gap:6px}.analysis-summary-name{font-weight:600;font-size:13px;margin-bottom:4px}.analysis-quality-row{display:flex;align-items:center;gap:6px;font-size:13px}.analysis-quality-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.analysis-moves{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;max-height:400px;overflow-y:auto}.analysis-moves h3{margin:0 0 10px;font-size:14px}.analysis-move{border-left:3px solid transparent;padding-left:6px;font-size:13px;transition:background .15s}.analysis-move.current{background:#e6394626}.analysis-loading{display:flex;align-items:center;gap:8px;padding:20px 0}.analysis-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}.analysis-empty{text-align:center;padding:60px 20px}.deep-analysis-btn{width:100%;font-weight:600}.deep-progress-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.deep-progress-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:14px}.deep-progress-bar{height:6px;border-radius:3px;background:var(--border);overflow:hidden}.deep-progress-fill{height:100%;border-radius:3px;background:var(--green);transition:width .3s}.accuracy-report{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px}.accuracy-report h3{margin:0 0 14px;font-size:15px;font-weight:700}.accuracy-badges{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.accuracy-badge{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--bg-darker, rgba(0,0,0,.1));border-radius:10px;padding:12px 8px}.accuracy-player{font-weight:600;font-size:13px}.accuracy-pct{font-size:28px;font-weight:800;line-height:1.1}.accuracy-acpl{font-size:12px}.accuracy-phases{display:flex;flex-direction:column;gap:6px}.accuracy-phase-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0;border-bottom:1px solid var(--border)}.accuracy-phase-row:last-child{border-bottom:none}.accuracy-phase-name{font-weight:600;min-width:90px}.accuracy-phase-bars{display:flex;gap:16px}.accuracy-phase-val{font-weight:600;min-width:56px;text-align:center}.puzzle-rush-overlay{position:fixed;inset:0;z-index:1000;background:#000000b3;display:flex;align-items:center;justify-content:center}.puzzle-rush-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:440px;width:90%;text-align:center}.puzzle-rush-card h2{margin:0 0 8px;font-size:1.5rem}.puzzle-rush-timer{font-size:48px;font-weight:800;font-variant-numeric:tabular-nums;margin:16px 0}.puzzle-rush-timer.low{color:#ca3431;animation:pulse .6s infinite}.puzzle-rush-stats{display:flex;justify-content:center;gap:24px;margin:12px 0}.puzzle-rush-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.puzzle-rush-stat-val{font-size:28px;font-weight:700}.puzzle-rush-stat-label{font-size:12px;color:var(--text-muted)}.puzzle-rush-result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:440px;width:90%;text-align:center}.puzzle-rush-result-card h2{margin:0 0 12px}.puzzle-rush-best{color:var(--green);font-weight:700}.chess960-toggle{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:14px;cursor:pointer}.chess960-toggle input{width:18px;height:18px;accent-color:var(--green);cursor:pointer}.chess960-badge{background:#e58f2a;color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}.opening-stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-top:12px}.opening-stats-card h4{margin:0 0 10px;font-size:14px}.opening-stats-bar{display:flex;height:24px;border-radius:6px;overflow:hidden;margin-bottom:8px;font-size:11px;font-weight:700;color:#fff}.opening-stats-w{background:#96bc4b;display:flex;align-items:center;justify-content:center;min-width:24px}.opening-stats-d{background:#888;display:flex;align-items:center;justify-content:center;min-width:24px}.opening-stats-l{background:#ca3431;display:flex;align-items:center;justify-content:center;min-width:24px}.opening-stats-total{font-size:12px;color:var(--text-muted);text-align:center;margin-bottom:12px}.opening-stats-moves{display:flex;flex-direction:column;gap:6px}.opening-stats-move-row{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}.opening-stats-move-row:hover{background:var(--bg-hover, rgba(255,255,255,.05))}.opening-stats-move-san{font-weight:700;min-width:44px}.opening-stats-move-bar{flex:1;display:flex;height:14px;border-radius:4px;overflow:hidden;font-size:10px;color:#fff}.opening-stats-move-count{font-size:11px;color:var(--text-muted);min-width:40px;text-align:right}.pz-rating-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}.pz-rating-val{font-size:24px;font-weight:800}.pz-rating-delta{font-size:14px;font-weight:600}.pz-rating-delta.up{color:#96bc4b}.pz-rating-delta.down{color:#ca3431}.profile-level-section{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:20px}.profile-level-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}.profile-level-badge{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;background:linear-gradient(135deg,var(--green),#5a9a2f);color:#fff;box-shadow:0 2px 10px #e6394666}.profile-level-info{flex:1;min-width:0}.profile-level-title{font-weight:700;font-size:16px;margin-bottom:6px}.profile-xp-bar-wrap{display:flex;align-items:center;gap:10px}.profile-xp-bar{flex:1;height:10px;background:var(--bg-body);border-radius:5px;overflow:hidden}.profile-xp-fill{height:100%;background:linear-gradient(90deg,var(--green),#96d44a);border-radius:5px;transition:width .5s ease}.profile-xp-text{font-size:12px;color:var(--text-muted);white-space:nowrap}.profile-elo-row{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.profile-elo-icon{font-size:22px}.profile-elo-val{font-size:24px;font-weight:800;color:var(--amber)}.profile-elo-rank{font-size:14px;font-weight:600;color:var(--text-secondary);background:#e8a93e26;padding:3px 10px;border-radius:8px}.rating-chart-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px;margin-top:8px}.rating-chart-header{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}.rating-chart-current{font-size:28px;font-weight:800;color:var(--text-primary)}.rating-chart-change{font-size:16px;font-weight:700}.rating-chart-change.positive{color:var(--success, #43a047)}.rating-chart-change.negative{color:var(--danger, #e53935)}.rating-chart-svg{width:100%;height:auto;display:block}.rating-chart-empty{text-align:center;padding:24px 0}.avatar-picker-panel{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.avatar-picker-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;width:380px;max-width:95vw;max-height:85vh;overflow-y:auto}.avatar-picker-inner h3{margin:0 0 16px;font-size:18px;text-align:center}.avatar-picker-preview{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:18px}.avatar-preview-circle{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;background:var(--green);transition:background .3s;box-shadow:0 4px 16px #0000004d}.avatar-section-title{font-size:12px;text-transform:uppercase;color:var(--text-muted);letter-spacing:1px;margin:14px 0 8px;font-weight:600}.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.avatar-item{width:100%;aspect-ratio:1;border-radius:10px;border:2px solid transparent;background:var(--bg-body);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:all .15s}.avatar-item:hover{border-color:var(--text-muted);transform:scale(1.1)}.avatar-item.selected{border-color:var(--green);background:#e6394626}.avatar-color-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.avatar-color-item{width:100%;aspect-ratio:1;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:all .15s}.avatar-color-item:hover{transform:scale(1.1)}.avatar-color-item.selected{border-color:#fff;box-shadow:0 0 0 2px var(--green)}.avatar-picker-actions{display:flex;gap:10px;margin-top:18px}.avatar-picker-actions button{flex:1;padding:10px;border-radius:10px;border:none;font-weight:600;cursor:pointer;font-size:14px;transition:opacity .2s}.avatar-picker-actions button:first-child{background:var(--bg-body);color:var(--text-secondary)}.avatar-picker-actions button:last-child{background:var(--green);color:#fff}.opening-page{max-width:1100px;margin:0 auto;padding:20px 16px}.opening-page h2{margin:0 0 6px;font-size:1.4rem}.opening-page>.muted{margin-bottom:16px;display:block}.opening-search{width:100%;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:14px;margin-bottom:16px}.opening-search:focus{outline:none;border-color:var(--green)}.opening-cat-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.opening-cat-tab{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.opening-cat-tab:hover{border-color:var(--green);color:var(--green)}.opening-cat-tab.active{background:var(--green);color:#fff;border-color:var(--green)}.opening-content{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}@media(max-width:800px){.opening-content{grid-template-columns:1fr}.opening-board-col{order:-1;position:static}}.opening-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.opening-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;transition:all .2s}.opening-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.opening-card.active{border-color:var(--green);background:#e6394614}.opening-card-eco{display:inline-block;padding:2px 8px;border-radius:6px;background:#e6394626;color:var(--green);font-size:11px;font-weight:700;margin-bottom:6px}.opening-card h4{margin:0 0 4px;font-size:14px}.opening-card .muted{font-size:12px}.opening-card-diff{margin-top:6px;font-size:12px}.opening-board-col{position:sticky;top:80px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px}.opening-board-col h3{margin:0 0 6px;font-size:15px}.opening-board-col .muted{display:block;margin-bottom:12px;font-size:13px}.opening-board-col .chessboard-wrap{margin-bottom:12px}.opening-move-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.opening-move-btn{padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-body);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .15s}.opening-move-btn:hover{border-color:var(--green);color:var(--green)}.opening-move-btn.current{background:var(--green);color:#fff;border-color:var(--green)}.opening-practice-btn{width:100%;padding:10px;border-radius:10px;border:none;background:var(--green);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s}.opening-practice-btn:hover{opacity:.85}.leaderboard-page{max-width:700px;margin:0 auto;padding:24px 16px}.leaderboard-page h2{margin:0 0 4px;font-size:1.4rem}.leaderboard-page>.muted{display:block;margin-bottom:18px}.lb-sort-tabs{display:flex;gap:8px;margin-bottom:20px}.lb-sort-tab{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.lb-sort-tab:hover{border-color:var(--green);color:var(--green)}.lb-sort-tab.active{background:var(--green);color:#fff;border-color:var(--green)}.lb-podium{display:flex;justify-content:center;align-items:flex-end;gap:14px;margin-bottom:24px;padding:16px 0}.lb-podium-item{display:flex;flex-direction:column;align-items:center;padding:16px 12px;border-radius:14px;background:var(--bg-card);border:1px solid var(--border);min-width:100px;transition:all .3s}.lb-podium-item.first{background:linear-gradient(135deg,#e8a93e26,#e8a93e0d);border-color:var(--amber);transform:scale(1.08)}.lb-podium-item.second{background:linear-gradient(135deg,#c0c0c01f,#c0c0c00a);border-color:#9e9e9e}.lb-podium-item.third{background:linear-gradient(135deg,#cd7f321f,#cd7f320a);border-color:#cd7f32}.lb-podium-medal{font-size:28px;margin-bottom:6px}.lb-podium-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--bg-body);margin-bottom:6px}.lb-podium-name{font-weight:700;font-size:14px;margin-bottom:2px}.lb-podium-val{font-size:18px;font-weight:800;color:var(--amber)}.lb-list{display:flex;flex-direction:column;gap:6px}.lb-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);transition:all .15s}.lb-row:hover{border-color:var(--green)}.lb-row.is-you{border-color:var(--green);background:#e6394614}.lb-rank{width:30px;font-weight:700;font-size:15px;color:var(--text-muted);text-align:center}.lb-row-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--bg-body);flex-shrink:0}.lb-row-info{flex:1;min-width:0}.lb-row-name{font-weight:600;font-size:14px}.lb-row-sub{font-size:12px;color:var(--text-muted)}.lb-row-val{font-size:16px;font-weight:800;color:var(--amber)}.pz-action-card.active-mode{border-color:var(--green);background:#e639461f}.pz-streak-info{display:block;font-size:12px;color:var(--amber);margin-top:4px;font-weight:700}.pz-daily-done{display:inline-block;margin-left:6px;font-size:14px}.pz-streak-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;font-size:14px}.pz-streak-bar strong{color:var(--amber)}.pz-daily-bar{padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;font-size:14px;text-align:center}.pz-daily-complete{color:var(--green);font-weight:600}.friends-page{max-width:700px;margin:0 auto;padding:24px 16px}.friends-page h2{margin:0 0 4px;font-size:1.4rem}.friends-page>.muted{display:block;margin-bottom:18px}.friends-search{width:100%;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:14px;margin-bottom:16px}.friends-search:focus{outline:none;border-color:var(--green)}.friends-tabs{display:flex;gap:8px;margin-bottom:18px}.friends-tab{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.friends-tab:hover{border-color:var(--green);color:var(--green)}.friends-tab.active{background:var(--green);color:#fff;border-color:var(--green)}.friends-list{display:flex;flex-direction:column;gap:8px}.friend-card{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);transition:all .2s}.friend-card:hover{border-color:var(--green)}.friend-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--bg-body);flex-shrink:0;position:relative}.friend-online-dot{position:absolute;bottom:2px;right:2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-card)}.friend-online-dot.online{background:var(--green)}.friend-online-dot.offline{background:var(--text-muted)}.friend-info{flex:1;min-width:0}.friend-name{font-weight:600;font-size:14px}.friend-sub{font-size:12px;color:var(--text-muted)}.friend-actions{display:flex;gap:6px}.friend-action-btn{padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-body);color:var(--text-secondary);cursor:pointer;font-size:12px;transition:all .15s}.friend-action-btn:hover{border-color:var(--green);color:var(--green)}.friend-action-btn.primary{background:var(--green);color:#fff;border-color:var(--green)}.friend-action-btn.danger:hover{border-color:#ca3431;color:#ca3431}.friends-empty{text-align:center;padding:40px 20px;color:var(--text-muted)}.friends-empty-icon{font-size:48px;margin-bottom:12px}.friend-request-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:#ca3431;color:#fff;font-size:11px;font-weight:700;margin-left:6px;padding:0 5px}.game-chat{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-top:10px}.game-chat.compact{font-size:13px}.game-chat.minimized .chat-header{border-radius:12px}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--bg-body);border:none;color:var(--text-primary);cursor:pointer;width:100%;font-size:13px;font-weight:600}.chat-header:hover{background:#ffffff0a}.chat-unread{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:#ca3431;color:#fff;font-size:11px;font-weight:700;padding:0 5px;margin-left:6px}.chat-toggle{color:var(--text-muted);font-size:10px}.chat-messages{max-height:160px;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:4px}.chat-empty{text-align:center;color:var(--text-muted);padding:16px 0;font-size:12px}.chat-msg{display:flex;flex-direction:column;padding:4px 10px;border-radius:8px;background:var(--bg-body);max-width:85%;align-self:flex-start}.chat-msg.mine{align-self:flex-end;background:#e6394626}.chat-sender{font-size:10px;font-weight:600;color:var(--text-muted)}.chat-text{font-size:13px}.chat-quick{display:flex;gap:4px;padding:6px 10px;overflow-x:auto;border-top:1px solid var(--border)}.chat-quick-btn{padding:3px 8px;border-radius:12px;border:1px solid var(--border);background:var(--bg-body);color:var(--text-secondary);cursor:pointer;font-size:11px;white-space:nowrap;transition:all .15s}.chat-quick-btn:hover{border-color:var(--green);color:var(--green)}.chat-input-form{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border)}.chat-input{flex:1;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg-body);color:var(--text-primary);font-size:13px}.chat-input:focus{outline:none;border-color:var(--green)}.chat-send-btn{padding:6px 12px;border-radius:8px;border:none;background:var(--green);color:#fff;cursor:pointer;font-size:14px;transition:opacity .15s}.chat-send-btn:disabled{opacity:.4;cursor:default}.coord-page{max-width:500px;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;align-items:center}.coord-page h2{margin:0 0 6px;font-size:1.4rem}.coord-mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;margin:24px 0}.coord-mode-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:24px 16px;text-align:center;cursor:pointer;transition:all .2s}.coord-mode-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.coord-mode-icon{font-size:36px;margin-bottom:10px;display:block}.coord-mode-card h3{margin:0 0 6px;font-size:15px}.coord-best-score{margin-top:16px;padding:12px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:14px}.coord-hud{display:flex;align-items:center;gap:18px;margin-bottom:14px;padding:10px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;font-size:16px;font-weight:600;width:100%;justify-content:center}.coord-hud-score{color:var(--green)}.coord-hud-timer{color:var(--amber)}.coord-hud-lives{letter-spacing:3px}.coord-target-display{font-size:42px;font-weight:800;margin-bottom:12px;padding:10px 30px;border-radius:12px;background:var(--bg-card);border:2px solid var(--border);transition:all .2s}.coord-target-display.correct{border-color:var(--green);color:var(--green)}.coord-target-display.wrong{border-color:#ca3431;color:#ca3431;animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.coord-board{width:100%;max-width:400px;aspect-ratio:1}.coord-grid{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:8px;overflow:hidden;border:2px solid var(--border)}.coord-square{position:relative;cursor:pointer;transition:all .1s}.coord-square:hover{opacity:.8}.coord-square.target{animation:pulse 1s infinite}.coord-square.highlighted{box-shadow:inset 0 0 0 3px var(--amber)}.coord-label-rank{position:absolute;top:2px;left:3px;font-size:9px;font-weight:700;color:#ffffff80;pointer-events:none}.coord-label-file{position:absolute;bottom:1px;right:3px;font-size:9px;font-weight:700;color:#ffffff80;pointer-events:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.coord-name-form{display:flex;gap:8px;margin-top:14px;width:100%;max-width:200px}.coord-name-input{flex:1;padding:10px 14px;border-radius:10px;border:2px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:22px;font-weight:700;text-align:center;text-transform:lowercase}.coord-name-input:focus{outline:none;border-color:var(--green)}.coord-name-input.correct{border-color:var(--green)}.coord-name-input.wrong{border-color:#ca3431;animation:shake .3s}.coord-result{text-align:center;padding:40px 20px}.coord-final-score{margin:20px 0}.coord-final-num{font-size:64px;font-weight:800;color:var(--green);display:block}.coord-new-best{font-size:18px;font-weight:700;color:var(--amber);margin:10px 0}.coord-result-stats{margin:16px 0;font-size:14px;color:var(--text-muted)}.coord-result-actions{display:flex;gap:10px;justify-content:center;margin-top:20px}.home-dashboard{margin-bottom:24px}.home-dash-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.home-dash-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .2s}.home-dash-card:hover{border-color:var(--green)}.home-dash-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;background:linear-gradient(135deg,var(--green),#5a9a2f);color:#fff;flex-shrink:0}.home-dash-info{min-width:0}.home-dash-info strong{font-size:16px;display:block}.home-dash-info .muted{font-size:12px}.home-xp-mini-bar{height:6px;background:var(--bg-body);border-radius:3px;overflow:hidden;margin:4px 0}.home-xp-mini-fill{height:100%;background:linear-gradient(90deg,var(--green),#96d44a);border-radius:3px;transition:width .5s ease}.home-daily-widget{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:14px;cursor:pointer;transition:all .2s}.home-daily-widget:hover{border-color:var(--amber)}.home-daily-left{display:flex;align-items:center;gap:12px}.home-daily-icon{font-size:24px}.home-daily-left div{display:flex;flex-direction:column}.home-daily-left strong{font-size:14px}.home-daily-left .muted{font-size:12px}.home-daily-arrow{font-size:18px;color:var(--text-muted)}.home-recent{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.home-recent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.home-recent-header h4{margin:0;font-size:14px}.home-recent-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--border);cursor:pointer;transition:opacity .15s}.home-recent-item:hover{opacity:.8}.home-recent-item:first-of-type{border-top:none}.home-recent-badge{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.home-recent-badge.win{background:#e6394633;color:var(--green)}.home-recent-badge.loss{background:#ca343133;color:#ca3431}.home-recent-badge.draw{background:#e8a93e33;color:var(--amber)}.home-recent-names{flex:1;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-recent-moves{font-size:12px;color:var(--text-muted);flex-shrink:0}.edu-quick-actions{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}.edu-quick-card{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.edu-quick-card:hover{border-color:var(--green);color:var(--green)}.premove-from{box-shadow:inset 0 0 0 3px #6495ed99!important}.premove-to{box-shadow:inset 0 0 0 3px #6495ed99!important;background:#6495ed33!important}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-size:14px;font-weight:500;box-shadow:0 8px 24px #0006;pointer-events:auto;cursor:pointer;animation:toastIn .3s ease forwards;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-exit{animation:toastOut .3s ease forwards}.toast-icon{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.toast-msg{flex:1;line-height:1.3}.toast-success{border-left:4px solid var(--green)}.toast-success .toast-icon{background:#e6394633;color:var(--green)}.toast-error{border-left:4px solid #ca3431}.toast-error .toast-icon{background:#ca343133;color:#ca3431}.toast-info{border-left:4px solid #5ba4cf}.toast-info .toast-icon{background:#5ba4cf33;color:#5ba4cf}.toast-warning{border-left:4px solid var(--amber)}.toast-warning .toast-icon{background:#e8a93e33;color:var(--amber)}.toast-achievement{border-left:4px solid #ffd700;background:linear-gradient(135deg,var(--bg-card),rgba(255,215,0,.06))}.toast-achievement .toast-icon{background:#ffd70033;color:gold}.toast-xp{border-left:4px solid var(--green)}.toast-xp .toast-icon{background:#e6394633;color:var(--green)}@keyframes toastIn{0%{opacity:0;transform:translate(40px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(40px) scale(.9)}}.board-annotation-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:8}.time-presets{display:flex;flex-direction:column;gap:8px}.time-category{display:flex;flex-direction:column;gap:4px}.time-cat-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.tournament-page{max-width:960px;margin:0 auto;padding:24px 16px}.tournament-setup{text-align:center;max-width:440px;margin:0 auto}.tournament-setup h1{margin-bottom:8px}.tournament-form{display:flex;flex-direction:column;gap:18px;margin-top:24px;text-align:left}.tournament-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.tournament-header h1{margin:0}.tournament-meta{display:flex;gap:8px;flex-wrap:wrap}.tournament-champion{display:flex;align-items:center;gap:16px;padding:20px 24px;border-radius:14px;background:linear-gradient(135deg,#e8a93e1f,#ffd7000f);border:2px solid var(--amber);margin-bottom:20px}.tournament-champion.champion-human{background:linear-gradient(135deg,#e639461f,#e639460a);border-color:var(--green)}.champion-emoji{font-size:42px}.tournament-champion h2{margin:0;font-size:18px}.tournament-next-match{background:var(--bg-card);border:1px solid var(--green);border-radius:14px;padding:20px 24px;margin-bottom:24px;text-align:center}.tournament-next-match h3{margin:0 0 12px;font-size:16px}.tournament-matchup{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.tm-player{font-size:14px;font-weight:600}.tm-you{color:var(--green)}.tm-opponent{color:var(--amber)}.tm-vs{font-size:12px;font-weight:800;color:var(--text-muted);padding:4px 10px;background:var(--bg-body);border-radius:6px}.tournament-match-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.tournament-bracket{display:flex;gap:12px;overflow-x:auto;padding:16px 0}.bracket-round{display:flex;flex-direction:column;min-width:200px;gap:8px}.bracket-round-label{text-align:center;font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:4px}.bracket-matches{display:flex;flex-direction:column;gap:12px;justify-content:space-around;flex:1}.bracket-match{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative}.bracket-match.bracket-decided{opacity:.85}.bracket-slot{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;border-bottom:1px solid var(--border)}.bracket-slot:last-child{border-bottom:none}.bracket-slot.bracket-winner{background:#e639461a;font-weight:700}.bracket-slot.bracket-human{color:var(--green)}.bracket-emoji{font-size:16px;flex-shrink:0}.bracket-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bracket-rating{font-size:11px;color:var(--text-muted);flex-shrink:0}.bracket-score{position:absolute;top:50%;right:-6px;transform:translateY(-50%);font-size:10px;padding:1px 5px;background:var(--bg-body);border:1px solid var(--border);border-radius:4px;color:var(--text-muted)}.tournament-footer{text-align:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.spectate-page{max-width:800px;margin:0 auto;padding:24px 16px}.spectate-header{text-align:center;margin-bottom:24px}.spectate-header h1{margin-bottom:6px}.spectate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.spectate-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px;cursor:pointer;transition:all .2s}.spectate-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.spectate-card-players{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.sp-player{display:flex;align-items:center;gap:8px;font-size:14px}.sp-emoji{font-size:18px}.sp-name{font-weight:600}.sp-rating{font-size:12px;color:var(--text-muted)}.sp-vs{text-align:center;font-size:11px;font-weight:800;color:var(--text-muted);padding:2px 0}.spectate-card-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sp-live-dot{width:8px;height:8px;border-radius:50%;background:#ca3431;animation:livePulse 1.5s ease infinite}.sp-live-text{font-size:11px;font-weight:800;color:#ca3431;letter-spacing:1px}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.4}}.sp-watch-btn{width:100%}.spectate-watching{max-width:900px}.spectate-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.spectate-viewer-count{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.spectate-layout{display:flex;flex-direction:column;align-items:center;gap:12px}.sp-board-player{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:14px;width:100%;max-width:560px}.sp-board-player .sp-emoji{font-size:20px}.sp-board-player .sp-name{font-weight:700}.sp-moves-panel{width:100%;max-width:560px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px 16px}.sp-moves-panel h4{margin:0 0 8px;font-size:14px}.sp-controls{display:flex;gap:6px;padding-top:10px;border-top:1px solid var(--border);margin-top:8px;justify-content:center}.sp-result{text-align:center;padding:14px 0 4px;border-top:1px solid var(--border);margin-top:8px}.sp-result h3{margin:0 0 4px}.sp-status{display:flex;align-items:center;gap:8px;justify-content:center;padding-top:10px;font-size:13px;color:var(--text-muted)}.theme-mini-board{display:grid;grid-template-columns:repeat(4,1fr);width:120px;height:120px;border-radius:8px;overflow:hidden;margin:0 auto 12px;border:2px solid var(--border);transition:transform .2s}.tmb-sq{display:flex;align-items:center;justify-content:center;transition:background .25s ease}.tmb-piece{font-size:18px;opacity:.8}.theme-swatch.previewing{transform:scale(1.08);box-shadow:0 0 0 2px var(--amber)}@media(max-width:640px){.tournament-bracket{flex-direction:column;align-items:stretch}.bracket-round{min-width:unset}.spectate-grid{grid-template-columns:1fr}.toast-container{left:16px;right:16px;max-width:unset}.time-presets{gap:6px}.bf-diff-grid{grid-template-columns:1fr 1fr}.editor-content{flex-direction:column}.editor-board-grid{max-width:100%}.analysis-pgn-btns{flex-wrap:wrap}}.material-bar{margin-top:8px;width:100%}.material-bar-track{height:10px;background:var(--card);border-radius:5px;overflow:hidden;border:1px solid var(--border);position:relative}.material-bar-white{height:100%;background:#f0f0f0;border-radius:5px 0 0 5px;transition:width .4s ease;min-width:2%;max-width:98%}.material-bar-labels{display:flex;justify-content:space-between;align-items:center;font-size:11px;margin-top:4px;color:var(--text-muted)}.material-bar-diff{font-weight:700;font-size:12px}.material-bar-diff.positive{color:#f0f0f0}.material-bar-diff.negative{color:var(--text-muted)}.analysis-pgn-btns{display:flex;gap:6px;margin-left:auto;flex-shrink:0}.analysis-pgn-btns .btn{font-size:12px;padding:4px 8px}.pgn-textarea{width:100%;min-height:120px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:10px;font-family:Courier New,monospace;font-size:12px;resize:vertical;margin:8px 0}.analysis-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.history-card-actions{display:flex;gap:4px;align-items:center}.btn-xs{font-size:11px;padding:2px 6px}.blindfold-page{max-width:1100px;margin:0 auto}.bf-setup{text-align:center;padding:32px 16px;max-width:600px;margin:0 auto}.bf-setup h1{font-size:28px;margin-bottom:8px}.bf-rules{display:flex;gap:16px;justify-content:center;margin:24px 0;flex-wrap:wrap}.bf-rule-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:120px}.bf-rule-icon{font-size:24px}.bf-diff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0 24px}.bf-diff-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;font-size:14px}.bf-diff-emoji{font-size:24px}.bf-playing{display:flex;gap:24px;justify-content:center;padding:16px;flex-wrap:wrap}.bf-playing .gp-board-col{order:-1}.bf-board-container{position:relative}.bf-overlay{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;font-size:64px;background:#1e1c1ad9;border-radius:4px;pointer-events:none}.bf-stats-bar{display:flex;gap:16px;padding:12px;background:var(--card);border-radius:10px;border:1px solid var(--border);margin-bottom:12px}.bf-stat{display:flex;flex-direction:column;align-items:center;flex:1}.bf-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.bf-stat-value{font-size:22px;font-weight:700;color:var(--green)}.bf-peek-btn{width:100%;font-size:16px;padding:12px;margin-bottom:12px}.bf-peek-btn.peeking{background:var(--amber);animation:peek-pulse .5s ease-in-out infinite alternate}@keyframes peek-pulse{0%{opacity:1}to{opacity:.7}}.bf-toggle{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card);border-radius:8px;border:1px solid var(--border);margin-bottom:12px;cursor:pointer;font-size:13px}.bf-toggle input{accent-color:var(--green)}.editor-page{max-width:1100px;margin:0 auto;padding:16px}.editor-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.editor-header h1{font-size:22px;margin:0}.editor-content{display:flex;gap:24px}.editor-board-col{flex-shrink:0}.editor-board-grid{display:flex;flex-direction:column;gap:0;-webkit-user-select:none;user-select:none}.editor-board-row{display:flex;align-items:center}.editor-coord-rank{width:20px;text-align:center;font-size:11px;color:var(--text-muted)}.editor-sq{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:28px;border:none;cursor:pointer;transition:all .15s;padding:0;line-height:1}.editor-sq.light{background:#eeeed2;color:#333}.editor-sq.dark{background:#769656;color:#333}.editor-sq:hover{outline:2px solid var(--amber);outline-offset:-2px;z-index:1}.editor-sq.has-piece{text-shadow:0 1px 2px rgba(0,0,0,.3)}.editor-coord-files{display:flex}.editor-coord-file{width:52px;text-align:center;font-size:11px;color:var(--text-muted)}.editor-fen-display{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:var(--card);border-radius:8px;border:1px solid var(--border)}.editor-fen-text{font-size:11px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.editor-side{flex:1;min-width:240px}.editor-side h3{font-size:14px;margin:0 0 8px;color:var(--text-muted)}.editor-palette{margin-bottom:16px}.editor-palette-grid{display:flex;flex-wrap:wrap;gap:6px}.editor-palette-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:24px;border:2px solid var(--border);border-radius:8px;background:var(--card);cursor:pointer;transition:all .15s}.editor-palette-btn:hover{border-color:var(--amber);transform:scale(1.08)}.editor-palette-btn.active{border-color:var(--green);background:#e6394626;box-shadow:0 0 0 2px var(--green)}.editor-palette-btn.eraser{font-size:18px}.editor-turn{margin-bottom:16px}.editor-turn-btns{display:flex;gap:8px}.editor-fen-input{margin-bottom:16px}.editor-fen-row{display:flex;gap:8px}.editor-fen-field{flex:1;padding:8px 12px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px}.editor-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.editor-start{display:flex;flex-direction:column;gap:8px}.editor-start .btn{width:100%}.eg-page{max-width:960px;margin:0 auto}.eg-header{text-align:center;margin-bottom:32px}.eg-header h1{font-size:28px;margin-bottom:6px}.eg-progress-bar{width:100%;max-width:400px;margin:16px auto 6px;height:10px;background:var(--border);border-radius:6px;overflow:hidden}.eg-progress-fill{height:100%;background:linear-gradient(90deg,#43a047,#66bb6a);border-radius:6px;transition:width .4s ease}.eg-progress-text{font-size:13px;color:var(--text-muted)}.eg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.eg-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;cursor:pointer;text-align:left;color:var(--text);transition:transform .18s,box-shadow .18s,border-color .18s}.eg-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f;border-color:var(--accent)}.eg-card.completed{border-color:#43a047;background:#43a0470f}.eg-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.eg-card-icon{font-size:32px}.eg-diff-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;color:#fff;text-transform:uppercase;letter-spacing:.5px}.eg-card h3{font-size:16px;margin-bottom:4px}.eg-card p{font-size:13px;line-height:1.5}.eg-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:12px}.eg-done-badge{font-size:12px;color:#43a047;font-weight:600}.eg-play{max-width:980px;margin:0 auto}.eg-play-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.eg-play-header h2{flex:1;font-size:20px;margin:0;white-space:nowrap}.eg-pos-counter{font-size:13px;color:var(--text-muted);background:var(--card);padding:4px 14px;border-radius:20px;border:1px solid var(--border)}.eg-play-body{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}.eg-play-board{display:flex;justify-content:center}.eg-play-side{display:flex;flex-direction:column;gap:14px}.eg-stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px}.eg-stat-row{display:flex;justify-content:space-between;padding:4px 0;font-size:14px}.eg-stat-row strong{color:var(--accent)}.eg-tip-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px}.eg-tip-card h4{font-size:14px;margin-bottom:8px}.eg-tip-card p{font-size:13px;color:var(--text-muted);line-height:1.6}.eg-result{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px;border-radius:12px;text-align:center}.eg-result.checkmate{background:#43a0471f;border:1px solid #43a047;color:#43a047}.eg-result.stalemate{background:#f9a8251f;border:1px solid #f9a825;color:#f9a825}.eg-result.draw{background:#9e9e9e1f;border:1px solid #9e9e9e;color:#9e9e9e}.eg-result-icon{font-size:28px}.eg-actions{display:flex;gap:8px}.eg-actions .btn{flex:1}.eg-thinking{text-align:center;font-size:13px;color:var(--text-muted);animation:pulse 1s infinite;margin-top:6px}@media(max-width:780px){.eg-play-body{grid-template-columns:1fr}.eg-play-board{order:-1}.eg-play-side{order:2}}.tc-page{max-width:1040px;margin:0 auto}.tc-header{text-align:center;margin-bottom:16px}.tc-header h1{font-size:28px;margin-bottom:4px}.tc-stat-row{display:flex;justify-content:center;gap:10px;margin-top:10px}.tc-stat-bubble{font-size:13px;background:var(--card);border:1px solid var(--border);padding:4px 16px;border-radius:20px;color:var(--text-muted)}.tc-filters{margin-bottom:20px}.tc-chip-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:10px}.tc-chip{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:13px;cursor:pointer;color:var(--text);display:inline-flex;align-items:center;gap:6px;transition:all .15s}.tc-chip:hover{border-color:var(--accent)}.tc-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tc-chip-count{font-size:11px;opacity:.7}.tc-chip.small{padding:4px 12px;font-size:12px}.tc-body{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}.tc-board-col{display:flex;justify-content:center}.tc-side{display:flex;flex-direction:column;gap:14px}.tc-info-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px}.tc-info-top{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.tc-pill{font-size:12px;padding:3px 10px;border-radius:20px;background:var(--border);color:var(--text);font-weight:600}.tc-pill.solved{background:#43a04726}.tc-info-card h3{font-size:16px;margin-bottom:4px}.tc-side-to-move{font-size:13px;margin-bottom:8px}.tc-theme-badge{display:inline-block;font-size:12px;background:var(--accent);color:#fff;padding:3px 12px;border-radius:20px}.tc-hint-area{min-height:40px}.tc-hint-text{font-size:13px;color:var(--text-muted);background:var(--card);border:1px dashed var(--border);border-radius:10px;padding:12px;line-height:1.5}.tc-feedback{padding:12px;border-radius:10px;text-align:center;font-weight:600;font-size:15px}.tc-feedback.ok{background:#43a0471f;border:1px solid #43a047;color:#43a047}.tc-feedback.bad{background:#e539351f;border:1px solid #e53935;color:#e53935}.tc-progress-section{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px}.tc-progress-section h4{font-size:13px;margin-bottom:10px;color:var(--text-muted)}.tc-progress-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.tc-progress-label{width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tc-progress-bar{flex:1;height:6px;background:var(--border);border-radius:4px;overflow:hidden}.tc-progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .4s ease}.tc-progress-nums{width:30px;text-align:right;color:var(--text-muted)}.tc-nav{display:flex;gap:8px}.tc-nav .btn{flex:1}.tc-empty{text-align:center;padding:40px}@media(max-width:780px){.tc-body{grid-template-columns:1fr}.tc-progress-label{width:80px}}.eval-bar{width:28px;min-width:28px;border-radius:4px;overflow:hidden;display:flex;flex-direction:column;position:relative;border:1px solid #39393680;flex-shrink:0}.eval-bar-section{transition:flex .4s ease}.eval-bar-black{background:#312e2b}.eval-bar-white{background:#e8e6e1}.eval-bar-score{position:absolute;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;line-height:1;pointer-events:none;text-shadow:0 0 3px rgba(0,0,0,.5)}.eval-bar-score.top{top:4px;color:#a0a0a0}.eval-bar-score.bottom{bottom:4px;color:#555}.coach-board-with-eval{display:flex;gap:4px;align-items:stretch}.coach-board-with-eval .eval-bar{align-self:stretch}.coach-game-actions{display:flex;gap:6px;padding:6px 10px}.coach-action-btn{flex:1;padding:6px 0;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.coach-action-btn.hint{background:#3b82f6;color:#fff}.coach-action-btn.hint:hover:not(:disabled){background:#2563eb}.coach-action-btn.takeback{background:#6b7280;color:#fff}.coach-action-btn.takeback:hover:not(:disabled){background:#4b5563}.coach-action-btn:disabled{opacity:.4;cursor:not-allowed}.coach-move-btn.q-brilliant{border-left:3px solid #1bada6}.coach-move-btn.q-great{border-left:3px solid #97af2f}.coach-move-btn.q-good{border-left:3px solid #6bab56}.coach-move-btn.q-inaccuracy{border-left:3px solid #e6a629}.coach-move-btn.q-mistake{border-left:3px solid #e08726}.coach-move-btn.q-blunder{border-left:3px solid #ca3431}.coach-theme-section{margin:12px 0 4px}.coach-theme-label{display:block;font-size:13px;color:#9e9b98;margin-bottom:6px;text-align:center}.coach-theme-options{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.coach-theme-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid #484542;border-radius:6px;background:#2b2926;color:#c0bdb9;cursor:pointer;font-size:12px;transition:all .15s}.coach-theme-btn:hover{border-color:#81b64c;color:#fff}.coach-theme-btn.selected{border-color:#81b64c;background:#81b64c22;color:#81b64c}.coach-quick-links{display:flex;gap:8px;margin-top:10px;justify-content:center}.coach-quick-link{padding:7px 16px;border:1px solid #484542;border-radius:6px;background:transparent;color:#c0bdb9;cursor:pointer;font-size:13px;transition:all .15s}.coach-quick-link:hover{border-color:#81b64c;color:#81b64c}.coach-question-modal{background:#1e1c19;border:1px solid #484542;border-radius:8px;padding:12px;margin:6px 10px;position:relative}.coach-question-text{color:#e8e6e1;font-size:13px;margin:0 0 8px}.coach-question-reveal{padding:5px 14px;border:none;border-radius:4px;background:#81b64c;color:#fff;cursor:pointer;font-size:12px;font-weight:600}.coach-question-reveal:hover{background:#6fa33e}.coach-question-dismiss{position:absolute;top:6px;right:8px;background:none;border:none;color:#666;cursor:pointer;font-size:14px}.coach-diff-suggestion{background:#312e2b;border:1px solid #484542;border-radius:6px;padding:8px 12px;margin-bottom:8px;color:#e6a629;font-size:13px;text-align:center}.coach-report-card{background:#1e1c19;border:1px solid #484542;border-radius:10px;padding:16px;margin-bottom:10px}.report-header{text-align:center;font-size:15px;font-weight:700;color:#e8e6e1;margin-bottom:14px}.report-accuracy-section{display:flex;justify-content:center;margin-bottom:14px}.report-accuracy-ring{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff}.report-accuracy-label{text-align:center;font-size:12px;color:#9e9b98;margin-top:4px}.report-quality-bars{display:flex;flex-direction:column;gap:4px}.report-quality-row{display:flex;align-items:center;gap:6px;font-size:12px}.report-quality-icon{width:16px;text-align:center}.report-quality-label{width:70px;color:#c0bdb9}.report-quality-bar{flex:1;height:10px;background:#312e2b;border-radius:3px;overflow:hidden}.report-quality-fill{height:100%;border-radius:3px;transition:width .5s ease}.report-quality-count{width:20px;text-align:right;color:#9e9b98;font-weight:600}.report-move-highlights{display:flex;gap:6px;margin-top:10px}.report-move-btn{flex:1;padding:5px 0;border:1px solid #484542;border-radius:4px;background:#2b2926;color:#c0bdb9;cursor:pointer;font-size:11px;text-align:center}.report-move-btn:hover{border-color:#81b64c;color:#fff}.coach-lessons-page{max-width:900px;margin:0 auto;padding:20px}.coach-lessons-page h1{color:#e8e6e1;font-size:22px;margin-bottom:16px}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.lesson-card{background:#262522;border:1px solid #3a3835;border-radius:10px;padding:16px;cursor:pointer;transition:border-color .15s,transform .15s}.lesson-card:hover{border-color:#81b64c;transform:translateY(-2px)}.lesson-card-icon{font-size:28px;margin-bottom:6px}.lesson-card-title{font-size:15px;font-weight:700;color:#e8e6e1;margin-bottom:4px}.lesson-card-desc{font-size:12px;color:#9e9b98;margin-bottom:8px}.lesson-card-meta{display:flex;gap:8px;align-items:center}.lesson-diff-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#fff}.lesson-diff-badge.beginner{background:#6bab56}.lesson-diff-badge.intermediate{background:#e6a629}.lesson-diff-badge.advanced{background:#ca3431}.lesson-complete-badge{color:#81b64c;font-size:13px}.lesson-play-layout{display:flex;gap:16px;align-items:flex-start}.lesson-board-col{flex-shrink:0}.lesson-side-panel{flex:1;background:#262522;border-radius:10px;padding:16px;min-width:240px}.lesson-step-info{font-size:13px;color:#9e9b98;margin-bottom:6px}.lesson-instruction{font-size:15px;color:#e8e6e1;line-height:1.5;margin-bottom:12px}.lesson-feedback{padding:8px 12px;border-radius:6px;font-size:13px;font-weight:600;margin-bottom:10px}.lesson-feedback.correct{background:#81b64c22;color:#81b64c}.lesson-feedback.wrong{background:#ca343122;color:#ca3431}.lesson-btn-row{display:flex;gap:8px}.lesson-hint-btn,.lesson-next-btn,.lesson-back-btn{padding:7px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600}.lesson-hint-btn{background:#3b82f6;color:#fff}.lesson-next-btn{background:#81b64c;color:#fff}.lesson-back-btn{background:#484542;color:#c0bdb9}@media(max-width:700px){.lesson-play-layout{flex-direction:column}}.coach-progress-page{max-width:700px;margin:0 auto;padding:20px}.coach-progress-page h1{color:#e8e6e1;font-size:22px;margin-bottom:16px}.progress-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:20px}.progress-card{background:#262522;border:1px solid #3a3835;border-radius:10px;padding:14px;text-align:center}.progress-card-value{font-size:24px;font-weight:800;color:#81b64c}.progress-card-label{font-size:12px;color:#9e9b98;margin-top:2px}.progress-section-title{color:#e8e6e1;font-size:15px;font-weight:700;margin-bottom:10px}.progress-chart{display:flex;align-items:flex-end;gap:8px;height:120px;margin-bottom:20px;padding:0 4px}.progress-chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.progress-chart-bar{width:100%;max-width:36px;background:#81b64c;border-radius:3px 3px 0 0;min-height:2px;transition:height .4s ease}.progress-chart-label{font-size:10px;color:#9e9b98;margin-top:4px}.progress-breakdown{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.progress-breakdown-row{display:flex;align-items:center;gap:8px;font-size:13px}.progress-breakdown-label{width:60px;color:#c0bdb9}.progress-breakdown-bar{flex:1;height:14px;background:#312e2b;border-radius:4px;overflow:hidden}.progress-breakdown-fill{height:100%;border-radius:4px}.progress-breakdown-fill.wins{background:#81b64c}.progress-breakdown-fill.losses{background:#ca3431}.progress-breakdown-fill.draws{background:#e6a629}.progress-breakdown-count{width:24px;text-align:right;color:#9e9b98;font-weight:600}.progress-insight{background:#262522;border:1px solid #3a3835;border-radius:10px;padding:14px;margin-bottom:16px;font-size:13px;color:#e6a629;text-align:center}.progress-actions{display:flex;gap:8px;flex-wrap:wrap}.progress-action-btn{flex:1;min-width:100px;padding:10px 0;border:1px solid #484542;border-radius:8px;background:#2b2926;color:#c0bdb9;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s;text-align:center}.progress-action-btn:hover{border-color:#81b64c;color:#81b64c}
