:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box}body{color:#e5e7eb;background:#0f172a;margin:0;font-family:system-ui,sans-serif}.app{flex-direction:column;height:100vh;display:flex}.topbar{background:#111827;border-bottom:1px solid #1f2937;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.topbar h1{margin:0;font-size:20px}.speed-control{color:#9ca3af;align-items:center;gap:6px;font-size:14px;display:flex}.speed-control input{color:#e5e7eb;text-align:center;background:#1f2937;border:1px solid #374151;border-radius:8px;width:58px;padding:6px 8px;font-size:14px}.browse-button{color:#e5e7eb;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:#1f2937;border:1px solid #374151;border-radius:8px;max-width:260px;padding:8px 14px;font-size:14px;overflow:hidden}.browse-button:hover{background:#374151}.browser-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.browser-modal{background:#111827;border:1px solid #1f2937;border-radius:14px;flex-direction:column;width:680px;height:480px;display:flex;overflow:hidden;box-shadow:0 20px 60px #0009}.browser-diff-header{border-bottom:1px solid #1f2937;flex-shrink:0;align-items:center;gap:14px;padding:14px 18px;display:flex}.diff-label{color:#6b7280;white-space:nowrap;min-width:62px;font-size:13px}.diff-range{flex:1;height:20px;position:relative}.diff-track-bg{pointer-events:none;background:#374151;border-radius:2px;height:4px;position:absolute;top:8px;left:0;right:0}.diff-track-fill{pointer-events:none;background:#3b82f6;border-radius:2px;height:4px;position:absolute;top:8px}.diff-range input[type=range]{-webkit-appearance:none;pointer-events:none;background:0 0;width:100%;height:20px;margin:0;padding:0;position:absolute;top:0;left:0}.diff-range input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:all;cursor:pointer;background:#3b82f6;border:2px solid #0f172a;border-radius:50%;width:16px;height:16px}.diff-range input[type=range]::-webkit-slider-runnable-track{background:0 0;height:4px}.browser-body{flex:1;display:flex;overflow:hidden}.browser-sidebar{border-right:1px solid #1f2937;flex-direction:column;gap:2px;width:180px;min-width:180px;padding:10px 8px;display:flex;overflow-y:auto}.browser-cat{text-align:left;color:#9ca3af;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:8px;padding:9px 12px;font-size:14px;overflow:hidden}.browser-cat:hover{color:#e5e7eb;background:#1f2937}.browser-cat.active{color:#fff;background:#1d4ed8}.browser-files{flex-direction:column;flex:1;gap:4px;padding:10px;display:flex;overflow-y:auto}.browser-file{text-align:left;color:#e5e7eb;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:11px 14px;font-size:14px}.browser-file:hover{color:#fff;background:#263348;border-color:#3b82f6}.global-controls{gap:8px;display:flex}.global-play-button,.global-stop-button{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600}.global-play-button{color:#fff;background:#1d4ed8}.global-play-button:hover:not(:disabled){background:#2563eb}.global-stop-button{color:#e5e7eb;background:#374151}.global-stop-button:hover:not(:disabled){background:#4b5563}.global-play-button:disabled,.global-stop-button:disabled{opacity:.35;cursor:default}.message{cursor:pointer}.message.active>.bubble{outline-offset:2px;outline:2px solid #3b82f6}.content{flex-direction:row;flex:1;display:flex;overflow:hidden}.empty{color:#9ca3af;flex:1;padding:40px}.chat{background:#0f172a;flex:1;padding:20px;overflow-y:auto}.meta{color:#9ca3af;gap:12px;margin-bottom:20px;display:flex}.message{margin-bottom:14px;display:flex}.message.left{justify-content:flex-start}.message.right{justify-content:flex-end}.bubble{background:#1e293b;border:1px solid #334155;border-radius:16px;max-width:70%;padding:14px 16px;box-shadow:0 2px 10px #00000059}.message.right .bubble{background:#064e3b;border-color:#047857}.speaker{color:#94a3b8;margin-bottom:6px;font-size:12px;font-weight:700}.thai{color:#f8fafc;margin-bottom:8px;font-size:22px}.karaoke{color:#cbd5e1;margin-bottom:6px;font-size:15px}.english{color:#94a3b8;font-size:14px}.bubble-actions{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.play-button{color:#f8fafc;cursor:pointer;background:#334155;border:none;border-radius:999px;width:32px;height:32px;margin-left:auto;font-size:14px}.play-button:hover{background:#475569}.play-button.playing{color:#052e16;background:#22c55e}.copy-button{color:#f8fafc;cursor:pointer;white-space:nowrap;background:#334155;border:none;border-radius:999px;align-items:center;gap:5px;height:32px;padding:6px 12px;font-size:14px;display:flex}.copy-button:hover{background:#475569}.copy-button.copied{color:#052e16;background:#22c55e}.tutor-panel{background:#0d1424;border-left:1px solid #1f2937;flex-direction:column;width:340px;min-width:260px;display:flex}.tutor-header{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #1f2937;padding:12px 16px;font-size:13px;font-weight:700}.tutor-messages{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.tutor-empty{color:#4b5563;text-align:center;margin-top:20px;font-size:13px}.tutor-msg{white-space:pre-wrap;word-break:break-word;border-radius:12px;padding:10px 13px;font-size:14px;line-height:1.5}.tutor-msg-user{color:#eff6ff;background:#1d4ed8;align-self:flex-end;max-width:85%}.tutor-msg-assistant{color:#e2e8f0;background:#1e293b;align-self:flex-start;max-width:92%}.tutor-thinking{color:#64748b;font-style:italic}.tutor-input-row{border-top:1px solid #1f2937;align-items:flex-end;gap:8px;padding:12px;display:flex}.tutor-input{resize:none;color:#e5e7eb;background:#1f2937;border:1px solid #374151;border-radius:8px;flex:1;padding:8px 10px;font-family:inherit;font-size:14px;line-height:1.4}.tutor-input:focus{border-color:#3b82f6;outline:none}.tutor-send{color:#fff;cursor:pointer;white-space:nowrap;background:#1d4ed8;border:none;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:600}.tutor-send:hover:not(:disabled){background:#2563eb}.tutor-send:disabled{opacity:.35;cursor:default}
