*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh}.app{max-width:800px;margin:0 auto;padding:3rem 1rem 0}.top-bar{position:fixed;top:0;left:0;right:0;height:2.5rem;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;background:#0f1923;border-bottom:1px solid #1e2d3d;z-index:200}.top-bar-logo{display:flex;align-items:center;gap:.4rem;font-size:1rem;font-weight:700;color:#d8dce2;text-decoration:none}.top-bar-right{display:flex;align-items:center;gap:.75rem}.top-bar-signin{padding:.25rem .75rem;background:#629924;color:#fff;border:none;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer}.top-bar-signin:hover{background:#4e7d1d}.top-bar-menu{position:relative}.top-bar-menu-trigger{display:flex;align-items:center;gap:.35rem;background:none;border:none;color:#d8dce2;font-size:.85rem;font-weight:600;cursor:pointer;padding:.25rem 0}.top-bar-menu-trigger:hover{color:#eef0f3}.menu-caret{font-size:.7rem;transition:transform .15s;color:#89a}.menu-caret-open{transform:rotate(180deg)}.menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:299}.top-bar-dropdown{position:absolute;top:100%;right:0;margin-top:.4rem;background:#1a2535;border:1px solid #2a3a4a;border-radius:6px;min-width:140px;padding:.25rem 0;box-shadow:0 4px 16px #0006;z-index:300}.dropdown-item{display:block;width:100%;padding:.5rem 1rem;background:none;border:none;color:#ccc;font-size:.85rem;text-align:left;cursor:pointer}.dropdown-item:hover{background:#ffffff12;color:#fff}.dropdown-divider{height:1px;background:#2a3a4a;margin:.25rem 0}.scoreboard{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;padding:1rem;background:#16213e;border-radius:12px}.score-item{text-align:center}.score-item .label{display:block;font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.score-item .value{display:block;font-size:1.5rem;font-weight:700;color:#e94560}.correct-count{color:#4caf50!important}.puzzle-container{display:flex;flex-direction:column;align-items:center;padding-bottom:3.5rem;max-width:520px;margin:0 auto}.puzzle-info{text-align:center;margin-bottom:.4rem}.puzzle-info h2{font-size:1.1rem}.puzzle-meta{color:#888;font-size:.85rem;margin-top:.1rem}.difficulty{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase}.difficulty.easy{background:#4caf50;color:#fff}.difficulty.medium{background:#ff9800;color:#fff}.difficulty.hard{background:#f44336;color:#fff}.board-toolbar{display:flex;justify-content:space-between;align-items:center;margin:0 auto}.board-toolbar-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.board-toolbar-right{display:flex;align-items:center;gap:.25rem}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:4px;color:#667;cursor:pointer;transition:color .15s,background .15s}.toolbar-btn-labeled{width:auto;gap:.3rem;padding:0 .5rem}.toolbar-btn-label{font-size:.75rem}.toolbar-btn:hover{color:#ccc;background:#ffffff14}.board-clock-container{display:flex;justify-content:flex-end;align-items:center;margin:0 auto;gap:.5rem}.clock-player-name{font-size:.85rem;color:#a0aec0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-clock{font-family:Courier New,monospace;font-size:1rem;font-weight:700;padding:.25rem .6rem;border-radius:4px;min-width:3.5rem;text-align:center}.clock-white{background:#2a2a3e;color:#e8e8e8}.clock-black{background:#2a2a3e;color:#ddd}.board-clock.clock-low{color:#f44336}.board-wrapper{border-radius:8px;overflow:hidden;box-shadow:0 8px 32px #0000004d}@keyframes capture-fade{0%{opacity:1}20%{opacity:.4}to{opacity:0}}.capture-fading [data-piece]{animation:capture-fade .3s ease-out forwards}.vote-bar{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.8rem 1rem;margin-top:.5rem}.vote-prompt{font-size:.85rem;color:#89a}.result-header{width:100%;padding:.75rem 1rem;border-radius:8px;display:flex;align-items:center;justify-content:space-between}.result-header.grade-best{background:#1b5e20;border:1px solid #4caf50}.result-header.grade-good{background:#1a472a;border:1px solid #66bb6a}.result-header.grade-inaccuracy{background:#4a3800;border:1px solid #ff9800}.result-header.grade-mistake{background:#b71c1c;border:1px solid #f44336}.result-feedback{font-weight:600;font-size:.95rem}.grade-color-best,.grade-color-good{color:#4caf50}.grade-color-inaccuracy{color:#ff9800}.grade-color-mistake{color:#f44336}.result-summary{width:100%;margin-top:.25rem}.result-summary .result-feedback{text-align:center;font-size:1rem;font-weight:600;margin-bottom:.5rem}.analysis-details{width:100%;margin-top:0;background:#16213e;border-radius:0 0 8px 8px;padding:.75rem;overflow:hidden}.move-comparison{display:flex;justify-content:space-between;gap:.3rem;width:100%;margin-bottom:.5rem}.move-item{flex:1;text-align:center;padding:.4rem .4rem .3rem;background:#0f3460;border-radius:6px}.move-label{display:block;font-size:.6rem;color:#888;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.15rem}.move-value{display:block;font-size:1rem;font-weight:700;font-family:Courier New,monospace}.move-eval{display:block;font-size:.75rem;font-family:Courier New,monospace;margin-top:.1rem;opacity:.8}.move-eval.good,.move-eval.grade-color-best{color:#4caf50}.move-eval.grade-color-good{color:#66bb6a}.move-eval.grade-color-inaccuracy{color:#ff9800}.move-eval.mistake,.move-eval.grade-color-mistake{color:#f44336}.move-value.good,.move-value.grade-color-best{color:#4caf50}.move-value.grade-color-good{color:#66bb6a}.move-value.grade-color-inaccuracy{color:#ff9800}.move-value.mistake,.move-value.grade-color-mistake{color:#f44336}.show-analysis-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:#16213e;border:none;border-radius:8px;color:#a0aec0;font-size:.85rem;cursor:pointer;transition:background .15s}.show-analysis-toggle:hover{background:#1a2744;color:#ccc}.caret{font-size:.65rem;transition:transform .2s;display:inline-block}.caret-open{transform:rotate(90deg)}.exploration-start{color:#556;cursor:pointer;padding:.1rem .3rem;border-radius:3px;font-size:.7rem;transition:background .15s,color .15s;margin-right:.2rem}.exploration-start:hover{background:#ffffff1a;color:#fff}.exploration-start.active{background:#e9456040;color:#fff}.exploration-moves{display:flex;align-items:baseline;flex-wrap:wrap;gap:.15rem;padding:.5rem;margin-bottom:.5rem;background:#ffffff08;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem}.exploration-label{color:#556;font-size:.75rem;margin-right:.3rem}.exploration-move{color:#aaa;cursor:pointer;padding:.1rem .25rem;border-radius:3px;transition:background .15s,color .15s}.exploration-move:hover{background:#ffffff1a;color:#fff}.exploration-move.active{background:#e9456040;color:#fff}.variation-explorer{margin-bottom:.75rem;outline:none}.variation-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.variation-header .analyze-btn{margin:0;padding:.2rem .6rem;font-size:.7rem}.depth-badge{font-size:.65rem;color:#64b5f6;margin-left:.4rem;text-transform:none}.variation-explorer h3{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.05em;margin:0;display:flex;align-items:center;gap:.5rem}.nav-hint{font-size:.65rem;color:#555;text-transform:none;letter-spacing:0;font-weight:400}.variation-line{display:flex;align-items:baseline;gap:.5rem;padding:.45rem .5rem;border-radius:4px;font-size:.9rem;margin-bottom:2px;cursor:pointer;border-left:3px solid transparent;transition:background .15s,border-color .15s;overflow:hidden}.variation-line:hover{background:#ffffff0d}.variation-line.selected{background:#e945601f;border-left-color:#e94560}.variation-line.game-line{border-top:1px solid #2a2a4a;margin-top:4px;padding-top:.55rem}.line-label{color:#666;font-size:.75rem;width:2.5rem;flex-shrink:0}.line-eval{font-family:Courier New,monospace;font-weight:700;width:3.5rem;text-align:right;font-size:.85rem;flex-shrink:0}.line-eval.positive{color:#4caf50}.line-eval.negative{color:#f44336}.line-moves{font-family:Courier New,monospace;font-size:.85rem;color:#aaa;flex:1;line-height:1.6;white-space:nowrap;overflow:hidden;mask-image:linear-gradient(to right,#000 85%,transparent);-webkit-mask-image:linear-gradient(to right,#000 85%,transparent);min-width:0}.move-number{color:#555;margin-right:1px}.variation-move{cursor:pointer;padding:1px 3px;border-radius:3px;transition:background .1s,color .1s;margin-right:2px}.variation-move:hover{background:#ffffff26;color:#fff}.variation-move.active{background:#e94560;color:#fff}.reset-board-btn{display:block;margin:.5rem auto;padding:.3rem 1rem;background:transparent;color:#888;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.8rem}.reset-board-btn:hover{border-color:#e94560;color:#e94560}.analyze-btn{display:block;margin:.25rem auto;padding:.3rem 1rem;background:transparent;border:1px solid #64b5f6;color:#64b5f6;border-radius:6px;cursor:pointer;font-size:.8rem}.analyze-btn:hover:not(:disabled){background:#64b5f626}.analyze-btn.analyzing-active{border-color:#e94560;color:#e94560}.game-link{display:inline-block;color:#64b5f6;font-size:.85rem;text-decoration:none;margin-top:.25rem}.game-link:hover{text-decoration:underline}.puzzle-vote{display:flex;align-items:center;gap:1.5rem}.vote-btn{padding:.4rem .8rem;background:transparent;border:none;border-radius:8px;font-size:2.4rem;cursor:pointer;transition:all .15s;line-height:1;filter:grayscale(.8) opacity(.5)}.vote-btn:hover{filter:grayscale(0) opacity(1);transform:scale(1.15)}.vote-btn:active{transform:scale(.95)}.vote-btn.voted{filter:grayscale(0) opacity(1)}.analyzing{margin-top:1rem;color:#888;font-style:italic}.setup{text-align:center}.waiting-section{background:#16213e;padding:2rem;border-radius:12px}.waiting-section h2{margin-bottom:1rem}.waiting-section p{color:#a0aec0;line-height:1.5}.waiting-spinner{width:40px;height:40px;margin:1.5rem auto;border:3px solid #2a2a3e;border-top-color:#629924;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-hint{font-size:.85rem;color:#667}.notify-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #2a2a3e}.notify-section p{margin-bottom:.75rem;color:#ccc}.notify-form{display:flex;gap:.5rem;justify-content:center}.notify-input{padding:.5rem .75rem;border-radius:6px;border:1px solid #3a3a5e;background:#1a1a2e;color:#eee;font-size:.9rem;width:220px}.notify-btn{padding:.5rem 1.25rem;background:#629924;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.notify-btn:disabled{opacity:.5;cursor:default}.notify-confirmed{margin-top:1rem;color:#629924;font-weight:500}.error{color:#f44336;margin-top:1rem}.reset-btn{padding:.3rem .8rem;background:transparent;color:#888;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.8rem}.reset-btn:hover{border-color:#e94560;color:#e94560}.finished{text-align:center;padding:3rem;background:#16213e;border-radius:12px}.finished h2{margin-bottom:1rem}.grade{font-size:5rem;font-weight:700;color:#e94560;margin-top:1rem}.upsell-banner{margin:1rem auto 1.5rem;padding:1.25rem;background:#16213e;border:1px solid #2a2a3e;border-radius:10px;text-align:center;max-width:520px}.upsell-banner p{margin:0 0 .75rem;color:#ccc;font-size:.95rem}.upsell-btn{padding:.6rem 1.5rem;background:#629924;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer}.upsell-btn:hover{background:#4e7d1d}.upsell-hint{font-size:.8rem!important;color:#667!important;margin-top:.75rem!important;margin-bottom:0!important}.feedback-panel{background:#16213e;border-radius:8px;padding:.75rem;margin-bottom:.75rem}.feedback-input{width:100%;background:#0f3460;color:#eee;border:1px solid #333;border-radius:6px;padding:.5rem;font-size:.85rem;font-family:inherit;resize:vertical}.feedback-input:focus{outline:none;border-color:#64b5f6}.feedback-submit{margin-top:.4rem;padding:.3rem 1rem;background:#e94560;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.8rem}.feedback-submit:disabled{opacity:.4;cursor:default}.feedback-thanks{color:#4caf50;text-align:center;font-size:.9rem;padding:.5rem 0}.analytics-panel{background:#16213e;border-radius:12px;padding:1.5rem}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.analytics-header h2{font-size:1.3rem}.analytics-close{padding:.3rem 1rem;background:transparent;color:#888;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.85rem}.analytics-close:hover{border-color:#e94560;color:#e94560}.analytics-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.analytics-card{background:#0f3460;border-radius:8px;padding:.75rem;text-align:center}.analytics-card-label{display:block;font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.analytics-card-value{display:block;font-size:1.4rem;font-weight:700;color:#eee;margin-top:.2rem}.analytics-section{margin-bottom:1.5rem}.analytics-section h3{font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.analytics-empty{color:#555;font-style:italic}.grade-bar{display:flex;height:24px;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.grade-bar-segment{min-width:4px;transition:width .3s}.grade-legend{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:#aaa}.grade-legend-item{display:flex;align-items:center;gap:.3rem}.grade-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.accuracy-chart{width:100%;max-width:400px}.solved-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.solved-item{display:flex;align-items:center;gap:.75rem;padding:.35rem .5rem;background:#1a1a2e;border-radius:4px;font-size:.8rem}.solved-link{color:#8ab4f8;text-decoration:none;font-family:monospace;font-size:.75rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.solved-link:hover{text-decoration:underline}.solved-grade{font-weight:600;font-size:.75rem;text-transform:capitalize}.solved-time{color:#888;font-size:.75rem}.solved-date{color:#666;font-size:.7rem;margin-left:auto}.clear-stats-btn{display:block;margin:0 auto;padding:.4rem 1.2rem;background:transparent;color:#666;border:1px solid #333;border-radius:4px;cursor:pointer;font-size:.8rem}.clear-stats-btn:hover{border-color:#f44336;color:#f44336}.loading,.no-puzzles{text-align:center;padding:3rem;color:#888;font-size:1.2rem}
