*{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}#welcome-view{width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#0f0f23,#16213e);overflow-y:auto}#welcome-view .welcome-container{text-align:center;padding:40px 20px;max-width:440px;width:100%}.welcome-auth-box{background:#16213ecc;border:1px solid #444;border-radius:12px;padding:28px 24px;margin-top:28px;text-align:left}.welcome-auth-title{color:#7fdbca;margin-bottom:6px;font-size:1.2em;text-align:center}.welcome-auth-subtitle{color:#aaa;font-size:.85em;margin-bottom:18px;text-align:center}#welcome-auth-tabs{display:flex;margin-bottom:16px;gap:8px}#welcome-auth-tabs .tab{flex:1;background:#1a1a2e;color:#888;border:1px solid #444;padding:8px 16px;cursor:pointer;border-radius:4px;font-size:.9em}#welcome-auth-tabs .tab.active{background:#7fdbca;color:#1a1a2e;font-weight:700;border-color:#7fdbca}#welcome-auth-form input{width:100%;padding:10px;margin-bottom:12px;background:#1a1a2e;border:1px solid #444;color:#eee;border-radius:4px;font-size:.9em}#welcome-auth-form input:focus{outline:none;border-color:#7fdbca}#welcome-auth-submit{width:100%;padding:10px;background:#7fdbca;color:#1a1a2e;border:none;border-radius:4px;font-size:1em;font-weight:700;cursor:pointer}#welcome-auth-submit:hover{background:#5fc4b1}#welcome-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)}#welcome-auth-error.hidden{display:none}#welcome-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)}#welcome-auth-success.hidden{display:none}.welcome-divider{border-top:1px solid #444;margin:20px 0}.guest-btn{width:100%;padding:12px;background:transparent;color:#aaa;border:1px solid #555;border-radius:4px;font-size:.95em;cursor:pointer;transition:all .2s}.guest-btn:hover{color:#eee;border-color:#888;background:#ffffff0d}#landing-page{width:100vw;min-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:30px 20px;max-width:900px;width:100%}.landing-title{font-size:3em;color:#7fdbca;margin-bottom:8px;text-shadow:0 0 20px rgba(127,219,202,.3)}.landing-subtitle{font-size:1.2em;color:#aaa;margin-bottom:24px}#landing-user-section{margin-bottom:24px}.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(2,1fr);gap:16px;margin-top:24px}.game-card{background:linear-gradient(145deg,#16213e,#1a1a2e);border:2px solid #444;border-radius:12px;padding:24px 16px;cursor:pointer;transition:all .3s;text-align:center;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:2.5em;margin-bottom:10px}.game-card h2{color:#7fdbca;font-size:1.2em;margin-bottom:4px}.game-card p{color:#aaa;font-size:.85em;margin-bottom:4px}.game-card .game-desc{color:#777;font-size:.8em;margin-top:6px}.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;min-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}#game-view .mode-game,#game-view .mode-ai,#game-view .mode-puzzles,#game-view .mode-tutorial,#game-view .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}#mp-player-info{margin:8px 0}.mp-profile-row{display:flex;align-items:center;gap:8px;margin:4px 0}.mp-avatar{width:24px;height:24px;border-radius:50%;border:1px solid #444;object-fit:cover}.mp-vs{color:#666;font-size:.75em;margin:2px 0;padding-left:32px}#mp-my-name,#mp-opponent-name{font-size:.85em;color:#ccc}#profile-setup-view{width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#0f0f23,#16213e);overflow-y:auto}#avatar-upload-section{text-align:center;margin-bottom:20px}#avatar-preview{width:80px;height:80px;border-radius:50%;border:2px solid #444;margin:0 auto 12px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#1a1a2e}#avatar-placeholder{font-size:2em;color:#555}#avatar-preview-img{width:100%;height:100%;object-fit:cover}.avatar-upload-btn{display:inline-block;padding:6px 16px;background:#16213e;color:#7fdbca;border:1px solid #7fdbca;border-radius:4px;cursor:pointer;font-size:.85em;transition:all .2s}.avatar-upload-btn:hover{background:#7fdbca;color:#16213e}#avatar-upload-error,#profile-save-error{font-size:.8em;margin-top:8px;color:#ff6b6b;padding:8px;background:#ff6b6b1a;border-radius:4px;border:1px solid rgba(255,107,107,.3)}#game-id-section{margin-bottom:20px}#game-id-input{width:100%;padding:10px;background:#1a1a2e;border:1px solid #444;color:#eee;border-radius:4px;font-size:.9em;margin-bottom:4px}#game-id-input:focus{outline:none;border-color:#7fdbca}#game-id-hint{font-size:.75em;color:#666;margin-bottom:4px}#game-id-status{font-size:.8em;padding:4px 8px;border-radius:4px}#game-id-status.available{color:#4f8;background:#44ff881a}#game-id-status.taken{color:#ff6b6b;background:#ff6b6b1a}#game-id-status.invalid{color:#f7c948;background:#f7c9481a}.user-avatar{width:40px;height:40px;border-radius:50%;border:2px solid #7fdbca;object-fit:cover}#landing-user-info{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px}#landing-user-display{color:#7fdbca;font-size:1em}#landing-user-actions{display:flex;gap:8px;justify-content:center}.user-btn-small{background:transparent;color:#aaa;border:1px solid #555;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:.85em;transition:all .2s}.user-btn-small:hover{color:#7fdbca;border-color:#7fdbca}#promotion-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:150;display:flex;align-items:center;justify-content:center}#promotion-modal.hidden{display:none}.promotion-content{background:#16213e;border:2px solid #7fdbca;border-radius:12px;padding:20px 24px;text-align:center;box-shadow:0 8px 32px #00000080}.promotion-title{color:#7fdbca;font-size:1em;margin-bottom:14px;font-weight:700}.promotion-choices{display:flex;gap:16px;justify-content:center}.promotion-btn{background:#1a1a2e;border:2px solid #444;border-radius:8px;padding:12px 20px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px;color:#eee;min-width:80px}.promotion-btn:hover{border-color:#7fdbca;background:#1a2740;transform:translateY(-2px);box-shadow:0 4px 12px #7fdbca33}.promotion-icon{font-size:2em}.promotion-btn span:last-child{font-size:.8em;color:#aaa}#music-player{position:fixed;bottom:0;left:0;right:0;height:40px;background:#0a0a1ef2;border-top:1px solid #333;display:flex;align-items:center;gap:10px;padding:0 16px;z-index:200}#music-toggle{background:none;border:1px solid #444;color:#7fdbca;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1em;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}#music-toggle:hover{border-color:#7fdbca;background:#7fdbca1a}#music-toggle.playing{background:#7fdbca33;border-color:#7fdbca}#music-title{color:#aaa;font-size:.8em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}#music-volume{width:80px;flex-shrink:0;accent-color:#7fdbca;cursor:pointer}
