html{scroll-behavior:smooth}body{color:#7a5c6e;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fef7f9;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;overflow-x:hidden}button{font-family:inherit}a{color:inherit;text-decoration:none}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fef7f9;--bg2:#fff0f5;--bg3:#fff8fa;--surface:#fff;--border:#f0d4e0;--border-light:#f8e8ef;--text:#7a5c6e;--text-bright:#3d2a35;--accent:#e86bac;--accent2:#a87be5;--accent3:#f5a0c0;--accent4:#8bc8f0;--pink:#f7c0d8;--lavender:#d8c0f0;--mint:#c0f0e0;--peach:#f0d8c0;--sky:#c0ddf0;--shadow-sm:0 2px 8px #e86bac1a;--shadow-md:0 8px 30px #e86bac1f;--shadow-lg:0 16px 50px #e86bac26}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;overflow-x:hidden}.grain{pointer-events:none;z-index:9999;background-image:radial-gradient(circle at 20% 30%,#e86bac08 0%,#0000 50%),radial-gradient(circle at 80% 70%,#a87be508 0%,#0000 50%),radial-gradient(circle,#f5a0c005 0%,#0000 70%);position:fixed;inset:0}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)rotate(0)}50%{opacity:1;transform:scale(1)rotate(180deg)}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-15px)rotate(5deg)}}@keyframes floatSlow{0%,to{transform:translateY(0)rotate(0)}33%{transform:translateY(-10px)rotate(-3deg)}66%{transform:translateY(5px)rotate(3deg)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(0)rotate(-12deg)}60%{transform:scale(1.1)rotate(3deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes rainbowBorder{0%{border-color:var(--pink)}25%{border-color:var(--lavender)}50%{border-color:var(--mint)}75%{border-color:var(--sky)}to{border-color:var(--pink)}}.app{max-width:900px;min-height:100vh;margin:0 auto;padding:0 24px;position:relative}.flowers{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.flower{opacity:.15;font-size:24px;animation:8s ease-in-out infinite floatSlow;position:absolute}.flower:first-child{font-size:28px;animation-delay:0s;top:5%;left:8%}.flower:nth-child(2){font-size:20px;animation-delay:1.5s;top:15%;right:12%}.flower:nth-child(3){animation-delay:3s;top:35%;left:5%}.flower:nth-child(4){font-size:32px;animation-delay:.8s;top:55%;right:8%}.flower:nth-child(5){font-size:18px;animation-delay:2.2s;top:75%;left:15%}.flower:nth-child(6){animation-delay:4s;top:85%;right:18%}.flower:nth-child(7){font-size:22px;animation-delay:1s;top:45%;left:90%}.flower:nth-child(8){font-size:16px;animation-delay:3.5s;top:25%;left:85%}.sparkles{pointer-events:none;z-index:1;position:fixed;inset:0;overflow:hidden}.sparkle-dot{background:var(--accent);border-radius:50%;width:4px;height:4px;animation:3s ease-in-out infinite sparkle;position:absolute}.sparkle-dot:first-child{background:var(--pink);animation-delay:0s;top:10%;left:20%}.sparkle-dot:nth-child(2){background:var(--lavender);width:3px;height:3px;animation-delay:.5s;top:20%;left:70%}.sparkle-dot:nth-child(3){background:var(--accent);animation-delay:1s;top:40%;left:15%}.sparkle-dot:nth-child(4){background:var(--mint);width:5px;height:5px;animation-delay:1.5s;top:60%;left:80%}.sparkle-dot:nth-child(5){background:var(--peach);animation-delay:2s;top:30%;left:50%}.sparkle-dot:nth-child(6){background:var(--lavender);width:3px;height:3px;animation-delay:2.5s;top:70%;left:35%}.sparkle-dot:nth-child(7){background:var(--pink);animation-delay:.7s;top:80%;left:60%}.sparkle-dot:nth-child(8){background:var(--sky);width:5px;height:5px;animation-delay:1.2s;top:50%;left:90%}.sparkle-dot:nth-child(9){background:var(--accent3);animation-delay:1.8s;top:15%;left:40%}.sparkle-dot:nth-child(10){background:var(--lavender);animation-delay:.3s;top:90%;left:25%}.sparkle-star{width:12px;height:12px;animation:4s ease-in-out infinite sparkle;position:absolute}.sparkle-star:before,.sparkle-star:after{content:"";background:var(--accent3);border-radius:2px;position:absolute}.sparkle-star:before{width:100%;height:2px;top:50%;transform:translateY(-50%)}.sparkle-star:after{width:2px;height:100%;left:50%;transform:translate(-50%)}.sparkle-star:nth-child(11){animation-delay:.4s;top:25%;left:30%}.sparkle-star:nth-child(12){animation-delay:1.7s;top:55%;left:75%}.sparkle-star:nth-child(13){animation-delay:2.8s;top:75%;left:45%}.sparkle-star:nth-child(14){animation-delay:3.2s;top:5%;left:65%}.hero{text-align:center;z-index:2;padding:80px 0 60px;position:relative}.hero-badge{background:linear-gradient(135deg, var(--pink), var(--lavender));letter-spacing:2px;color:#fff;text-transform:uppercase;box-shadow:var(--shadow-sm);border-radius:100px;margin-bottom:32px;padding:8px 20px;font-size:11px;font-weight:700;animation:6s ease-in-out infinite float;display:inline-block}.hero-title{color:var(--text-bright);letter-spacing:-2px;margin-bottom:24px;font-size:clamp(48px,10vw,80px);font-weight:900;line-height:.95}.hero-accent{background:linear-gradient(135deg, var(--accent), var(--accent2), var(--accent3));-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:4s linear infinite shimmer}.hero-sub{color:var(--text);max-width:400px;margin:0 auto;font-size:18px}.hero-emoji{margin-bottom:16px;font-size:48px;animation:4s ease-in-out infinite float;display:block}.picker-section{z-index:2;padding-bottom:60px;position:relative}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.section-title{letter-spacing:3px;text-transform:uppercase;color:var(--text);font-size:14px;font-weight:700}.selection-count{gap:8px;display:flex}.selection-pill{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;white-space:nowrap;border-radius:100px;padding:5px 16px;font-size:12px;font-weight:700;animation:.3s ease-out popIn;box-shadow:0 2px 10px #e86bac40}.selection-pill.empty{background:var(--surface);color:var(--border);border:2px dashed var(--border);box-shadow:none}.artist-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-bottom:32px;display:grid}.artist-card{background:var(--surface);border:2px solid var(--border-light);cursor:pointer;text-align:center;color:inherit;box-shadow:var(--shadow-sm);border-radius:16px;flex-direction:column;padding:0;font-family:inherit;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;overflow:hidden}.artist-card:hover{border-color:var(--pink);box-shadow:var(--shadow-md);transform:translateY(-4px)rotate(-1deg)}.artist-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px #e86bac26, var(--shadow-md);animation:3s linear infinite rainbowBorder;transform:translateY(-2px)}.artist-card.disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.artist-img-wrap{aspect-ratio:1;background:var(--bg2);position:relative;overflow:hidden}.artist-img{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.artist-card:hover .artist-img{transform:scale(1.08)}.artist-card.selected .artist-img{filter:brightness(.8)saturate(1.2)}.artist-img-fallback{background:linear-gradient(135deg, var(--pink), var(--lavender));width:100%;height:100%}.artist-check{color:#fff;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#e86bac33;justify-content:center;align-items:center;font-size:36px;font-weight:900;animation:.4s ease-out bounceIn;display:flex;position:absolute;inset:0}.artist-name{color:var(--text-bright);white-space:nowrap;text-overflow:ellipsis;padding:10px 8px;font-size:13px;font-weight:700;overflow:hidden}.actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.btn-generate{letter-spacing:2px;background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;cursor:pointer;border:none;border-radius:100px;padding:16px 40px;font-family:inherit;font-size:14px;font-weight:800;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;box-shadow:0 4px 20px #e86bac4d}.btn-generate:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);transition:transform .6s;position:absolute;inset:0;transform:translate(-100%)}.btn-generate:hover:not(:disabled):before{transform:translate(100%)}.btn-generate:hover:not(:disabled){transform:translateY(-3px)scale(1.02);box-shadow:0 8px 35px #e86bac66}.btn-generate:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-random{border:2px solid var(--border);letter-spacing:2px;background:var(--surface);color:var(--text);cursor:pointer;border-radius:100px;padding:16px 32px;font-family:inherit;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.btn-random:hover{border-color:var(--accent2);color:var(--accent2);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.loading{text-align:center;letter-spacing:2px;text-transform:uppercase;color:var(--accent);padding:60px 0;font-size:14px}.loading:after{content:" ✿";animation:1s ease-in-out infinite wiggle;display:inline-block}.error{text-align:center;color:#e05050;padding:40px}.result-section{border-top:2px dashed var(--border);z-index:2;padding:80px 0;animation:.6s ease-out fadeUp;position:relative}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.result-reveal{text-align:center}.result-label{letter-spacing:4px;color:var(--accent);text-transform:uppercase;margin-bottom:16px;font-size:11px;font-weight:700}.result-name{letter-spacing:-1px;margin-bottom:16px;font-size:clamp(40px,8vw,72px);font-weight:900;line-height:1;animation:.5s ease-out bounceIn}.result-genre{color:var(--text);letter-spacing:1px;margin-bottom:24px;font-size:16px}.result-members{color:var(--text-bright);letter-spacing:1px;margin-bottom:48px;font-size:14px}.members-label{color:var(--accent);letter-spacing:3px;margin-bottom:6px;font-size:10px;display:block}.result-grid{grid-template-columns:1fr 1fr;align-items:start;gap:32px;margin-bottom:48px;display:grid}@media (width<=700px){.result-grid{grid-template-columns:1fr}}.result-album{text-align:center}.result-album canvas{max-width:480px;box-shadow:var(--shadow-lg);border-radius:16px;width:100%!important;height:auto!important}.album-label{letter-spacing:3px;color:var(--text);margin-top:12px;font-size:11px}.tour-poster{background:var(--surface);border:2px solid var(--border-light);text-align:center;box-shadow:var(--shadow-md);border-radius:16px;padding:40px 32px;position:relative;overflow:hidden}.tour-poster:before{content:"";background:linear-gradient(180deg, var(--bg2) 0%, transparent 30%, transparent 70%, var(--bg2) 100%);pointer-events:none;position:absolute;inset:0}.poster-border{z-index:1;position:relative}.poster-label{letter-spacing:3px;color:var(--accent);margin-bottom:24px;font-size:9px;font-weight:600}.poster-title{color:var(--text-bright);letter-spacing:-1px;margin-bottom:8px;font-size:clamp(28px,5vw,40px);font-weight:900;line-height:1}.poster-subtitle{letter-spacing:4px;color:var(--accent);margin-bottom:24px;font-size:14px;font-weight:700}.poster-divider{background:linear-gradient(90deg, var(--pink), var(--lavender));border-radius:2px;width:40px;height:2px;margin:20px auto}.poster-genre{color:var(--text);letter-spacing:1px;margin-bottom:8px;font-size:12px}.poster-cities{flex-direction:column;gap:8px;margin:20px 0;display:flex}.poster-city{border-bottom:1px dashed var(--border-light);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.poster-date{color:var(--accent);letter-spacing:1px;font-size:11px;font-weight:700}.poster-city-name{color:var(--text-bright);letter-spacing:2px;font-size:13px;font-weight:700}.poster-footer{letter-spacing:2px;color:var(--text);margin-top:8px;font-size:9px}.vibe-player{background:var(--surface);border:2px solid var(--border-light);max-width:500px;box-shadow:var(--shadow-md);text-align:center;border-radius:20px;margin:32px auto 48px;padding:24px;position:relative;overflow:hidden}.vibe-player:before{content:"";background:linear-gradient(90deg, var(--pink), var(--accent), var(--lavender), var(--accent2));background-size:200% 100%;height:3px;animation:3s linear infinite shimmer;position:absolute;top:0;left:0;right:0}.vibe-label{letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:12px;font-size:10px;font-weight:700}.vibe-now-playing{color:var(--text-bright);min-height:20px;margin-bottom:16px;font-size:13px;font-weight:600}.vibe-segments{text-align:left;flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.vibe-seg{transition:opacity .3s}.vibe-seg:not(.active):not(.done){opacity:.45}.vibe-seg.done{opacity:.6}.vibe-seg-label{letter-spacing:1px;color:var(--text);margin-bottom:4px;font-size:10px;font-weight:700;transition:color .3s}.vibe-seg.active .vibe-seg-label{color:var(--accent)}.vibe-seg-bar{background:var(--bg2);border-radius:3px;width:100%;height:5px;overflow:hidden}.vibe-seg-fill{background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:3px;height:100%;transition:width .2s linear}.vibe-seg.done .vibe-seg-fill{background:var(--lavender)}.vibe-controls{justify-content:center;align-items:center;gap:16px;display:flex}.vibe-time{color:var(--text);letter-spacing:1px;font-variant-numeric:tabular-nums;font-size:11px}.vibe-btn{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-family:inherit;font-size:18px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:inline-flex;box-shadow:0 4px 20px #e86bac4d}.vibe-btn:hover{transform:scale(1.1);box-shadow:0 6px 25px #e86bac66}.vibe-btn.playing{animation:2s ease-in-out infinite pulse-glow}@keyframes pulse-glow{0%,to{box-shadow:0 4px 20px #e86bac4d}50%{box-shadow:0 4px 30px #e86bac80,0 0 60px #e86bac26}}.vibe-visualizer{justify-content:center;align-items:flex-end;gap:3px;height:32px;margin-bottom:12px;display:flex}.viz-bar{background:linear-gradient(to top, var(--accent), var(--lavender));border-radius:2px;width:4px;min-height:3px;transition:height .15s}.share-section{margin-bottom:48px}.share-card{width:540px;max-width:100%;height:540px;box-shadow:var(--shadow-lg);border-radius:16px;margin:0 auto 20px;position:relative;overflow:hidden}.share-card-inner{width:100%;height:100%;position:relative}.share-album{position:absolute;inset:0}.share-album canvas{display:block;width:100%!important;height:100%!important}.share-overlay{background:linear-gradient(#3c1e324d 0%,#0000 25% 45%,#3c1e328c 70%,#281423d9 100%);flex-direction:column;justify-content:space-between;padding:20px 24px;display:flex;position:absolute;inset:0}.share-top-tag{letter-spacing:2px;color:#fffc;text-transform:uppercase;text-align:left;font-size:9px;font-weight:700}.share-bottom{text-align:left}.share-name{color:#fff;letter-spacing:-.5px;text-shadow:0 2px 12px #0000004d;margin-bottom:6px;font-size:32px;font-weight:900;line-height:1.05}.share-genre{color:#ffffffb3;letter-spacing:.5px;margin-bottom:14px;font-size:12px}.share-artists{gap:12px;display:flex}.share-artist{color:#fff;align-items:center;gap:6px;font-size:11px;font-weight:700;display:flex}.share-artist-img{object-fit:cover;border:2px solid #ffffff80;border-radius:50%;width:26px;height:26px}.share-buttons{justify-content:center;gap:12px;display:flex}.share-btn{letter-spacing:2px;background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;cursor:pointer;border:none;border-radius:100px;padding:12px 28px;font-family:inherit;font-size:12px;font-weight:800;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 12px #e86bac40}.share-btn:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 4px 20px #e86bac59}.share-btn-alt{background:var(--surface);border:2px solid var(--border);color:var(--text);box-shadow:none}.share-btn-alt:hover{border-color:var(--accent);color:var(--accent);box-shadow:none}.btn-reset{border:2px solid var(--border);letter-spacing:2px;background:var(--surface);color:var(--text);cursor:pointer;border-radius:100px;margin-top:24px;padding:14px 36px;font-family:inherit;font-size:12px;font-weight:700;transition:all .3s}.btn-reset:hover{border-color:var(--accent);color:var(--accent)}.footer{border-top:2px dashed var(--border-light);text-align:center;letter-spacing:1px;color:var(--text);z-index:2;justify-content:center;gap:8px;padding:40px 0;font-size:12px;display:flex;position:relative}.footer a{color:var(--accent);font-weight:600;text-decoration:none}.footer a:hover{text-decoration:underline}@media (width<=640px){.app{padding:0 16px}.hero{padding:48px 0 40px}.artist-grid{grid-template-columns:repeat(3,1fr);gap:10px}.share-card{aspect-ratio:1;width:100%;height:auto}.share-artists{flex-direction:column;gap:6px}.vibe-player{margin:24px 16px 32px}}
