:root{color-scheme:light;--bg:#f8efe6;--ink:#2d2825;--muted:#8d7f73;--line:#eadfce;--surface:#ffffff;--accent:#ff6a57;--accent-dark:#f25845;--green:#2a7a57}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit}.page{width:100%;margin:0 auto;min-height:100vh;padding:14px 22px 24px;background:var(--bg)}.app-shell{position:relative}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 2px 10px}.brand-wrap{display:grid;grid-gap:2px;gap:2px}.brand{font-size:16px;font-weight:900;letter-spacing:-.03em}.brand-subtitle{margin:0;font-size:11px;color:var(--muted)}.nav{display:flex;gap:16px;color:var(--muted);font-size:12px}.profile-button{display:grid;place-items:center;width:46px;height:46px;margin-left:auto;border:1px solid #e6ddd1;border-radius:50%;background:#fff;box-shadow:0 1px 0 rgba(255,255,255,.8),0 2px 6px rgba(0,0,0,.04);transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease}.topbar-actions{display:flex;align-items:center;gap:10px}.ghost-pill{min-height:44px;padding:0 18px;border:2px solid #f07a67;border-radius:999px;background:transparent;color:#f07a67;font-weight:700;cursor:pointer;transition:transform .16s ease,background-color .16s ease,color .16s ease,border-color .16s ease}.profile-icon{font-size:24px;line-height:1}.hero{display:grid;place-items:center;grid-gap:10px;gap:10px;padding-top:12px;text-align:center}.hero-center{width:min(980px,100%);margin:0 auto}h2{font-size:18px;margin:0 0 14px}p{line-height:1.55}.muted{color:var(--muted)}.hero-kicker{margin:0;font-size:14px}.hero-subtitle{max-width:640px;margin:0;font-size:15px;color:#7f7266}.hero-intro{margin:2px 0 0;font-size:28px;line-height:1.05;font-weight:900;letter-spacing:-.03em}.grid{display:grid;grid-gap:14px;gap:14px}.starter-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px;width:min(600px,100%);margin:8px auto 0}.starter-grid-styles{width:min(560px,100%)}.starter-card{display:grid;align-content:start;justify-items:start;align-items:start;grid-gap:10px;gap:10px;min-height:162px;padding:14px;border:1px solid #e9dcc7;border-radius:26px;background:linear-gradient(180deg,#fff,#fffaf4);box-shadow:0 6px 18px rgba(94,67,42,.05);text-align:left;cursor:pointer;transition:transform .17s ease,box-shadow .17s ease,border-color .17s ease,background-color .17s ease,opacity .17s ease;-webkit-tap-highlight-color:transparent}.starter-emoji{align-self:end;margin-left:auto;font-size:34px}.starter-card strong{margin-top:auto;font-size:17px;line-height:1.02;color:#1e1c1a;text-align:left}.starter-card-style{min-height:86px;grid-template-columns:auto 1fr;align-items:center}.starter-card-style .starter-emoji{align-self:center;margin-left:0}.chat-panel{display:grid;grid-gap:8px;gap:8px;width:min(620px,100%);margin:10px auto 0;min-height:104px}.chat-row{display:flex}.chat-row-user{justify-content:flex-end}.chat-row-assistant{justify-content:flex-start}.chat-bubble{max-width:min(520px,100%);padding:10px 14px;border-radius:14px;box-shadow:0 1px 0 rgba(255,255,255,.8);font-size:15px;line-height:1.35}.chat-bubble-typing{min-width:76px;color:#b06a5a}.typing-dots{display:inline-flex;letter-spacing:.12em;animation:typingBlink 1s steps(2) infinite}.chat-bubble-assistant{background:#fff;color:#231f1c}.chat-bubble-user{background:#f2634f;color:#fff}.hero-divider{margin:24px 0 0;color:#ada19a;font-size:28px;font-weight:800;letter-spacing:.06em}.input-shell{display:grid;grid-template-columns:1fr 52px 52px;grid-gap:8px;gap:8px;align-items:center;width:min(760px,100%);margin:18px auto 0;padding:10px 12px;border:1px solid #d9cbbb;border-radius:24px;background:#fff;box-shadow:0 14px 36px rgba(102,74,42,.12)}.input-shell input{min-width:0;border:0;padding:6px 8px 6px 6px;font-size:15px;outline:none;background:transparent}.mic-button,.send-button{display:grid;place-items:center;width:44px;height:44px;border:1px solid #f1b0a5;border-radius:14px;background:#fff;color:var(--accent);font-size:22px;cursor:pointer;box-shadow:0 1px 0 rgba(255,255,255,.85),0 4px 10px rgba(0,0,0,.04);transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease;-webkit-tap-highlight-color:transparent}.send-button{border-color:#d2cdc7;background:#efeae2;color:#4b4038}.button:hover,button:hover{transform:translateY(-1px)}button:disabled,input:disabled{cursor:not-allowed;opacity:.58}.button:active,.mic-button:active,.profile-button:active,.send-button:active,.starter-card:active,button:active{transform:translateY(1px) scale(.98);box-shadow:0 1px 2px rgba(0,0,0,.06)}.starter-card:hover{border-color:#ddcdb7;box-shadow:0 10px 24px rgba(94,67,42,.08);background:linear-gradient(180deg,#fff,#fff8ef)}.button:focus-visible,.mic-button:focus-visible,.profile-button:focus-visible,.send-button:focus-visible,.starter-card:focus-visible,button:focus-visible{outline:3px solid rgba(255,106,87,.28);outline-offset:2px}.mic-button:hover,.profile-button:hover{border-color:#e59d8f;box-shadow:0 4px 12px rgba(0,0,0,.06)}.send-button:hover{background:#e6e1d8;border-color:#c7c0b9}.mic-button span,.send-button{color:#111}@keyframes typingBlink{0%,49%{opacity:.3}50%,to{opacity:1}}.confirm-primary,.confirm-secondary,.ghost-pill,.selected-chip,.starter-card span,.starter-card strong{font-feature-settings:"kern" 1;letter-spacing:0}.selected-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;min-height:30px}.selected-chip{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;background:#f07a67;color:#fff;font-weight:700;font-size:14px}.selected-chip-muted{background:#fff;color:#2d2825;border:1px solid #e5d6c4}.confirm-modal{position:relative;width:min(430px,calc(100vw - 32px));padding:28px 24px 22px;border-radius:22px;background:#fff;box-shadow:0 28px 80px rgba(61,42,25,.24)}.confirm-modal h2{margin:0 0 20px;font-size:28px;line-height:1.06;letter-spacing:-.03em}.confirm-primary,.confirm-secondary{display:grid;width:100%;min-height:62px;place-items:center;border-radius:14px;border:0;font-size:18px;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,color .16s ease}.confirm-primary{margin-bottom:12px;background:#ef7a66;color:#fff}.confirm-secondary{background:#fff;color:#7b6f66;border:2px solid #e0e4ea}.modal-close{position:absolute;top:16px;right:16px;border:0;background:transparent;color:#666;font-size:28px;cursor:pointer}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;background:rgba(46,36,26,.38);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-modal button:active,.confirm-primary:active,.confirm-secondary:active,.ghost-pill:active{transform:translateY(1px) scale(.99)}.hero-footer{margin:14px 0 0;color:#9b8f83;font-size:12px;line-height:1.4}.songs-page{max-width:1040px}.songs-grid{display:grid;grid-gap:14px;gap:14px;padding-top:18px}.empty-state{display:grid;justify-items:start;grid-gap:12px;gap:12px}.empty-state h1{margin:0;font-size:28px;line-height:1.05}.song-card{display:grid;grid-gap:14px;gap:14px;padding:18px;border:1px solid #e5d8c8;border-radius:8px;background:#fff;box-shadow:0 8px 24px rgba(94,67,42,.06)}.song-card-header{display:flex;justify-content:space-between;gap:14px}.song-card h2{margin:2px 0 0;font-size:22px;line-height:1.1}.song-status{margin:0;color:#2a7a57;font-size:13px;font-weight:800;line-height:1.2;text-transform:uppercase}.song-card-failed .song-status,.song-card-needs_support .song-status{color:#b93526}.song-count{display:grid;place-items:center;flex:0 0 auto;width:48px;height:48px;border-radius:50%;background:#fff4ec;color:#a94f3f;font-weight:900}.song-style{margin:0;color:#66584e}.progress-line{position:relative;height:8px;overflow:hidden;border-radius:999px;background:#f1e4d4}.progress-line span{position:absolute;inset:0 auto 0 0;width:42%;border-radius:inherit;background:#f07a67;animation:progressSlide 1.6s ease-in-out infinite}.track-list{display:flex;flex-wrap:wrap;gap:10px}.track-link{display:inline-flex;align-items:center;min-height:44px;padding:0 14px;border-radius:8px;background:#2d2825;color:#fff;font-weight:800;text-decoration:none}@keyframes progressSlide{0%{transform:translateX(-110%)}50%{transform:translateX(70%)}to{transform:translateX(250%)}}.card,.panel{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:20px}label{display:grid;grid-gap:6px;gap:6px;font-weight:700;font-size:14px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:12px;font:inherit;background:#fff;color:var(--ink)}textarea{min-height:150px;resize:vertical}.button,button{display:inline-flex;justify-content:center;align-items:center;min-height:44px;padding:0 16px;border:0;border-radius:8px;background:var(--accent);color:#fff;font-weight:800;cursor:pointer;text-decoration:none;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease,color .16s ease}.button.secondary,button.secondary{background:#fff;color:var(--ink);border:1px solid var(--line)}.status{padding:10px 12px;border-radius:8px;background:#fff3d7;color:#6c4b00;font-size:14px}.success{background:#e4f5ec;color:var(--green)}pre{white-space:pre-wrap;overflow-wrap:anywhere;background:#111;color:#f8f8f8;padding:14px;border-radius:8px;font-size:13px}@media (max-width:800px){.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{align-self:flex-end}.starter-grid{grid-template-columns:1fr}.input-shell{grid-template-columns:1fr 46px 46px;width:100%}.starter-card{min-height:150px}.starter-card-style{min-height:72px}.hero-intro{font-size:22px}.hero-subtitle{font-size:16px}}