:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#e0e0e0;min-height:100vh}.app{max-width:560px;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:20px;transition:max-width .3s}.app-wide{max-width:1200px}.title{font-size:28px;font-weight:700;color:#fff;letter-spacing:1px}.loading{color:#888;font-size:16px;padding:40px 0}.game-area{display:flex;flex-direction:column;align-items:center;gap:16px}.game-area-split{flex-direction:row;align-items:flex-start;gap:28px}.left-col{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.board-col{display:flex;flex-direction:column;align-items:center;gap:16px;flex-shrink:0;width:480px}.right-col{flex:1;min-width:280px;max-width:380px;display:flex;flex-direction:column;gap:16px}.board-container{border-radius:4px;overflow:hidden;box-shadow:0 4px 20px #0006}.board-wrapper{position:relative}.promotion-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10}.promotion-dialog{display:flex;gap:4px;background:#1a1a2e;border:1px solid #3a3a5a;border-radius:8px;padding:8px}.promotion-piece{width:56px;height:56px;font-size:36px;line-height:1;display:flex;align-items:center;justify-content:center;background:#16213e;border:1px solid #3a3a5a;border-radius:6px;cursor:pointer;transition:background .15s}.promotion-piece:hover{background:#253050;border-color:#5c6bc0}.turn-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 0;font-size:15px;font-weight:600;border-radius:0 0 4px 4px;background:#16213e}.turn-dot{width:14px;height:14px;border-radius:50%;border:1px solid #555}.turn-indicator.white .turn-dot{background:#fff}.turn-indicator.black .turn-dot{background:#222}.board-controls{display:flex;gap:10px;padding:8px 0 0}.difficulty-slider{width:100%;max-width:400px;text-align:center}.difficulty-label{font-size:15px;color:#ccc}.difficulty-value{font-weight:700;color:#fff;font-size:18px}.difficulty-range{color:#888}.slider-row{display:flex;align-items:center;gap:10px;margin-top:6px}.slider-end{font-size:13px;color:#666;min-width:16px;text-align:center}.slider-input{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:#2a2a4a;outline:none;cursor:pointer}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#5c6bc0;border:2px solid #7986cb;cursor:pointer}.slider-input::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#5c6bc0;border:2px solid #7986cb;cursor:pointer}.scoreboard{display:flex;align-items:center;gap:16px;padding:10px 20px;background:#16213e;border-radius:8px;font-size:16px}.score-correct{color:#4caf50;font-weight:600}.score-incorrect{color:#f44336;font-weight:600}.score-accuracy{color:#aaa}.elo-ratings{font-size:13px;color:#7986cb;font-weight:500}.elo-change-display{text-align:center;font-size:14px;color:#ccc}.elo-label{color:#aaa}.elo-delta{font-weight:600}.elo-positive{color:#4caf50}.elo-negative{color:#f44336}.elo-position{font-size:13px;color:#888;margin-top:2px}.guess-controls{text-align:center;background:#16213e;border-radius:8px;padding:24px 20px}.guess-question{font-size:18px;margin-bottom:12px;color:#ccc}.guess-buttons{display:flex;gap:16px;justify-content:center}.results-panel{background:#16213e;border-radius:8px;padding:20px;min-width:300px;max-width:380px;display:flex;flex-direction:column;gap:16px}.verdict{font-size:24px;font-weight:700;text-align:center}.verdict.correct{color:#4caf50}.verdict.incorrect{color:#f44336}.verdict-detail{text-align:center;color:#aaa;font-size:14px}.results-section{border-top:1px solid #253050;padding-top:12px}.results-heading{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#7986cb;margin-bottom:8px}.tactic-tags{display:flex;flex-wrap:wrap;gap:6px}.tactic-tag{background:#1a237e;color:#9fa8da;padding:3px 10px;border-radius:12px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:4px}.puzzle-rating{font-size:13px;color:#aaa;margin-top:6px}.puzzle-rating strong{color:#e0e0e0}.motif-vote{background:none;border:none;cursor:pointer;font-size:10px;line-height:1;padding:0 2px;color:#666;transition:color .15s;vertical-align:middle}.motif-vote:hover{color:#aaa}.motif-vote-up.active{color:#4caf50}.motif-vote-down.active{color:#f44336}.position-vote{display:flex;gap:16px;justify-content:center}.vote-btn{width:64px;height:64px;font-size:32px;line-height:1;display:flex;align-items:center;justify-content:center;background:#1a1a2e;border:2px solid #3a3a5a;border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s}.vote-btn:hover{background:#253050;border-color:#5c6bc0}.vote-up.active{background:#4caf5026;border-color:#4caf50}.vote-down.active{background:#f4433626;border-color:#f44336}.analysis-result{display:flex;flex-direction:column;gap:6px}.eval-display{display:flex;align-items:baseline;gap:10px}.eval-score{font-size:22px;font-weight:700;font-family:Courier New,monospace}.eval-score.white-adv{color:#e0e0e0}.eval-score.black-adv{color:#888}.eval-depth{font-size:12px;color:#666}.best-line{font-size:13px;color:#aaa;font-family:Courier New,monospace;word-break:break-word}.analysis-error{color:#f44336;font-size:13px}.btn{padding:10px 28px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 16px;font-size:13px}.btn-yes{background:#4caf50;color:#fff}.btn-no{background:#f44336;color:#fff}.btn-next{background:#2196f3;color:#fff}.btn-analyze{background:#5c6bc0;color:#fff;width:100%}.btn-board{background:#2a2a4a;color:#aaa;border:1px solid #3a3a5a}.btn-reset{background:transparent;color:#888;font-size:13px;padding:4px 12px;border:1px solid #444}.move-history-panel{width:100%;background:#16213e;border-radius:8px;overflow:hidden}.move-history-header{padding:8px 12px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#7986cb;border-bottom:1px solid #253050}.move-history{width:100%;min-height:48px;max-height:400px;overflow-y:auto;padding:8px 12px;font-family:Courier New,monospace;font-size:14px;display:flex;flex-direction:column;gap:2px}.move-history-empty{color:#555;font-size:13px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:4px 0}.move-pair{display:flex;gap:6px;white-space:nowrap}.move-number{color:#666;min-width:28px;text-align:right}.move-san{color:#ccc;padding:1px 4px;border-radius:3px;min-width:48px}.move-san.move-current{background:#ff03;color:#fff;font-weight:600}.move-san.move-future,.move-san.move-placeholder{color:#555}.top-bar{width:100%;display:flex;align-items:center;justify-content:space-between}.auth-area{display:flex;align-items:center;gap:10px}.auth-username{color:#7986cb;font-weight:600;font-size:14px}.auth-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.auth-modal{background:#16213e;border:1px solid #3a3a5a;border-radius:12px;padding:28px 32px;min-width:300px;display:flex;flex-direction:column;gap:16px}.auth-modal h2{text-align:center;color:#fff;font-size:20px}.auth-modal form{display:flex;flex-direction:column;gap:10px}.auth-input{padding:10px 14px;border:1px solid #3a3a5a;border-radius:6px;background:#1a1a2e;color:#e0e0e0;font-size:15px;outline:none}.auth-input:focus{border-color:#5c6bc0}.auth-submit{margin-top:4px}.auth-error{color:#f44336;font-size:13px;text-align:center}.auth-switch{text-align:center;color:#888;font-size:13px}.auth-link{background:none;border:none;color:#7986cb;cursor:pointer;font-size:13px;text-decoration:underline}.auth-success{color:#4caf50;font-size:13px;text-align:center}.auth-divider{text-align:center;margin:12px 0;color:#666;font-size:12px;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#444}.auth-divider:before{left:0}.auth-divider:after{right:0}.btn-lichess{background:#629924!important;color:#fff!important;border:none;font-weight:600}.btn-lichess:hover{background:#4e7a1c!important}.email-verify-banner{background:#332a00;color:#ffd54f;text-align:center;padding:8px 16px;font-size:13px;border-radius:4px;margin-bottom:8px}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center;gap:16px;padding:40px 20px}.landing-title{font-size:48px;font-weight:800;color:#fff;letter-spacing:2px}.landing-subtitle{font-size:20px;color:#7986cb;font-weight:500;margin-top:-8px}.landing-description{font-size:16px;color:#aaa;max-width:460px;line-height:1.6}.btn-cta{background:#5c6bc0;color:#fff;padding:14px 40px;font-size:18px;border-radius:8px;margin-top:12px}.tutorial-intro{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:40px 20px;min-height:50vh}.tutorial-intro-title{font-size:32px;font-weight:700;color:#fff}.tutorial-intro-text{font-size:16px;color:#bbb;max-width:520px;line-height:1.6}.tutorial-intro-buttons{display:flex;gap:16px;margin-top:12px}.tutorial-layout{display:flex;gap:28px;align-items:flex-start;width:100%}.tutorial-board-col{flex-shrink:0;width:480px}.tutorial-right-col{flex:1;display:flex;flex-direction:column;gap:16px;min-width:280px;max-width:400px}.tutorial-guess-controls,.tutorial-feedback-controls{text-align:center}.tutorial-skip-btn{align-self:center;margin-top:4px}.tutorial-chat{background:#16213e;border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.tutorial-chat-header{padding:10px 16px;font-size:14px;font-weight:600;color:#7986cb;border-bottom:1px solid #253050}.tutorial-progress-bar{height:4px;background:#253050;border-radius:2px;margin-top:6px;overflow:hidden}.tutorial-progress-fill{height:100%;background:#5c6bc0;border-radius:2px;transition:width .3s}.tutorial-chat-messages{padding:12px 16px;display:flex;flex-direction:column;gap:10px;max-height:340px;overflow-y:auto}.tutorial-msg{padding:10px 14px;border-radius:8px;font-size:14px;line-height:1.5}.tutorial-msg-system{background:#1a1a2e;color:#aaa;border:1px solid #2a2a4a}.tutorial-msg-user{background:#253050;color:#e0e0e0;align-self:flex-end;max-width:80%}.tutorial-msg-explanation{background:#1a237e;color:#c5cae9;border-left:3px solid #5c6bc0}.auth-username-link{background:none;border:none;cursor:pointer;text-decoration:none;transition:color .15s}.auth-username-link:hover{color:#9fa8da;text-decoration:underline}.profile-page{width:100%;max-width:700px;display:flex;flex-direction:column;gap:20px}.profile-header{display:flex;align-items:center;justify-content:space-between}.profile-username{font-size:24px;font-weight:700;color:#fff}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.profile-stat{background:#16213e;border-radius:8px;padding:14px 12px;text-align:center;display:flex;flex-direction:column;gap:4px}.profile-stat-large{grid-column:span 2}.profile-stat-value{font-size:22px;font-weight:700;color:#e0e0e0}.profile-stat-large .profile-stat-value{font-size:32px}.profile-stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#888}.profile-section{display:flex;flex-direction:column;gap:10px}.profile-section-title{font-size:16px;font-weight:600;color:#7986cb;text-transform:uppercase;letter-spacing:1px}.elo-chart{background:#16213e;border-radius:8px;padding:16px}.elo-chart-svg{width:100%;height:auto}.elo-chart-empty{background:#16213e;border-radius:8px;padding:32px;text-align:center;color:#666;font-size:14px}.elo-chart-legend{display:flex;gap:20px;justify-content:center;margin-bottom:8px;font-size:13px;color:#aaa}.legend-item{display:flex;align-items:center;gap:6px}.legend-line{display:inline-block;width:20px;height:3px;border-radius:2px}.legend-vision{background:#5c6bc0}.legend-puzzle{background:#ab47bc}.profile-history{background:#16213e;border-radius:8px;overflow:hidden}.profile-history-table{width:100%;border-collapse:collapse;font-size:14px}.profile-history-table th{text-align:left;padding:10px 14px;color:#7986cb;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #253050;font-weight:600}.profile-history-table td{padding:8px 14px;border-bottom:1px solid #1a1a2e;color:#ccc}.profile-history-table tr:last-child td{border-bottom:none}.profile-history-pos{font-family:Courier New,monospace;font-size:13px;color:#888}.puzzle-panel{background:#16213e;border-radius:8px;padding:20px;min-width:300px;max-width:380px;display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center}.puzzle-instruction{font-size:22px;font-weight:700;color:#fff}.puzzle-progress{font-size:15px;color:#7986cb;font-weight:500}.puzzle-status-correct{color:#4caf50;font-weight:600;font-size:16px}.puzzle-status-retry{color:#ff9800;font-weight:600;font-size:16px}.puzzle-status-failed{color:#f44336;font-weight:600;font-size:16px}.puzzle-banner{font-size:24px;font-weight:700}.puzzle-replay-status{font-size:15px;color:#7986cb;font-weight:500;margin-top:4px}.btn-giveup{background:transparent;color:#888;font-size:13px;padding:8px 20px;border:1px solid #444;border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s;margin-top:8px}.btn-giveup:hover{color:#ccc;border-color:#666}.solution-replay-indicator{color:#7986cb;font-size:14px;font-weight:500;text-align:center;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.analysis-panel{background:#16213e;border-radius:8px;padding:16px;width:100%;display:flex;flex-direction:column;gap:12px}.analysis-panel-header{display:flex;align-items:center;justify-content:space-between}.btn-analysis-start{background:#4caf50;color:#fff}.btn-analysis-stop{background:#f44336;color:#fff}.eval-bar{position:relative;height:24px;background:#333;border-radius:4px;overflow:hidden}.eval-bar-fill{height:100%;background:#e0e0e0;border-radius:4px 0 0 4px;transition:width .3s ease}.eval-bar-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:Courier New,monospace;color:#1a1a2e;mix-blend-mode:difference}.analysis-depth{display:flex;align-items:center;gap:8px;font-size:13px;color:#aaa}.analysis-depth-spinner{width:12px;height:12px;border:2px solid #3a3a5a;border-top-color:#5c6bc0;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.analysis-mpv-selector{display:flex;gap:4px}.btn-mpv{background:#1a1a2e;color:#888;border:1px solid #3a3a5a;padding:3px 10px;font-size:12px}.btn-mpv-active{background:#1a237e;color:#9fa8da;border-color:#3949ab}.analysis-lines{display:flex;flex-direction:column;gap:4px}.analysis-line{display:flex;align-items:baseline;gap:8px;padding:4px 8px;border-radius:4px;background:#1a1a2e;font-size:13px}.analysis-line-top{background:#1a237e}.analysis-line-eval{font-weight:700;font-family:Courier New,monospace;min-width:48px;text-align:right}.analysis-line-moves{color:#aaa;font-family:Courier New,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analysis-line-empty{color:#666;justify-content:center;padding:12px}.analysis-stats{display:flex;justify-content:space-between;font-size:11px;color:#666;padding-top:4px;border-top:1px solid #253050}.analysis-toggle{transition:background .15s}.analysis-toggle-active{background:#3949ab}.practice-mode-banner{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 20px;background:#332a00;color:#ffd54f;border-radius:6px;font-size:14px;font-weight:500}.profile-history-pos-link{background:none;border:none;cursor:pointer;font-family:Courier New,monospace;font-size:13px;color:#7986cb;padding:0;transition:color .15s}.profile-history-pos-link:hover{color:#9fa8da;text-decoration:underline}
