:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0f1218;--panel:#171b24;--text:#e8ecf1;--muted:#9aa3b2;--accent:#6ee7b7;--border:#2a3142;font-family:Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(1200px 800px at 20% 0%, #1a2233 0%, var(--bg) 55%);color:var(--text);margin:0}.page{max-width:1120px;margin:0 auto;padding:24px 20px 48px}.header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px 24px;margin-bottom:20px;display:flex}h1{letter-spacing:.02em;margin:0 0 6px;font-size:1.6rem;font-weight:650}.sub{color:var(--muted);max-width:52ch;margin:0;line-height:1.55}.toolbar{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.field{color:var(--muted);flex-direction:column;gap:4px;font-size:.78rem;display:flex}select{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;min-width:200px;padding:8px 10px}button{color:var(--text);border:1px solid var(--border);cursor:pointer;background:linear-gradient(#2c3448,#222838);border-radius:8px;padding:9px 14px;font-weight:600}button:hover{border-color:#3d4a63}.layout{grid-template-columns:minmax(280px,420px) 1fr;align-items:start;gap:20px;display:grid}.post-game{border-color:#6ee7b759;grid-column:1/-1}.post-game-hint{color:var(--muted);margin:0 0 12px;font-size:.88rem;line-height:1.5}.post-game-body{max-height:min(70vh,520px);overflow:auto}.engine-explain{border-color:#93c5fd59}.engine-explain-intro{color:var(--muted);margin:0 0 12px;font-size:.88rem;line-height:1.55}.engine-explain-btn{background:linear-gradient(#243044,#1a2230);border-color:#3d5a8a;margin-bottom:12px}.engine-explain-btn:hover{border-color:#5b7eb8}.engine-explain-body{max-height:min(55vh,420px);margin-top:4px;overflow:auto}@media (width<=880px){.layout{grid-template-columns:1fr}}.board-wrap{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:12px}.setup-banner{color:var(--accent);margin-bottom:10px;font-size:.88rem;line-height:1.45}.spare-pieces{border:1px solid var(--border);background:#0003;border-radius:10px;flex-wrap:wrap;gap:6px;margin-bottom:10px;padding:8px;display:flex}.spare-pieces--hidden{display:none}.spare-pieces>div{width:36px;height:36px}.setup-tools{flex-direction:column;gap:10px;margin-top:12px;display:flex}.setup-tools .row,.fen-import{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.fen-label{flex:1;min-width:200px}.fen-text{border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;background:#0c0f14;border-radius:8px;margin-top:4px;padding:8px 10px;font-family:ui-monospace,monospace;font-size:.82rem}.play-bar{align-items:center}.fen-inline{color:var(--muted);word-break:break-all;max-height:4.2em;font-size:.72rem;line-height:1.35;overflow:auto}.status{color:var(--muted);align-items:center;gap:8px;margin-top:10px;font-size:.9rem;display:flex}.dot{border-radius:999px;width:8px;height:8px;display:inline-block}.dot.ok{background:var(--accent);box-shadow:0 0 10px #6ee7b780}.dot.load{background:#fbbf24}.dot.bad{background:#f87171}.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;min-height:200px;padding:16px 18px}.panel h2{margin:0 0 12px;font-size:1.05rem}.coach{white-space:pre-wrap;color:#dfe6f0;margin:0;font-size:.95rem;line-height:1.65}.tutor-setup-form{background:#6ee7b70f;border:1px solid #6ee7b740;border-radius:10px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.tutor-setup-title{color:var(--accent);letter-spacing:.03em;font-size:.82rem;font-weight:600}.tutor-assignment-input{border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;background:#0c0f14;border-radius:8px;margin-top:4px;padding:8px 10px;font-family:inherit;font-size:.88rem}.tutor-chat-panel{border-color:#6ee7b74d;flex-direction:column;grid-column:1/-1;min-height:320px;display:flex}.tutor-panel{flex-direction:column;flex:1;gap:10px;display:flex}.tutor-messages{flex-direction:column;flex:1;gap:10px;max-height:380px;padding-right:4px;display:flex;overflow-y:auto}.tutor-msg{flex-direction:column;gap:3px;display:flex}.tutor-msg-label{color:var(--muted);font-size:.75rem;font-weight:600}.tutor-msg--assistant .tutor-msg-label{color:var(--accent)}.tutor-msg-text{border-radius:10px;max-width:88%;margin:0;padding:10px 12px;font-size:.93rem;line-height:1.6}.tutor-msg--assistant .tutor-msg-text{background:#6ee7b714;border:1px solid #6ee7b72e;align-self:flex-start}.tutor-msg--user .tutor-msg-text{background:#60a5fa1a;border:1px solid #60a5fa33;align-self:flex-end}.tutor-thinking{color:var(--muted);font-style:italic}.tutor-input-row{align-items:flex-end;gap:8px;display:flex}.tutor-input{border:1px solid var(--border);color:var(--text);resize:none;background:#0c0f14;border-radius:8px;flex:1;padding:8px 10px;font-family:inherit;font-size:.88rem}.tutor-input:focus{border-color:#6ee7b766;outline:none}.tutor-send-btn{white-space:nowrap;color:var(--accent);background:linear-gradient(#1d3a2a,#152a1e);border-color:#6ee7b759}.tutor-send-btn:hover:not(:disabled){border-color:var(--accent)}.tutor-send-btn:disabled{opacity:.45;cursor:not-allowed}.user-badge{align-items:center;gap:8px;margin-left:auto;display:flex}.user-name{color:var(--accent);font-size:.85rem;font-weight:600}.logout-btn{border-color:var(--border);color:var(--muted);background:0 0;padding:6px 10px;font-size:.8rem;font-weight:400}.logout-btn:hover{color:var(--text);border-color:#4a5568}.encouragement-banner{color:var(--accent);text-align:center;background:linear-gradient(135deg,#6ee7b71f,#60a5fa14);border:1px solid #6ee7b74d;border-radius:8px;margin-bottom:12px;padding:8px 12px;font-size:.9rem}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 8px 40px #0006}.login-title{text-align:center;margin:0 0 8px;font-size:1.5rem}.login-sub{color:var(--muted);text-align:center;margin:0 0 24px;font-size:.85rem;line-height:1.5}.login-tabs{background:#0003;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:flex}.login-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:8px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.login-tab.active{background:var(--panel);color:var(--text);border:1px solid var(--border)}.login-form{flex-direction:column;gap:14px;display:flex}.login-field{color:var(--muted);flex-direction:column;gap:6px;font-size:.82rem;display:flex}.login-input{color:var(--text);border:1px solid var(--border);background:#0c0f14;border-radius:8px;outline:none;padding:10px 12px;font-size:.95rem;transition:border-color .15s}.login-input:focus{border-color:#6ee7b780}.login-error{color:#f87171;text-align:center;margin:0;font-size:.85rem}.login-btn{color:var(--accent);background:linear-gradient(#1d4a35,#153626);border-color:#6ee7b766;margin-top:4px;padding:12px;font-size:1rem}.login-btn:hover:not(:disabled){border-color:var(--accent)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-hint{color:var(--muted);text-align:center;margin:20px 0 0;font-size:.78rem;line-height:1.5}
