@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--primary:#4f46e5;--primary-hover:#4338ca;--accent:#ea580c;--bg:#0f172a;--bg-secondary:#1e293b;--surface:#1e293b;--surface-hover:#334155;--surface-border:#ffffff14;--overlay:#0f172aeb;--text:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--light-square:#f0d9b5;--dark-square:#b58863;--selected-square:#7fc47f;--last-move-square:#9bc7004d;--legal-dot:#0000002e;--legal-capture-border:#00000040;--radius:10px;--radius-sm:6px;--shadow-lg:0 8px 30px #0000004d;--font-heading:"Space Grotesk", sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}::selection{color:var(--text);background:#4f46e54d}.hidden{display:none!important}.back-home-btn{border:1px solid var(--surface-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;align-items:center;gap:4px;margin-bottom:8px;padding:6px 14px;font-size:.82rem;transition:all .15s;display:inline-flex}.back-home-btn:hover{background:var(--surface-hover);color:var(--text);border-color:#ffffff26}.back-home-btn:active{transform:scale(.97)}#app{max-width:1280px;margin:0 auto;padding:0 20px}.app-header{text-align:center;padding:24px 0 16px}.app-header h1{font-family:var(--font-heading);letter-spacing:-.03em;background:linear-gradient(135deg,#fff 0%,#94a3b8 100%);-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:2px;font-size:1.6rem;font-weight:700}.app-header .subtitle{color:var(--text-muted);letter-spacing:.05em;font-size:.78rem}.welcome-container{flex-direction:column;align-items:center;max-width:520px;margin:0 auto;padding:40px 20px 60px;display:flex}.welcome-hero{text-align:center;margin-bottom:40px}.welcome-icon{margin-bottom:20px}.welcome-title{font-family:var(--font-heading);letter-spacing:-.03em;margin-bottom:10px;font-size:2rem;font-weight:700}.welcome-desc{color:var(--text-secondary);max-width:380px;margin:0 auto;font-size:.95rem;line-height:1.6}.welcome-cards{flex-direction:column;gap:12px;width:100%;display:flex}.welcome-card{background:var(--surface);border:1px solid var(--surface-border);cursor:pointer;border-radius:14px;align-items:center;gap:16px;padding:20px;transition:all .2s;display:flex}.welcome-card:hover{background:var(--surface-hover);border-color:#ffffff26;transform:translateY(-1px)}.welcome-card:active{transform:scale(.98)}.welcome-card-icon{text-align:center;flex-shrink:0;width:48px;font-size:2rem}.welcome-card-body{flex:1;min-width:0}.welcome-card-body h3{font-family:var(--font-heading);margin-bottom:4px;font-size:1.05rem;font-weight:600}.welcome-card-body p{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.welcome-card-arrow{color:var(--text-muted);flex-shrink:0;font-size:1.2rem;transition:transform .2s}.welcome-card:hover .welcome-card-arrow{color:var(--text);transform:translate(4px)}.welcome-footer{color:var(--text-muted);margin-top:28px;font-size:.75rem}.tutorial-container{align-items:flex-start;gap:24px;min-height:400px;display:flex}.tutorial-nav{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius);flex:0 0 160px;padding:16px 0;position:sticky;top:16px}.tutorial-nav-title{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--surface-border);margin-bottom:4px;padding:0 16px 12px;font-size:.7rem;font-weight:600}.tutorial-nav-list{padding:4px 0;list-style:none}.tutorial-nav-item{color:var(--text-secondary);cursor:pointer;border-left:3px solid #0000;padding:10px 16px;font-size:.88rem;transition:all .15s}.tutorial-nav-item:hover{color:var(--text);background:#ffffff08}.tutorial-nav-item.active{color:var(--text);border-left-color:var(--primary);background:#4f46e51a;font-weight:600}.tutorial-main{flex:1;gap:24px;min-width:0;display:flex}.tutorial-content{flex:1;min-width:0}.tutorial-chapter{display:none}.tutorial-chapter.active{display:block}.tutorial-chapter h2{font-family:var(--font-heading);letter-spacing:-.02em;margin-bottom:4px;font-size:1.5rem;font-weight:700}.tutorial-meta{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem}.tutorial-body{color:var(--text);font-size:.92rem;line-height:1.7}.tutorial-body p{margin-bottom:12px}.tutorial-body h3{font-family:var(--font-heading);margin:20px 0 8px;font-size:1.05rem;font-weight:600}.tutorial-body ul,.tutorial-body ol{margin-bottom:12px;padding-left:20px}.tutorial-body li{margin-bottom:4px}.tutorial-body hr{border:none;border-top:1px solid var(--surface-border);margin:20px 0}.tut-show-btn{color:var(--primary);background:#4f46e514;border-color:#4f46e540;margin:6px 0 12px;font-size:.78rem;transition:all .15s}.tut-show-btn:hover{border-color:var(--primary);background:#4f46e52e}.tutorial-board-panel{flex:0 0 280px;align-self:flex-start;position:sticky;top:16px}.tutorial-board-header{justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 2px;display:flex}.tutorial-board-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.7rem;font-weight:600}.tutorial-demo-name{color:var(--primary);font-size:.75rem;font-weight:500}#tutorial-board{width:280px;height:280px;box-shadow:var(--shadow-lg);border-radius:4px;position:relative;overflow:hidden}.tutorial-board-controls{justify-content:center;align-items:center;gap:10px;margin-top:10px;padding:0 4px;display:flex}.tut-step-counter{font-size:.78rem;font-family:var(--font-mono);color:var(--text-secondary);text-align:center;min-width:50px}.tut-control-hint{color:var(--text-muted);margin-left:auto;font-size:.7rem;font-style:italic}.demo-tag{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-secondary);border-radius:4px;margin-left:6px;padding:2px 8px;font-size:.75rem;font-weight:400;display:inline-block}.placeholder-view{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.placeholder-icon{margin-bottom:20px;font-size:4rem}.placeholder-title{font-family:var(--font-heading);letter-spacing:-.02em;margin-bottom:10px;font-size:1.5rem;font-weight:700}.placeholder-desc{color:var(--text-secondary);margin-bottom:28px;font-size:.95rem}.view{display:none}.view.active{display:block}.game-layout{justify-content:center;align-items:flex-start;gap:24px;display:flex}.board-section{flex:none}#chess-board,#analysis-board{width:560px;height:560px;box-shadow:var(--shadow-lg);border-radius:4px;position:relative;overflow:hidden}#eval-bar-container{width:560px;margin-top:8px;padding:0}#eval-bar-track{background:var(--dark-square);border-radius:4px;width:100%;height:24px;position:relative;overflow:hidden}#eval-bar-fill{background:var(--light-square);width:50%;height:100%;transition:width .3s}#eval-bar-label{font-family:var(--font-mono);color:#000;text-shadow:0 0 4px #fff9;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;line-height:24px;display:flex;position:absolute;inset:0}.board-container{grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:100%;height:100%;display:grid}.square{cursor:pointer;user-select:none;justify-content:center;align-items:center;display:flex;position:relative}.square.light{background:var(--light-square)}.square.dark{background:var(--dark-square)}.square.last-move{background:var(--last-move-square)!important}.square.selected{background:var(--selected-square)!important}.square.legal-move:after{content:"";background:var(--legal-dot);pointer-events:none;border-radius:50%;width:28%;height:28%;position:absolute}.piece-img{object-fit:contain;pointer-events:none;cursor:pointer;width:82%;height:82%;display:block}.coord{color:#00000059;pointer-events:none;font-size:11px;font-weight:600;line-height:1;position:absolute}.coord-rank{top:2px;left:3px}.coord-file{bottom:2px;right:3px}.side-panel{flex:1;min-width:290px;max-width:340px}.panel-section{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius);margin-bottom:10px;padding:16px}.panel-section h3{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:.68rem;font-weight:600}.btn{border:1px solid var(--surface-border);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-body);background:var(--surface);color:var(--text);justify-content:center;align-items:center;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{background:var(--surface-hover);border-color:#ffffff26}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger{color:var(--danger);background:0 0;border-color:#ef44444d}.btn-danger:hover{border-color:var(--danger);background:#ef44441a}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000;font-size:.8rem}.btn-ghost:hover{color:var(--text-secondary);background:#ffffff0a}.btn-full{width:100%}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-group{gap:4px;display:flex}.btn-group .btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.difficulty-selector{margin-bottom:12px}.difficulty-selector label,.color-selector label{color:var(--text-secondary);margin-bottom:6px;font-size:.73rem;font-weight:500;display:block}.difficulty-slider-container{align-items:center;gap:10px;display:flex}.difficulty-slider-container input[type=range]{appearance:none;background:var(--surface-hover);border-radius:2px;outline:none;flex:1;height:4px}.difficulty-slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border:2px solid var(--bg);width:16px;height:16px;box-shadow:0 0 0 1px var(--surface-border);border-radius:50%}.difficulty-slider-container input[type=range]::-moz-range-thumb{background:var(--primary);cursor:pointer;border:2px solid var(--bg);border-radius:50%;width:16px;height:16px}.color-selector{margin-bottom:12px}.badge{font-family:var(--font-heading);border-radius:20px;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-level{background:var(--primary);color:#fff}.game-actions{gap:6px;margin-bottom:8px;display:flex}.game-actions .btn{flex:1}.game-info-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.game-turn-indicator{color:var(--text-secondary);font-size:.8rem;font-weight:500}.move-list{max-height:260px;font-family:var(--font-mono);font-size:.8rem;line-height:1.8;overflow-y:auto}.move-list::-webkit-scrollbar{width:4px}.move-list::-webkit-scrollbar-track{background:0 0}.move-list::-webkit-scrollbar-thumb{background:var(--surface-hover);border-radius:2px}.move-entry{border-radius:4px;padding:1px 6px;display:flex}.move-entry:hover{background:#ffffff0a}.move-number{width:28px;color:var(--text-muted);text-align:right;flex-shrink:0;margin-right:8px}.move-white,.move-black{cursor:pointer;border-radius:3px;width:70px;padding:0 4px}.move-white:hover,.move-black:hover{background:#ffffff0f}.move-eval{color:var(--text-muted);text-align:left;min-width:36px;margin-left:4px;font-size:.7rem}.analysis-best-line{background:var(--bg-secondary);border-radius:var(--radius-sm);margin-bottom:8px;padding:8px;font-size:.8rem;line-height:1.6}.eval-best-label{color:var(--success);font-weight:600}.eval-mono{font-family:var(--font-mono);font-size:.78rem}.eval-score{color:var(--text-secondary);font-family:var(--font-mono);margin-left:6px}.eval-depth{color:var(--text-muted);margin-left:6px;font-size:.7rem}.eval-pending{color:var(--text-muted);font-style:italic}.analysis-multi-pv{margin-bottom:4px}.pv-row{border-radius:3px;align-items:center;gap:6px;padding:3px 6px;font-size:.75rem;display:flex}.pv-row:hover{background:#ffffff0a}.pv-rank{color:var(--text-muted);min-width:14px;font-size:.7rem}.pv-score{color:var(--text-secondary);font-family:var(--font-mono)}.eval-loss{color:var(--danger);margin-left:auto;font-size:.7rem}.analysis-blink{min-height:1.2em;margin-top:4px;font-size:.75rem}.game-status{text-align:center;font-family:var(--font-heading);letter-spacing:-.01em;font-size:.95rem;font-weight:600}.game-status .win{color:var(--success)}.game-status .lose{color:var(--danger)}.game-status .draw{color:var(--warning)}.nav-controls{justify-content:center;align-items:center;gap:8px;display:flex}.nav-controls .btn{border-radius:var(--radius-sm);width:36px;height:36px;padding:0;font-size:.9rem}#move-counter{font-size:.8rem;font-family:var(--font-mono);color:var(--text-secondary);text-align:center;min-width:70px}.engine-output{font-size:.8rem;font-family:var(--font-mono);margin-top:12px;line-height:1.6}.eval-bar{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;font-size:.85rem;font-weight:600;display:flex}.eval-positive{color:var(--success)}.eval-negative{color:var(--danger)}.eval-best{color:var(--success)}.eval-mistake{color:var(--danger)}#pgn-input{resize:vertical;border:1px solid var(--surface-border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);font-family:var(--font-mono);outline:none;margin-bottom:10px;padding:10px;font-size:.78rem;line-height:1.5;transition:border-color .15s}#pgn-input:focus{border-color:var(--primary)}#pgn-input::placeholder{color:var(--text-muted)}.loading-overlay{background:var(--overlay);z-index:1000;-webkit-backdrop-filter:blur(8px);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-overlay.hidden{display:none}.loading-spinner{border:3px solid #ffffff1a;border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;margin-bottom:14px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay p{font-family:var(--font-body);color:var(--text-secondary);font-size:.9rem}@media (width<=960px){.game-layout{flex-direction:column;align-items:center}#chess-board,#analysis-board{aspect-ratio:1;width:100%;max-width:480px;height:auto}#eval-bar-container{width:100%;max-width:480px}.side-panel{width:100%;max-width:100%}.app-header h1{font-size:1.4rem}.tutorial-container{flex-direction:column}.tutorial-nav{flex:none;width:100%;position:static}.tutorial-nav-list{flex-wrap:wrap;display:flex}.tutorial-nav-item{text-align:center;border-bottom:3px solid #0000;border-left:none;flex:1;min-width:80px}.tutorial-nav-item.active{border-left-color:#0000;border-bottom-color:var(--primary)}.tutorial-main{flex-direction:column}.tutorial-board-panel{flex:none;width:100%;max-width:340px;margin:0 auto;position:static}#tutorial-board{aspect-ratio:1;width:100%;height:auto}}@media (width<=500px){#app{padding:0 12px}#chess-board,#analysis-board{max-width:100%}.panel-section{padding:12px}.coord{font-size:9px}.piece-img{width:78%;height:78%}}
