@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;550;600;650&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--ink: #1A1626;--paper: #F7F4EF;--lilac: #E9E3FB;--grape: #6B4FD8;--grape-deep: #4A32B0;--mute: #8A8398}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;height:100%}body{font-family:Inter,system-ui,sans-serif;color:var(--ink);background:radial-gradient(140% 60% at 50% 0%,var(--lilac) 0%,var(--paper) 45%)}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-height:100dvh;overflow:hidden}.header{flex-shrink:0;padding:16px 20px;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid rgba(107,79,216,.1);background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.wordmark{display:inline-flex;align-items:center;gap:7px}.spark{color:var(--grape)}.wordmark-main{font-family:Space Grotesk,sans-serif;font-size:19px;font-weight:700;letter-spacing:-.03em}.taste-badge{position:absolute;right:16px;display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:#e0457e;background:#fce7ef;border:1px solid #F3B6CE;padding:4px 9px;border-radius:20px}.chat-area{flex:1;display:flex;flex-direction:column;min-height:0;width:100%;max-width:720px;margin:0 auto}.thread{flex:1;overflow-y:auto;padding:18px 14px 8px;display:flex;flex-direction:column;gap:10px}.row{display:flex;width:100%}.row.user{justify-content:flex-end}.row.assistant{justify-content:flex-start}.bubble{max-width:82%;padding:11px 14px;border-radius:18px;font-size:14.5px;line-height:1.45;word-break:break-word;animation:bubbleIn .28s ease both}.bubble.assistant{background:#ffffffd9;border:1px solid rgba(107,79,216,.13);border-bottom-left-radius:6px;box-shadow:0 6px 20px -14px #4a32b066}.bubble.user{background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;border-bottom-right-radius:6px;box-shadow:0 8px 20px -12px #4a32b099}.bubble.error{background:#fbede0;border:1px solid #F0D4BC;color:#9a5b2e}.bubble-text{white-space:pre-wrap}.bubble-img{width:100%;max-width:240px;border-radius:12px;margin-bottom:8px;display:block}.url-chip{font-size:12.5px;font-weight:500;color:#fff;background:#ffffff2e;padding:5px 10px;border-radius:8px;margin-bottom:8px;display:inline-block}.para{margin:0 0 6px}.list-line{display:flex;gap:9px;align-items:baseline;margin:5px 0;padding:6px 9px;background:#e9e3fb73;border-radius:9px}.list-mark{font-family:Space Grotesk,sans-serif;font-weight:700;color:var(--grape);font-size:13px;flex-shrink:0;min-width:14px}.song-card{display:flex;align-items:center;gap:8px;margin:6px 0;padding:9px 11px;background:linear-gradient(135deg,#6b4fd814,#4a32b00d);border:1px solid rgba(107,79,216,.16);border-radius:11px;flex-wrap:wrap}.song-note{font-size:16px;color:var(--grape);flex-shrink:0}.song-info{display:flex;flex-direction:column;gap:1px;flex:1 1 120px;min-width:0}.song-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist{font-size:12.5px;color:var(--mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-mood{font-size:11px;color:var(--grape-deep);background:#ffffffb3;padding:3px 8px;border-radius:7px;font-weight:500;flex-shrink:0}.like-btn{flex-shrink:0;width:28px;height:28px;border-radius:8px;background:#fff9;border:1px solid rgba(107,79,216,.18);display:grid;place-items:center;cursor:pointer;color:#b0a9be;transition:all .15s}.like-btn.liked{background:#fce7ef;border-color:#f3b6ce;color:#e0457e}.typing{display:flex;gap:4px;padding:14px 16px}.d{width:6px;height:6px;border-radius:50%;background:var(--grape);opacity:.4;animation:blink 1.3s infinite}.d:nth-child(2){animation-delay:.2s}.d:nth-child(3){animation-delay:.4s}.staged-wrap{flex-shrink:0;padding:0 14px}.staged{display:inline-flex;align-items:center;gap:9px;background:#ffffffe6;border:1px solid rgba(107,79,216,.18);border-radius:12px;padding:6px 8px 6px 6px;margin-bottom:8px}.staged-img{width:34px;height:34px;border-radius:7px;object-fit:cover}.staged-url-icon{width:34px;height:34px;border-radius:7px;background:var(--lilac);display:grid;place-items:center;font-size:16px}.staged-label{font-size:12.5px;color:var(--mute);font-weight:500}.staged-remove{width:22px;height:22px;border-radius:50%;background:#1a16261a;border:none;display:grid;place-items:center;cursor:pointer;color:var(--ink)}.url-panel{flex-shrink:0;display:flex;align-items:center;gap:7px;padding:0 14px 8px}.url-input{flex:1;border:1px solid rgba(107,79,216,.25);border-radius:11px;background:#fff;padding:9px 12px;font-size:13.5px;font-family:inherit;color:var(--ink);outline:none}.url-go{flex-shrink:0;height:36px;padding:0 14px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:grid;place-items:center}.url-go:disabled{background:#6b4fd847;cursor:not-allowed}.url-close{flex-shrink:0;width:32px;height:32px;border-radius:9px;background:#1a162612;border:none;display:grid;place-items:center;cursor:pointer;color:var(--ink)}.composer{flex-shrink:0;display:flex;align-items:flex-end;gap:8px;padding:10px 14px calc(12px + env(safe-area-inset-bottom,0px));background:#ffffffb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(107,79,216,.12)}.attach-btn,.link-btn{flex-shrink:0;width:42px;height:42px;border-radius:13px;background:var(--lilac);color:var(--grape-deep);display:grid;place-items:center;cursor:pointer;border:none}.attach-btn{position:relative;overflow:hidden}.file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;font-size:0}.composer-input{flex:1;border:1px solid rgba(107,79,216,.2);border-radius:14px;background:#fff;padding:11px 14px;font-size:14.5px;font-family:inherit;color:var(--ink);resize:none;outline:none;line-height:1.4;max-height:120px;min-height:42px}.send-btn{flex-shrink:0;width:42px;height:42px;border-radius:13px;border:none;background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 18px -10px #4a32b0b3}.send-btn:disabled{background:#6b4fd847;box-shadow:none;cursor:not-allowed}.composer-input:focus,.url-input:focus{border-color:#6b4fd873}.composer-input::placeholder,.url-input::placeholder{color:#b0a9be}button:active:not(:disabled){transform:scale(.96)}@media (min-width: 721px){.chat-area{border-left:1px solid rgba(107,79,216,.1);border-right:1px solid rgba(107,79,216,.1);background:#ffffff40}.thread{padding:26px 24px 14px;gap:16px}.bubble{max-width:76%;font-size:15px}.composer{padding:14px 20px 18px}}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bubbleIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}@keyframes blink{0%,80%,to{opacity:.25}40%{opacity:.9}}@media (prefers-reduced-motion: reduce){*{animation:none!important}}.preview-btn{flex-shrink:0;padding:5px 11px;border-radius:8px;border:none;background:var(--grape);color:#fff;font-size:12px;font-weight:650;cursor:pointer;font-family:inherit}.preview-btn:hover{background:var(--grape-deep)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:linear-gradient(160deg,#e9e3fb,#c9bef0 55%,#b3a4e8);display:grid;place-items:center;padding:24px;animation:fadeIn .2s ease}.polaroid{position:relative;background:#fdfcfa;padding:14px 14px 0;border-radius:6px;box-shadow:0 24px 60px -18px #4a32b08c;transform:rotate(-2deg);width:300px;max-width:86vw;animation:polaroidRise .35s cubic-bezier(.2,.8,.2,1)}.story-close{position:absolute;top:-14px;right:-14px;z-index:5;width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;border:none;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 16px -6px #00000080}.polaroid-photo{width:100%;aspect-ratio:1 / 1;border-radius:2px;overflow:hidden;background:#2a2440}.polaroid-photo img{width:100%;height:100%;object-fit:cover;display:block}.polaroid-nophoto{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:#fff9}.polaroid-nophoto span:first-child{font-size:15px;font-weight:600}.polaroid-nophoto-sub{font-size:11.5px;opacity:.7}.polaroid-strip{padding:12px 4px 16px}.pola-sticker{display:inline-flex;align-items:center;gap:8px;background:#f1ecfb;border:.5px solid #D9CEF4;border-radius:9px;padding:5px 9px;margin-bottom:10px;max-width:100%}.pola-sticker-icon{width:22px;height:22px;border-radius:6px;flex-shrink:0;background:var(--grape);color:#fff;display:grid;place-items:center}.pola-sticker-info{display:flex;flex-direction:column;line-height:1.15;min-width:0}.pola-sticker-title{font-size:11.5px;font-weight:600;color:#26215c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pola-sticker-artist{font-size:10px;color:#7a719c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pola-play{width:20px;height:20px;border-radius:50%;flex-shrink:0;border:none;background:var(--grape);color:#fff;display:grid;place-items:center;cursor:pointer;margin-left:2px}.pola-play.loading{background:#6b4fd866}.pola-unavailable,a.pola-unavailable{text-decoration:none;flex-shrink:0;font-size:10px;font-weight:600;color:var(--grape-deep);background:#fff;padding:4px 8px;border-radius:7px;margin-left:2px}.polaroid-caption{font-family:Fraunces,Georgia,serif;font-style:italic;font-weight:400;font-size:17px;color:#2a2440;line-height:1.3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes polaroidRise{0%{opacity:0;transform:translateY(20px) rotate(-2deg) scale(.95)}to{opacity:1;transform:rotate(-2deg) scale(1)}}.about-btn{position:absolute;left:16px;width:34px;height:34px;border-radius:10px;background:var(--lilac);color:var(--grape-deep);border:none;display:grid;place-items:center;cursor:pointer}.about-overlay{background:#14101e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.about-card{position:relative;background:#fff;border-radius:22px;padding:32px 26px 26px;width:340px;max-width:88vw;text-align:center;box-shadow:0 30px 70px -20px #4a32b080;animation:polaroidRise .3s ease}.about-close{background:var(--ink)}.about-mark{width:56px;height:56px;border-radius:16px;margin:0 auto 14px;background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;display:grid;place-items:center;border:none;cursor:pointer;transition:transform .15s ease}.about-mark:active{transform:scale(.92)}.about-mark.confirming{background:linear-gradient(135deg,#e0447c,#b0245a)}.about-reset-hint{font-size:11.5px;color:var(--grape-deep);margin:-8px 0 12px;font-weight:550}.about-title{font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700;letter-spacing:-.03em;margin:0 0 4px;color:var(--ink)}.about-tagline{font-size:13px;color:var(--mute);margin:0 0 16px}.about-body{font-size:14px;line-height:1.55;color:var(--ink);margin:0 0 18px}.about-divider{height:1px;background:#6b4fd824;margin:0 0 16px}.about-credit{font-size:14px;color:var(--ink);margin:0 0 14px}.about-credit strong{font-weight:650;color:var(--grape-deep)}.about-feedback{display:inline-block;font-size:13.5px;font-weight:600;text-decoration:none;color:#fff;background:linear-gradient(135deg,var(--grape),var(--grape-deep));padding:10px 20px;border-radius:12px}.post-ig-btn{width:100%;margin-top:14px;padding:11px;border-radius:11px;border:none;background:linear-gradient(135deg,#6b4fd8,#4a32b0);color:#fff;font-size:14px;font-weight:650;font-family:inherit;cursor:pointer;box-shadow:0 8px 18px -10px #4a32b0b3}.post-ig-btn:disabled{opacity:.7;cursor:default}.post-ig-hint{margin:9px 2px 0;font-size:10.5px;line-height:1.4;color:#8a8398;text-align:center}.post-ig-hint strong{color:#4a32b0;font-weight:600}.wm-y{color:#6b4fd8}.wm-ai{background:linear-gradient(45deg,#ff8a5c,#e0447c,#8b5cf6,#4a32b0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;font-weight:700}.about-title .wm-y{color:#6b4fd8}.copy-btn{flex-shrink:0;margin-left:6px;width:24px;height:24px;border-radius:7px;border:none;background:#6b4fd81a;color:var(--grape-deep);display:inline-grid;place-items:center;cursor:pointer;vertical-align:middle}.copy-btn.copied{background:#dff5e4;color:#1e7a3c}.list-line{display:flex;align-items:baseline}.list-text{flex:1}.song-art{width:38px;height:38px;border-radius:9px;object-fit:cover;flex-shrink:0;box-shadow:0 4px 10px -4px #1a162659}.vibe-chips{display:flex;flex-wrap:wrap;gap:8px;padding:4px 2px 10px;animation:bubbleIn .35s ease both}.vibe-chip{border:1px solid rgba(107,79,216,.25);background:#ffffffbf;color:var(--grape-deep);font-size:13px;font-weight:550;font-family:inherit;padding:8px 13px;border-radius:999px;cursor:pointer}.vibe-chip:hover{background:var(--lilac)}.regen-wrap{display:flex;justify-content:flex-start;padding:0 2px 8px}.regen-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(107,79,216,.25);background:#ffffffbf;color:var(--grape-deep);font-size:12.5px;font-weight:600;font-family:inherit;padding:7px 12px;border-radius:999px;cursor:pointer}.regen-btn:hover{background:var(--lilac)}.typing-label{font-size:12.5px;color:var(--mute);margin-right:7px}.bubble.typing{display:inline-flex;align-items:center}.theme-btn{position:absolute;left:58px;width:34px;height:34px;border-radius:10px;background:var(--lilac);color:var(--grape-deep);border:none;display:grid;place-items:center;cursor:pointer}[data-theme=dark]{--ink: #ECE8F6;--paper: #16121F;--lilac: #262038;--mute: #9A92B2}[data-theme=dark] body{background:radial-gradient(140% 60% at 50% 0%,#221b36,#16121f 45%)}[data-theme=dark] .bubble.assistant{background:#28223aeb;border-color:#8c73eb38;box-shadow:0 6px 20px -14px #0009}[data-theme=dark] .bubble.error{background:#3a2a1c;border-color:#5a4128;color:#e8b888}[data-theme=dark] .header{background:#16121fbf;border-color:#8c73eb26}[data-theme=dark] .wordmark-main{color:var(--ink)}[data-theme=dark] .composer{background:#16121fd9;border-color:#8c73eb26}[data-theme=dark] .composer-input{background:#28223ae6;color:var(--ink)}[data-theme=dark] .composer-input::placeholder{color:var(--mute)}[data-theme=dark] .url-input{background:#28223ae6;color:var(--ink)}[data-theme=dark] .song-card{background:#6b4fd824;border-color:#8c73eb38}[data-theme=dark] .song-mood{background:#28223ad9;color:#c9bcf2}[data-theme=dark] .vibe-chip,[data-theme=dark] .regen-btn{background:#28223ad9;color:#c9bcf2;border-color:#8c73eb4d}[data-theme=dark] .copy-btn{background:#8c73eb2e;color:#c9bcf2}[data-theme=dark] .copy-btn.copied{background:#1e3a28;color:#7ed99a}.filter-row{display:flex;gap:8px;overflow-x:auto;padding:8px 2px 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-row::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;border:none;background:none;cursor:pointer;padding:0;font-family:inherit}.filter-chip img{width:52px;height:52px;border-radius:10px;object-fit:cover;border:2px solid transparent;transition:border-color .15s ease}.filter-chip.active img{border-color:var(--grape)}.filter-chip span{font-size:10.5px;color:var(--mute);font-weight:550}.filter-chip.active span{color:var(--grape-deep)}[data-theme=dark] .filter-chip.active img{border-color:#8b5cf6}
