:root{color:#1d2522;background:#f4f0e8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px}button,textarea,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;background:linear-gradient(180deg,#ffffffad,#f4f0e8eb),#f4f0e8}.workspace{display:grid;grid-template-columns:minmax(420px,1fr) 430px;min-height:100vh}.left-pane{padding:28px}.right-pane{display:flex;flex-direction:column;gap:14px;max-height:100vh;overflow:auto;border-left:1px solid #ded8cb;background:#fbfaf7;padding:18px}.product-hero{margin-bottom:24px;border:1px solid #1f2b27;border-radius:8px;background:linear-gradient(135deg,#266f6257,#0d1211f5),#111715;color:#f6f2e9;padding:18px;box-shadow:0 18px 45px #1f292429}.product-nav{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:30px}.brand-lockup{display:inline-flex;align-items:center;gap:10px}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border:1px solid #1f6f61;border-radius:8px;background:#1f6f61;color:#fff;font-size:22px;font-weight:900}.brand-lockup strong,.brand-lockup small{display:block}.brand-lockup strong{font-size:18px;line-height:1.1}.brand-lockup small{color:#b5c0b9;font-size:13px;margin-top:3px}.nav-links{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.nav-links a,.language-btn{display:inline-flex;align-items:center;min-height:32px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#ffffff0f;color:#eff5ef;padding:0 10px;font-size:13px;font-weight:800;text-decoration:none}.language-btn{background:#f4d06f;color:#1d2522}.hero-copy{max-width:820px}.hero-copy h1{max-width:760px;font-size:42px;line-height:1.08;margin-bottom:12px}.hero-copy p:not(.eyebrow){max-width:720px;color:#d2ddd5;font-size:17px;line-height:1.65;margin-bottom:0}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.secondary-btn{display:inline-flex;align-items:center;gap:8px;min-height:42px;border:1px solid rgba(255,255,255,.22);border-radius:8px;background:#ffffff14;color:#f8f3e8;padding:0 16px;font-weight:800}.secondary-btn:disabled{opacity:.65}.proof-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:10px;max-width:620px;margin-top:18px}.hero-stats span{min-height:68px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#ffffff12;padding:10px;color:#d9e4dd;font-size:13px}.hero-stats b{display:block;color:#f4d06f;font-size:24px;line-height:1.1;margin-bottom:6px}.proof-row span{display:inline-flex;align-items:center;min-height:28px;border:1px solid rgba(244,208,111,.22);border-radius:8px;background:#f4d06f1a;color:#f5e9c7;padding:0 10px;font-size:13px;font-weight:800}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.eyebrow{color:#6d7f72;font-size:13px;font-weight:700;margin:0 0 4px}h1,h2,p{margin-top:0}h1{font-size:32px;line-height:1.1;margin-bottom:0}h2{font-size:16px;margin-bottom:12px}.primary-btn,.upload-box,.segmented button,.level-row button,.move-limit,.move-controls button,.moves-table button,.sample-list button,.moment{border:1px solid #d4ccbd;border-radius:8px;background:#fffdf9;color:#1d2522}.primary-btn{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 16px;background:#1f6f61;color:#fff;border-color:#1f6f61;font-weight:700}.primary-btn:disabled{opacity:.65}.analysis-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.segmented{display:inline-grid;grid-template-columns:repeat(3,1fr);gap:4px;min-width:230px;padding:4px;border:1px solid #d4ccbd;border-radius:8px;background:#fbfaf7}.segmented button{min-height:34px;border-color:transparent;background:transparent;font-weight:700;color:#51605a}.segmented button.selected{background:#1f6f61;color:#fff}.move-limit{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 10px;color:#4e5b55;background:#fffdf9}.move-limit input{width:70px;border:1px solid #d4ccbd;border-radius:6px;padding:5px 6px;background:#fbfaf7;color:#1d2522}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.board-zone{display:flex;justify-content:center;align-items:center;min-height:360px}.move-controls{display:flex;align-items:center;justify-content:center;gap:10px;margin:18px 0}.move-controls button{display:grid;place-items:center;width:40px;height:40px}.move-controls span{min-width:92px;text-align:center;color:#5b625f}.moves-table{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:6px;max-height:250px;overflow:auto;padding:4px}.move-row{display:grid;grid-template-columns:36px 1fr 1fr;gap:4px;align-items:center}.move-number{color:#7a756d;font-size:13px}.moves-table button{min-height:32px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.move-btn{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:0 7px}.move-btn span{border-radius:999px;padding:2px 5px;font-size:11px;font-weight:800;color:#fff}.move-btn.inaccuracy span{background:#7f6a2a}.move-btn.mistake span{background:#ad6127}.move-btn.blunder span,.move-btn.allowed_mate span,.move-btn.missed_mate span{background:#a33c3c}.moves-table button.active{border-color:#1f6f61;background:#e4f1eb;font-weight:700}.status-line{display:flex;align-items:center;gap:8px;color:#4e5b55;min-height:34px;font-size:14px}.progress-card{display:flex;flex-direction:column;gap:9px}.progress-copy{display:flex;align-items:center;justify-content:space-between;gap:12px}.progress-copy strong{font-size:14px}.progress-copy span,.progress-card p{color:#6f736f;font-size:13px}.progress-card p{margin-bottom:0}.progress-track{height:9px;overflow:hidden;border-radius:999px;background:#ece5d8}.progress-track div{height:100%;border-radius:inherit;background:#1f6f61;transition:width .18s ease}.panel{border:1px solid #ded8cb;border-radius:8px;background:#fffdf9;padding:14px}.upload-box{display:flex;align-items:center;gap:8px;min-height:40px;padding:0 12px;margin-bottom:10px;color:#315f55;font-weight:700}.level-row{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:10px;padding:4px;border:1px solid #d4ccbd;border-radius:8px;background:#fbfaf7}.level-row button{min-height:32px;border-color:transparent;background:transparent;color:#51605a;font-size:13px;font-weight:700}.level-row button.selected{background:#315f55;color:#fff}.upload-box input{display:none}textarea{width:100%;min-height:150px;resize:vertical;border:1px solid #d4ccbd;border-radius:8px;padding:10px;background:#fbfaf7;color:#1d2522}.sample-list{display:flex;flex-direction:column;gap:6px;max-height:190px;overflow:auto}.demo-sample-btn{display:flex;align-items:center;gap:9px;width:100%;min-height:54px;border:1px solid #1f6f61;border-radius:8px;margin-bottom:10px;background:#eaf5ef;color:#173f37;padding:8px 10px;text-align:left}.demo-sample-btn:disabled{opacity:.65}.demo-sample-btn span,.demo-sample-btn b,.demo-sample-btn small{display:block;min-width:0}.demo-sample-btn b{font-size:14px}.demo-sample-btn small{overflow:hidden;color:#52645d;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.sample-list button{display:flex;align-items:center;gap:6px;min-height:34px;padding:0 8px;text-align:left}.sample-list span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-card p,.muted{color:#6f736f;font-size:14px}.engine-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.engine-meta span,.reason-tags span,.theme-row span{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 8px;background:#edf1ec;color:#43504a;font-size:12px;font-weight:700}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.panel-heading h2{margin-bottom:0}.panel-heading span{color:#6f736f;font-size:13px}.chart-panel svg{display:block;width:100%;height:auto;overflow:visible}.chart-zero{stroke:#d7d1c5;stroke-width:1.2;stroke-dasharray:5 5}.chart-line{fill:none;stroke:#315f55;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.chart-dot{fill:#315f55;stroke:#fffdf9;stroke-width:1.5}.chart-dot.inaccuracy{fill:#7f6a2a}.chart-dot.mistake{fill:#ad6127}.chart-dot.blunder,.chart-dot.missed_mate,.chart-dot.allowed_mate{fill:#a33c3c}.chart-dot.selected{stroke:#1d2522;stroke-width:2.4}.chart-hit{border:0;padding:0;background:transparent}.chart-cursor{stroke:#1d2522;stroke-width:1;opacity:.45}.chart-legend{display:flex;justify-content:space-between;color:#767267;font-size:12px;margin-top:-4px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.stat-card{min-height:62px;border:1px solid #ded8cb;border-radius:8px;background:#fbfaf7;padding:8px}.stat-card strong,.stat-card span{display:block}.stat-card strong{font-size:22px;line-height:1.1}.stat-card span{color:#6f736f;font-size:12px;margin-top:4px}.focus-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px}.focus-card{min-height:58px;border:1px solid #d4ccbd;border-radius:8px;background:#fffdf9;padding:10px;text-align:left}.focus-card:disabled{cursor:default;opacity:.72}.focus-card span,.focus-card b{display:block}.focus-card span{color:#6f736f;font-size:12px;margin-bottom:4px}.focus-card b{color:#1d2522;font-size:14px;line-height:1.35}.theme-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.moment-list{display:flex;flex-direction:column;gap:8px}.moment{text-align:left;padding:10px}.moment b,.moment small,.moment p{display:block}.moment small{color:#6f736f;margin:5px 0}.moment p{margin-bottom:0;font-size:14px;line-height:1.5}.coach-action{display:inline-flex;align-items:center;gap:6px;min-height:30px;border-radius:8px;margin-top:10px;padding:0 10px;background:#1f6f61;color:#fff;font-size:13px;font-weight:800}.coach-card{margin-top:10px;border:1px solid #c9dfd5;border-radius:8px;background:#f2faf6;padding:10px}.coach-card strong,.coach-card b,.coach-card p{display:block}.coach-card strong{margin-bottom:7px;color:#173f37}.coach-card p{color:#39423d;margin-bottom:7px}.coach-card b{color:#173f37;font-size:14px;line-height:1.45}.thought-box{margin-top:10px;border:1px solid #e0d8c9;border-radius:8px;background:#fffaf0;padding:10px}.thought-box label,.thought-box label span{display:block}.thought-box label span{color:#574f42;font-size:13px;font-weight:800;margin-bottom:6px}.thought-box textarea{min-height:64px;background:#fffdf9}.thought-action{display:inline-flex;align-items:center;gap:6px;min-height:30px;border:1px solid #7a6337;border-radius:8px;margin-top:8px;padding:0 10px;background:#7a6337;color:#fff;font-size:13px;font-weight:800}.thought-action:disabled{cursor:default;opacity:.55}.thought-review{display:flex;flex-direction:column;gap:7px;margin-top:10px;border-top:1px solid #e1d5bd;padding-top:9px}.thought-review p,.thought-review strong{margin:0;color:#3e372b;font-size:13px;line-height:1.45}.thought-review b{display:inline-flex;margin-right:7px;color:#6d5423}.thought-review strong{color:#5c451d}.coach-chat{margin-top:10px;border-top:1px solid #e2dbce;padding-top:10px}.chat-empty{color:#6f736f;font-size:13px;margin-bottom:8px}.chat-messages{display:flex;flex-direction:column;gap:7px;margin-bottom:9px}.chat-message{max-width:92%;border-radius:8px;padding:8px 9px;font-size:13px;line-height:1.45;white-space:pre-wrap}.chat-message.user{align-self:flex-end;background:#315f55;color:#fff}.chat-message.assistant{align-self:flex-start;background:#eef3ec;color:#26332e}.chat-input-row{display:grid;grid-template-columns:1fr 34px;gap:6px}.chat-input-row input{min-width:0;height:34px;border:1px solid #d4ccbd;border-radius:8px;background:#fffdf9;color:#1d2522;padding:0 9px}.chat-input-row button{display:grid;place-items:center;width:34px;height:34px;border:1px solid #1f6f61;border-radius:8px;background:#1f6f61;color:#fff}.chat-input-row button:disabled{cursor:default;opacity:.55}.tag{display:inline-block;border-radius:999px;padding:3px 8px;margin-bottom:8px;font-size:12px;font-weight:800;color:#fff}.tag.inaccuracy{background:#7f6a2a}.tag.mistake{background:#ad6127}.tag.blunder{background:#a33c3c}.tag.missed_mate,.tag.allowed_mate{background:#7f2f40}.reason-tags{display:flex;flex-wrap:wrap;gap:5px;margin:8px 0}.training-list{margin:0;padding-left:18px;color:#39423d;line-height:1.6}@media(max-width:980px){.workspace{grid-template-columns:1fr}.right-pane{max-height:none;border-left:0;border-top:1px solid #ded8cb}.analysis-strip{align-items:stretch;flex-direction:column}.segmented,.move-limit{width:100%}.product-nav{align-items:flex-start;flex-direction:column}.hero-stats{grid-template-columns:1fr}.hero-copy h1{font-size:32px}.hero-copy p:not(.eyebrow){font-size:15px}}
