*{margin:0;padding:0;box-sizing:border-box}body{background:#1a1a2e;color:#eee;font-family:Segoe UI,sans-serif;overflow:hidden}#ui{position:absolute;top:0;left:0;width:260px;height:100vh;background:#0a0a1ed9;padding:16px;overflow-y:auto;z-index:10;border-right:1px solid #333}#ui h1{font-size:1.3em;margin-bottom:4px;color:#7fdbca}#ui h2{font-size:.85em;font-weight:400;color:#888;margin-bottom:12px}#turn{font-size:1.1em;margin-bottom:8px}#status{color:#f7c948;margin-bottom:12px;min-height:20px}#captured{margin-bottom:12px}#captured h3{font-size:.85em;color:#888;margin-bottom:4px}.cap-row{min-height:24px;font-size:1.1em;margin-bottom:2px}#move-log{max-height:180px;overflow-y:auto;font-size:.8em;color:#aaa;border-top:1px solid #333;padding-top:8px;margin-top:8px}#move-log div{padding:1px 0}#controls{margin-top:12px}#controls button,#controls select{background:#16213e;color:#eee;border:1px solid #444;padding:6px 12px;cursor:pointer;margin:2px;border-radius:4px;font-size:.85em}#controls button:hover{background:#1a1a5e}#btn-surrender{background:#5e1a1a;border-color:#ff6b6b;color:#ff6b6b}#btn-surrender:hover{background:#7a2020}#btn-export{background:#1a3e2e;border-color:#7fdbca;color:#7fdbca}#btn-export:hover{background:#1a5e3e}.ctrl-row{margin-top:8px}.ctrl-row label{font-size:.85em;color:#888;margin-right:4px}.ctrl-row select{padding:4px 6px}.ai-label{font-size:.85em;color:#aaa;cursor:pointer}.ai-label input{margin-right:4px}#tooltip{position:absolute;background:#000c;color:#eee;padding:4px 8px;border-radius:4px;font-size:.8em;pointer-events:none;display:none;z-index:20}#server-status{margin-top:12px;border-top:1px solid #333;padding-top:8px}#server-status h3{font-size:.85em;color:#888;margin-bottom:4px}#server-info{font-size:.8em;color:#666}#server-info code{color:#7fdbca}#btn-sync{display:none;background:#16213e;color:#eee;border:1px solid #444;padding:4px 8px;cursor:pointer;margin-top:4px;border-radius:4px;font-size:.8em}#btn-sync:hover{background:#1a1a5e}canvas{display:block}#puzzle-section{margin-top:12px;border-top:1px solid #333;padding-top:8px}#puzzle-section h3{font-size:.85em;color:#888;margin-bottom:6px}.puzzle-card{background:#16213e;border:1px solid #333;border-radius:6px;padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:border-color .2s,background .2s}.puzzle-card:hover{border-color:#7fdbca;background:#1a1a5e}.puzzle-card.active{border-color:#f7c948;background:#1e2a4a}.puzzle-card.solved{border-color:#4f8}.puzzle-card.weekly{border-left:3px solid #7fdbca}.puzzle-card .puzzle-title{font-size:.85em;font-weight:700;color:#ddd;margin-bottom:2px}.puzzle-card .puzzle-desc{font-size:.75em;color:#888}.puzzle-card .puzzle-stars{font-size:.7em;color:#f7c948;float:right}.puzzle-card .puzzle-badge{font-size:.65em;color:#4f8;font-weight:700;margin-left:6px}.puzzle-card .weekly-badge{font-size:.65em;color:#7fdbca;font-weight:700;background:#7fdbca1a;padding:2px 6px;border-radius:3px;margin-left:6px}#puzzle-status{font-size:.8em;min-height:18px;margin-bottom:6px;color:#f7c948}#btn-hint,#btn-exit-puzzle{background:#16213e;color:#eee;border:1px solid #444;padding:4px 8px;cursor:pointer;border-radius:4px;font-size:.8em;margin:2px}#btn-hint:hover,#btn-exit-puzzle:hover{background:#1a1a5e}#tutorial-section{margin-top:12px;border-top:1px solid #333;padding-top:8px}#tutorial-section h3{font-size:.85em;color:#888;margin-bottom:6px}#tutorial-description{font-size:.8em;color:#ccc;margin-bottom:10px;line-height:1.4;min-height:18px}.tutorial-card{background:#16213e;border:1px solid #333;border-radius:6px;padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:border-color .2s,background .2s;display:flex;align-items:center;gap:10px}.tutorial-card:hover{border-color:#7fdbca;background:#1a1a5e}.tutorial-card.active{border-color:#f7c948;background:#1e2a4a}.tutorial-card .tutorial-icon{font-size:1.4em;width:28px;text-align:center}.tutorial-card .tutorial-name{font-size:.85em;font-weight:700;color:#ddd}#user-section{margin-top:12px;border-top:1px solid #333;padding-top:8px}#user-section h3{font-size:.85em;color:#888;margin-bottom:6px}#user-email{font-size:.8em;color:#aaa;margin-bottom:6px;word-break:break-all}#subscription-status{font-size:.75em;color:#7fdbca;margin:6px 0;padding:4px 8px;background:#7fdbca1a;border-radius:4px}#login-btn,#logout-btn,#subscribe-btn{background:#16213e;color:#eee;border:1px solid #444;padding:6px 12px;cursor:pointer;border-radius:4px;font-size:.85em;margin:2px 0;width:100%}#login-btn:hover,#logout-btn:hover{background:#1a1a5e}#subscribe-btn{background:#7fdbca;color:#1a1a2e;font-weight:700}#subscribe-btn:hover{background:#5fc4b1}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:100;display:flex;align-items:center;justify-content:center}.modal.hidden{display:none}.modal-content{background:#16213e;padding:24px;border-radius:8px;width:90%;max-width:400px;position:relative;border:1px solid #444}.modal-content h2{color:#7fdbca;margin-bottom:16px}#auth-tabs{display:flex;margin-bottom:16px;gap:8px}#auth-tabs .tab{flex:1;background:#1a1a2e;color:#888;border:1px solid #444;padding:8px 16px;cursor:pointer;border-radius:4px;font-size:.9em}#auth-tabs .tab.active{background:#7fdbca;color:#1a1a2e;font-weight:700;border-color:#7fdbca}#auth-form input{width:100%;padding:10px;margin-bottom:12px;background:#1a1a2e;border:1px solid #444;color:#eee;border-radius:4px;font-size:.9em}#auth-form input:focus{outline:none;border-color:#7fdbca}#auth-submit{width:100%;padding:10px;background:#7fdbca;color:#1a1a2e;border:none;border-radius:4px;font-size:1em;font-weight:700;cursor:pointer}#auth-submit:hover{background:#5fc4b1}.google-btn{width:100%;padding:10px;background:#fff;color:#333;border:1px solid #ddd;border-radius:4px;font-size:.95em;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px}.google-btn:hover{background:#f0f0f0}.google-btn svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;margin:14px 0;color:#666;font-size:.8em}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #444}.auth-divider span{padding:0 10px}#auth-subtitle{color:#aaa;font-size:.9em;margin-bottom:16px;margin-top:-8px}#auth-error{color:#ff6b6b;font-size:.85em;margin-top:12px;padding:8px;background:#ff6b6b1a;border-radius:4px;border:1px solid rgba(255,107,107,.3)}#auth-error.hidden{display:none}#auth-success{color:#7fdbca;font-size:.85em;margin-top:12px;padding:8px;background:#7fdbca1a;border-radius:4px;border:1px solid rgba(127,219,202,.3)}#auth-success.hidden{display:none}#close-auth{position:absolute;top:12px;right:12px;background:none;border:none;color:#888;font-size:1.5em;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center}#close-auth:hover{color:#fff}.hidden{display:none!important}#landing-page{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);overflow-y:auto}.landing-container{text-align:center;padding:40px 20px;max-width:1200px}.landing-title{font-size:4em;color:#7fdbca;margin-bottom:12px;text-shadow:0 0 20px rgba(127,219,202,.3)}.landing-subtitle{font-size:1.5em;color:#aaa;margin-bottom:40px}#landing-user-section{margin-bottom:40px}.user-btn{background:#16213e;color:#7fdbca;border:1px solid #7fdbca;padding:10px 24px;border-radius:6px;cursor:pointer;font-size:1em;transition:all .3s}.user-btn:hover{background:#7fdbca;color:#16213e}#landing-user-email{color:#7fdbca;margin-bottom:12px}.game-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-top:40px}.game-card{background:linear-gradient(145deg,#16213e,#1a1a2e);border:2px solid #444;border-radius:12px;padding:40px 30px;cursor:pointer;transition:all .3s;text-align:center;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center}.game-card:hover:not(.disabled){border-color:#7fdbca;transform:translateY(-8px);box-shadow:0 10px 30px #7fdbca33}.game-card.disabled{opacity:.5;cursor:not-allowed}.game-card.disabled:hover{transform:none}.game-icon{font-size:4em;margin-bottom:20px}.game-card h2{color:#7fdbca;font-size:1.8em;margin-bottom:8px}.game-card p{color:#aaa;font-size:1em;margin-bottom:8px}.game-card .game-desc{color:#777;font-size:.9em;margin-top:12px}.game-header{position:relative;margin-bottom:16px}.back-btn{background:#16213e;color:#7fdbca;border:1px solid #444;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9em;margin-bottom:12px;transition:all .2s}.back-btn:hover{border-color:#7fdbca;background:#1a2740}#mode-select{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);overflow-y:auto}#mode-select .back-btn{position:absolute;top:20px;left:20px}.mode-game,.mode-ai,.mode-puzzles,.mode-tutorial,.mode-online{display:none}#game-view.mode-pvp .mode-game{display:block}#game-view.mode-pvp .mode-ai{display:none}#game-view.mode-pvai .mode-game,#game-view.mode-pvai .mode-ai,#game-view.mode-puzzles .mode-puzzles,#game-view.mode-tutorial .mode-tutorial,#game-view.mode-online .mode-online,#game-view.mode-online .mode-game{display:block}#analyzer-ui{position:absolute;top:0;left:0;width:340px;height:100vh;background:#0a0a1eeb;padding:16px;overflow-y:auto;z-index:10;border-right:1px solid #333}#analyzer-ui h1{font-size:1.3em;margin-bottom:4px;color:#7fdbca}#analyzer-ui h2{font-size:.85em;font-weight:400;color:#888;margin-bottom:12px}#analyzer-upload{margin-bottom:16px}.upload-label{display:block;background:#7fdbca;color:#1a1a2e;font-weight:700;padding:10px 16px;border-radius:6px;cursor:pointer;text-align:center;font-size:.9em;margin-bottom:8px;transition:background .2s}.upload-label:hover{background:#5fc4b1}#analyzer-file{display:none}#analyzer-meta{font-size:.8em;color:#aaa;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #333}#analyzer-controls{display:flex;align-items:center;gap:6px;margin-bottom:12px}#analyzer-controls button{background:#16213e;color:#eee;border:1px solid #444;padding:6px 10px;cursor:pointer;border-radius:4px;font-size:.9em}#analyzer-controls button:hover{background:#1a1a5e}#az-position{font-size:.85em;color:#7fdbca;flex:1;text-align:center}#analyzer-move-list{max-height:160px;overflow-y:auto;margin-bottom:12px;border:1px solid #333;border-radius:4px}.az-move-entry{padding:4px 8px;font-size:.8em;cursor:pointer;display:flex;justify-content:space-between;border-bottom:1px solid #2a2a3e}.az-move-entry:hover{background:#1a1a5e}.az-move-entry.active{background:#1e2a4a;border-left:3px solid #7fdbca}.az-move-entry .az-move-num{color:#666;width:28px}.az-move-entry .az-move-notation{color:#eee;flex:1}.az-move-entry .az-move-badge{font-size:.75em;font-weight:700;padding:1px 6px;border-radius:3px}.az-badge-best{background:#4f83;color:#4f8}.az-badge-good{background:#7fdbca33;color:#7fdbca}.az-badge-inaccuracy{background:#f7c94833;color:#f7c948}.az-badge-blunder{background:#ff6b6b33;color:#ff6b6b}#analyzer-panel{border-top:1px solid #333;padding-top:8px}#analyzer-panel h3{font-size:.85em;color:#888;margin-bottom:8px}#az-played{font-size:.9em;color:#eee;margin-bottom:8px}#az-eval-bar{width:100%;height:12px;background:#333;border-radius:6px;overflow:hidden;margin-bottom:12px}#az-eval-fill{height:100%;width:50%;background:#7fdbca;transition:width .3s;border-radius:6px}#az-ranked-moves{max-height:200px;overflow-y:auto}.az-rank-row{display:flex;align-items:center;gap:8px;padding:3px 6px;font-size:.78em;border-bottom:1px solid #2a2a3e}.az-rank-row.played{background:#7fdbca1a;border-left:3px solid #7fdbca}.az-rank-num{color:#666;width:22px;text-align:right}.az-rank-notation{color:#ddd;flex:1}.az-rank-score{color:#aaa;width:60px;text-align:right;font-family:monospace}#online-setup .landing-container{position:relative}#online-setup .back-btn{position:absolute;top:20px;left:20px}.online-panel{background:#16213eb3;border:1px solid #333;border-radius:8px;padding:1.5rem;margin-bottom:1rem;max-width:460px;margin-left:auto;margin-right:auto}.online-panel h2{font-size:1.1em;color:#7fdbca;margin-bottom:.75rem}.color-picker{display:flex;gap:.5rem;margin-bottom:1rem}.color-btn{flex:1;padding:.5rem;background:#16213e;color:#ccc;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.85em;transition:all .15s}.color-btn:hover{background:#1a1a5e}.color-btn.selected{background:#1a3e5e;border-color:#7fdbca;color:#7fdbca}.primary-btn{width:100%;padding:.7rem;background:#1a5e3e;color:#7fdbca;border:1px solid #7fdbca;border-radius:4px;cursor:pointer;font-size:1em;transition:background .15s}.primary-btn:hover{background:#1a7e4e}.invite-link-row{display:flex;gap:.5rem}.invite-link-row input{flex:1;padding:.5rem;background:#0a0a1e;color:#eee;border:1px solid #444;border-radius:4px;font-size:.9em}.invite-link-row button{padding:.5rem 1rem;background:#16213e;color:#eee;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.85em}.invite-link-row button:hover{background:#1a1a5e}#mp-info{margin-bottom:12px;font-size:.85em}#mp-color-badge{font-weight:700}#mp-opponent-status{margin-top:4px;display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:#4f8}.status-dot.offline{background:#666}
