:root{--mono:ui-monospace, Consolas, monospace;font-synthesis:none;text-rendering:optimizelegibility}#root{box-sizing:border-box;width:100%;max-width:100%;min-height:100svh}body,p{margin:0}code{font-family:var(--mono);border-radius:4px;padding:4px 8px;font-size:15px;line-height:135%}:root{--up-maroon:#7b1113;--up-maroon-deep:#0c0103;--up-maroon-mid:#1a0306;--up-maroon-surface:#ffffff0d;--up-maroon-border:#ffcd001f;--up-gold:#ffcd00;--up-gold-dim:#ffcd001f;--up-green:#014421;--cream:#fdf6ee;--cream-muted:#fdf6ee80;--cream-faint:#fdf6ee12;--font-display:"DM Serif Display", Georgia, serif;--font-sans:"Plus Jakarta Sans", system-ui, sans-serif;--radius-sm:8px;--radius:16px;--radius-lg:28px;--glass-bg:#120204a6;--shadow-card:0 24px 64px #0009, 0 4px 16px #0000004d}*{box-sizing:border-box}body{background-color:var(--up-maroon-deep);color:var(--cream);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;overflow-x:hidden}h1,h2,h3{font-family:var(--font-display);color:var(--cream);font-weight:400}.app-wrapper{min-height:100vh;position:relative;overflow:hidden}.app-wrapper:before,.app-wrapper:after{content:"";filter:blur(120px);pointer-events:none;z-index:0;border-radius:50%;position:fixed}.app-wrapper:before{background:radial-gradient(circle,#7b111373 0%,#0000 70%);width:600px;height:600px;top:-200px;left:-150px}.app-wrapper:after{background:radial-gradient(circle,#5a080a59 0%,#0000 70%);width:500px;height:500px;bottom:-100px;right:-100px}.grain{z-index:1;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px;position:fixed;inset:0}.app-container{z-index:2;flex-direction:column;max-width:560px;min-height:100vh;margin:0 auto;padding:3rem 1.25rem 2rem;display:flex;position:relative}.header{text-align:center;margin-bottom:3rem;animation:.7s cubic-bezier(.16,1,.3,1) both slideDown}.logo{background:var(--up-gold-dim);border:1px solid #ffcd0033;border-radius:100px;align-items:center;gap:.6rem;margin-bottom:.75rem;padding:.4rem 1rem .4rem .75rem;display:inline-flex}.logo-icon{width:18px;height:18px;color:var(--up-gold)}.logo-label{font-family:var(--font-sans);letter-spacing:.08em;text-transform:uppercase;color:var(--up-gold);font-size:.78rem;font-weight:600}.header-title{font-family:var(--font-display);letter-spacing:-.5px;color:var(--cream);margin:0 0 .75rem;font-size:clamp(2.4rem,8vw,3.2rem);line-height:1.1}.header-title em{color:var(--up-gold);font-style:italic}.subtitle{color:var(--cream-muted);letter-spacing:.01em;margin:0;font-size:.95rem;font-weight:400}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--cream-faint);margin-bottom:1.25rem;padding:2rem;position:relative;overflow:hidden}.card:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffcd000a 0%,#0000 60%);position:absolute;inset:0}.prompt-section{animation:.6s cubic-bezier(.16,1,.3,1) .15s both fadeUp}.prompt-heading{font-family:var(--font-display);color:var(--cream);text-align:center;margin:0 0 1.5rem;font-size:1.5rem;font-style:italic;line-height:1.3}.input-group{flex-direction:column;gap:.875rem;display:flex}textarea{border-radius:var(--radius);border:1px solid var(--cream-faint);width:100%;height:110px;color:var(--cream);font-family:var(--font-sans);resize:none;background:#fdf6ee0a;outline:none;padding:1rem 1.1rem;font-size:1rem;line-height:1.6;transition:border-color .2s,background .2s}textarea::placeholder{color:var(--cream-muted)}textarea:focus{background:#fdf6ee0f;border-color:#ffcd0066}.primary-button{background:var(--up-gold);color:#1a0306;border-radius:var(--radius);font-family:var(--font-sans);cursor:pointer;letter-spacing:.02em;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.9rem 1.25rem;font-size:.95rem;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;display:flex;box-shadow:0 4px 20px #ffcd0040}.primary-button:hover{background:#ffe033;transform:translateY(-1px);box-shadow:0 6px 28px #ffcd0066}.primary-button:active{transform:scale(.98)translateY(0)}.primary-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.hint{text-align:center;color:var(--cream-muted);letter-spacing:.01em;margin-top:.25rem;font-size:.8rem}.result-section{animation:.55s cubic-bezier(.16,1,.3,1) both fadeUp}.song-display{position:relative}.song-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.song-icon-wrap{background:var(--up-gold-dim);border:1px solid #ffcd0033;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.music-icon{color:var(--up-gold)}.song-meta h3{font-family:var(--font-display);color:var(--cream);margin:0 0 .2rem;font-size:1.25rem}.song-meta p{color:var(--cream-muted);margin:0;font-size:.85rem;font-weight:500}.spotify-container{border-radius:var(--radius-sm);opacity:.9;margin-bottom:1.5rem;overflow:hidden}.spotify-container iframe{border-radius:var(--radius-sm);display:block}.lyrics-snippet{border-left:3px solid var(--up-gold);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;font-family:var(--font-display);color:#fdf6eed9;background:#ffcd000d;padding:1rem 1.2rem;font-size:1.05rem;line-height:1.6}.note-section{text-align:center}.note-section-title{font-family:var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--cream-muted);margin:0 0 1.25rem;font-size:.75rem;font-weight:700}.note-preview-label{color:var(--cream-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.6rem;font-size:.7rem;font-weight:500}.note-bubble-wrap{justify-content:center;margin-bottom:1.5rem;display:flex}.note-bubble{background:#fdf6ee14;border:1px solid #fdf6ee1f;border-radius:100px;align-items:center;gap:.6rem;max-width:90%;padding:.55rem 1.1rem .55rem .65rem;display:inline-flex;position:relative}.note-bubble:after{content:"";clip-path:polygon(0 0,100% 0,50% 100%);background:#fdf6ee14;width:12px;height:7px;position:absolute;bottom:-7px;left:18px}.avatar-placeholder{background:linear-gradient(135deg, var(--up-maroon) 0%, #3d0608 100%);border:2px solid #ffcd004d;border-radius:50%;flex-shrink:0;width:36px;height:36px}.bubble-content{color:var(--cream);text-align:left;font-size:.9rem;font-weight:500;line-height:1.4}.action-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.copy-button{color:#4ade80;font-family:var(--font-sans);cursor:pointer;background:#01442180;border:1px solid #4ade8040;border-radius:100px;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-size:.875rem;font-weight:600;transition:background .2s,border-color .2s,transform .15s;display:flex}.copy-button:hover{background:#014421b3;border-color:#4ade8073;transform:translateY(-1px)}.copy-button.copied{color:#86efac;background:#014421b3}.secondary-button{border:1px solid var(--cream-faint);color:var(--cream-muted);font-family:var(--font-sans);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-size:.875rem;font-weight:500;transition:border-color .2s,color .2s,transform .15s;display:flex}.secondary-button:hover{color:var(--cream);border-color:#fdf6ee40;transform:translateY(-1px)}.footer{text-align:center;color:var(--cream-muted);letter-spacing:.03em;padding:2rem 0 1rem;font-size:.78rem}.ai-insight{background:linear-gradient(135deg,#ffcd000d 0%,#7b11131a 100%);border:1px solid #ffcd0026;margin-bottom:1.5rem}.ai-insight-header{color:var(--up-gold);font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;font-weight:700;display:flex}.ai-icon{animation:2s infinite pulse}.ai-insight p{color:var(--cream);margin:0;font-size:1.05rem;font-style:italic;line-height:1.5}.spotify-search-link{color:#fff;border-radius:var(--radius-sm);background:#1db954;justify-content:center;align-items:center;gap:.6rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s,transform .15s;display:flex}.spotify-search-link:hover{background:#1ed760;transform:translateY(-1px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:.5s ease-out forwards fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=480px){.app-container{padding:2rem 1rem 1.5rem}.header-title{font-size:2.2rem}.card{padding:1.5rem}.action-buttons{flex-direction:column;align-items:stretch}.copy-button,.secondary-button{justify-content:center}}
