.app{position:relative;min-height:100vh;padding:2rem 1.25rem 3rem;overflow:hidden}.bg-glow{position:fixed;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}.bg-glow-a{width:420px;height:420px;top:-120px;right:-80px;background:#9b7ede38}.bg-glow-b{width:360px;height:360px;bottom:-100px;left:-60px;background:#e879a829}.header,.steps,.main,.footer{position:relative;z-index:1;max-width:760px;margin-inline:auto}.main:has(.player-panel),.main:has(.gallery-radio){max-width:920px}.header{margin-bottom:2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.locale-switcher{display:flex;padding:.2rem;border-radius:10px;border:1px solid var(--surface-border);background:#00000040}.locale-switcher-btn{padding:.4rem .65rem;border:none;border-radius:7px;background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.locale-switcher-btn:hover{color:var(--text)}.locale-switcher-btn.active{background:var(--accent-soft);color:var(--text)}.brand{display:flex;align-items:center;gap:1rem}.brand-mark{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent-2));font-family:var(--font-display);font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:#fff;box-shadow:0 8px 32px #e879a859}.brand h1{margin:0;font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:-.02em}.brand p{margin:.15rem 0 0;color:var(--text-muted);font-size:.92rem}.steps{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.step-pill{display:flex;align-items:center;gap:.45rem;padding:.45rem .85rem;border-radius:999px;border:1px solid var(--surface-border);color:var(--text-muted);font-size:.85rem;background:#ffffff05;transition:all .2s ease}.step-pill.active{color:var(--text);border-color:#e879a859;background:var(--accent-soft)}.step-pill.current .step-num{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.step-num{display:grid;place-items:center;width:1.35rem;height:1.35rem;border-radius:50%;font-size:.72rem;font-weight:600;background:#ffffff14}.panel{padding:1.75rem;border-radius:var(--radius);border:1px solid var(--surface-border);background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 24px 64px #00000059}.panel h2{margin:0 0 .5rem;font-family:var(--font-display);font-size:1.75rem;font-weight:400}.panel-desc{margin:0 0 1.5rem;color:var(--text-muted);line-height:1.55}.field{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem}.field span{font-size:.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.field-input-with-voice{position:relative}.field-control-with-voice{width:100%;padding:.75rem 2.85rem .75rem .9rem;border-radius:10px;border:1px solid var(--surface-border);background:#00000047;color:var(--text);outline:none;resize:vertical;min-height:100px;line-height:1.55;transition:border-color .15s ease,box-shadow .15s ease}.field-control-with-voice:focus{border-color:#e879a88c;box-shadow:0 0 0 3px var(--accent-soft)}.field-input-with-voice .voice-input-btn{position:absolute;right:.55rem;bottom:.55rem}.voice-input-btn{display:grid;place-items:center;width:32px;height:32px;padding:0;border-radius:999px;border:1px solid var(--surface-border);background:#ffffff0a;color:var(--text-muted);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;flex-shrink:0}.voice-input-btn:not(:disabled):hover{color:var(--text);border-color:#e879a873;background:#e879a814}.voice-input-btn.recording{color:#ff6b8a;border-color:#ff6b8aa6;background:#ff6b8a1f;animation:voice-pulse 1.2s ease-in-out infinite}.voice-input-btn.processing{cursor:wait}.voice-input-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent-2);border-radius:50%;animation:spin .8s linear infinite}@keyframes voice-pulse{0%,to{box-shadow:0 0 #ff6b8a59}50%{box-shadow:0 0 0 6px #ff6b8a00}}.field input,.field textarea,.field select{width:100%;padding:.75rem .9rem;border-radius:10px;border:1px solid var(--surface-border);background:#00000047;color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.field input:focus,.field textarea:focus,.field select:focus{border-color:#e879a88c;box-shadow:0 0 0 3px var(--accent-soft)}.field input::placeholder,.field textarea::placeholder{color:var(--text-muted);opacity:.72}.field textarea{resize:vertical;min-height:100px;line-height:1.55}.tag-picker{display:flex;flex-direction:column;gap:.65rem}.tag-picker-selected,.tag-picker-suggestions{display:flex;flex-wrap:wrap;gap:.45rem}.tag-picker-input-row{display:flex;gap:.5rem}.tag-picker-input-row input{flex:1;min-width:0;padding:.75rem .9rem;border-radius:10px;border:1px solid var(--surface-border);background:#00000047;color:var(--text);outline:none}.tag-picker-input-row input::placeholder{color:var(--text-muted);opacity:.72}.tag-picker-input-row input:focus{border-color:#e879a88c;box-shadow:0 0 0 3px var(--accent-soft)}.tag-picker-add{flex-shrink:0}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .65rem;border-radius:999px;font-size:.78rem;line-height:1.2;border:1px solid var(--surface-border);background:#ffffff0a;color:var(--text-muted);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.tag-chip--selected{background:var(--accent-soft);border-color:#e879a859;color:var(--text);cursor:default}.tag-chip--option:hover{background:#ffffff14;color:var(--text)}.tag-chip--option.active{background:var(--accent-soft);border-color:#e879a873;color:var(--text)}.tag-chip-remove{width:1.1rem;height:1.1rem;padding:0;border:none;border-radius:50%;background:#ffffff14;color:var(--text-muted);font-size:.85rem;line-height:1;cursor:pointer}.tag-chip-remove:hover{color:var(--text);background:#ffffff24}.tag-picker-hint{margin:0;font-size:.76rem;color:var(--text-muted)}.lyrics-editor{font-family:ui-monospace,Cascadia Code,Segoe UI Mono,monospace;font-size:.88rem}.field-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 1rem}@media(max-width:560px){.field-grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem 1.25rem;border-radius:10px;border:none;cursor:pointer;font-weight:600;font-size:.92rem;transition:transform .12s ease,opacity .12s ease,box-shadow .15s ease}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,var(--accent),#c76bb8);color:#fff;box-shadow:0 8px 24px #e879a859}.btn-primary:not(:disabled):hover{box-shadow:0 10px 28px #e879a873}.btn-secondary{background:#9b7ede38;color:#e8dff8;border:1px solid rgba(155,126,222,.35)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--surface-border)}.actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:.5rem}.error-banner{margin-bottom:1rem;padding:.85rem 1rem;border-radius:10px;background:var(--error-bg);color:var(--error-text);border:1px solid rgba(220,80,80,.25);font-size:.9rem}.loading-state{text-align:center;padding:2rem 1rem}.loading-state p{color:var(--text-muted);max-width:36ch;margin:1.5rem auto 0;line-height:1.55}.waveform{display:flex;align-items:flex-end;justify-content:center;gap:6px;height:48px}.waveform span{display:block;width:6px;height:12px;border-radius:999px;background:linear-gradient(to top,var(--accent),var(--accent-2));animation:wave .9s ease-in-out infinite alternate}@keyframes wave{0%{height:12px;opacity:.5}to{height:44px;opacity:1}}.player-card{display:flex;gap:1.5rem;align-items:center;padding:1.25rem;border-radius:14px;background:#00000040;border:1px solid var(--surface-border);margin-bottom:1.25rem}@media(max-width:560px){.player-card{flex-direction:column;text-align:center}}.vinyl{flex-shrink:0;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#3a3048,#120e18 65%);border:3px solid rgba(255,255,255,.08);display:grid;place-items:center;animation:spin 8s linear infinite}.vinyl-center{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2))}@keyframes spin{to{transform:rotate(360deg)}}.player-meta{flex:1;min-width:0}.player-meta h3{margin:0 0 .25rem;font-family:var(--font-display);font-size:1.5rem;font-weight:400}.player-meta p{margin:0 0 1rem;color:var(--text-muted);font-size:.85rem}.player-panel{max-width:920px}.cd-lyrics-player{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:1.25rem;align-items:stretch;min-height:360px}.cd-lyrics-player--loading{opacity:.92}.cd-lyrics-player__left{display:flex;flex-direction:column;gap:1rem}.cd-lyrics-player__right{min-height:0;display:flex;flex-direction:column}.cd-lyrics-player__right--loading{opacity:.75}.cd-stage{position:relative;display:grid;place-items:center;padding:.5rem 0}.cd-disc{position:relative;width:188px;height:188px;border-radius:50%;background:radial-gradient(circle at 30% 28%,rgba(255,255,255,.18),transparent 36%),radial-gradient(circle at 70% 72%,rgba(255,255,255,.08),transparent 42%),conic-gradient(from 210deg,#1a1428,#2d2440,#120e18,#3a2f52,#1a1428,#2a2038,#1a1428 360deg);border:2px solid rgba(255,255,255,.1);box-shadow:0 12px 40px #00000073,inset 0 0 0 1px #ffffff0d;transition:transform .3s ease}.cd-disc--spinning{animation:cd-spin 5.5s linear infinite}.cd-disc--loading{animation:cd-spin 3s linear infinite;opacity:.85}.cd-disc--thumb{width:72px;height:72px;border-width:1px;box-shadow:0 6px 20px #00000059,inset 0 0 0 1px #ffffff0d}.cd-disc--thumb .cd-disc__label{top:22%;right:22%;bottom:22%;left:22%}.cd-disc--thumb .cd-disc__label-mark{font-size:.55rem}.cd-disc--thumb .cd-disc__hole{width:10px;height:10px}.cd-disc--clickable{padding:0;cursor:pointer;font:inherit;color:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none}.cd-disc--clickable:hover{transform:scale(1.06)}.cd-disc--clickable.cd-disc--active{outline:2px solid var(--accent);outline-offset:3px;transform:scale(1.04)}@keyframes cd-spin{to{transform:rotate(360deg)}}.cd-disc__shine{position:absolute;top:8%;right:8%;bottom:8%;left:8%;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.22) 0%,transparent 38%,transparent 62%,rgba(232,121,168,.12) 100%);pointer-events:none}.cd-disc__grooves{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border-radius:50%;background:repeating-radial-gradient(circle at center,transparent 0 3px,rgba(255,255,255,.025) 3px 4px);pointer-events:none}.cd-disc__label{position:absolute;top:28%;right:28%;bottom:28%;left:28%;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.5rem;text-align:center;background:linear-gradient(145deg,#9b7ede59,#e879a838);border:1px solid rgba(255,255,255,.12);overflow:hidden}.cd-disc__label-mark{font-size:.72rem;font-weight:700;letter-spacing:.08em;color:#ffffffe6}.cd-disc__label-title{font-size:.62rem;line-height:1.25;color:#ffffffbf;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.cd-disc__hole{position:absolute;width:16px;height:16px;border-radius:50%;background:#0a0810;border:2px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 4px #000c}.cd-play-btn{position:absolute;width:52px;height:52px;border:none;border-radius:50%;display:grid;place-items:center;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 8px 24px #e879a859;transition:transform .15s ease,box-shadow .15s ease}.cd-play-btn:hover{transform:scale(1.05);box-shadow:0 10px 28px #e879a873}.cd-play-btn:active{transform:scale(.98)}.cd-player-meta{display:flex;flex-direction:column;gap:.65rem}.cd-player-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.cd-track-position{display:block;margin-bottom:.2rem;color:var(--accent);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.radio-controls{display:flex;align-items:center;justify-content:center;gap:.65rem;margin:.15rem 0}.radio-nav-btn{width:2.25rem;height:2.25rem;border:1px solid var(--surface-border);border-radius:50%;display:grid;place-items:center;cursor:pointer;color:var(--text);background:#ffffff0a;transition:background .15s ease,border-color .15s ease,opacity .15s ease}.radio-nav-btn:hover:not(:disabled){background:#ffffff14;border-color:#ffffff24}.radio-nav-btn:disabled{opacity:.35;cursor:not-allowed}.radio-nav-btn--primary{width:2.75rem;height:2.75rem;border:none;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px #e879a84d}.radio-nav-btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 8px 22px #e879a866}.cd-player-title{margin:0;font-family:var(--font-display);font-size:1.35rem;font-weight:400;line-height:1.25}.cd-player-tags{margin:0;color:var(--text-muted);font-size:.78rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.cd-progress{position:relative;height:6px;margin-top:.15rem}.cd-progress__track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:#ffffff1a;overflow:hidden;pointer-events:none}.cd-progress__track:after{content:"";display:block;height:100%;width:var(--progress, 0%);border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.cd-progress__range{position:relative;z-index:1;width:100%;height:6px;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}.cd-progress__range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:0;height:0;border:none;background:transparent;box-shadow:none}.cd-progress__range::-moz-range-thumb{width:0;height:0;border:none;background:transparent;box-shadow:none}.cd-time{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.cd-download-btn{align-self:flex-start;margin-top:.15rem}.cd-loading-wave{margin-top:.25rem}.cd-lyrics-empty{flex:1;display:grid;place-items:center;min-height:200px;border-radius:14px;border:1px dashed var(--surface-border);color:var(--text-muted);font-size:.9rem}.lyrics-panel--embedded{margin-bottom:0;flex:1;display:flex;flex-direction:column;min-height:0;height:100%}.lyrics-panel--embedded .lyrics-scroll{flex:1;max-height:none;min-height:280px}@media(max-width:720px){.cd-lyrics-player{grid-template-columns:1fr;min-height:0}.cd-lyrics-player__left{align-items:center;text-align:center}.cd-player-meta{width:100%;align-items:center}.cd-download-btn{align-self:center}.lyrics-panel--embedded .lyrics-scroll{min-height:220px;max-height:320px}}.audio-player{width:100%;height:40px}.lyrics-panel{margin-bottom:1.25rem;border-radius:14px;border:1px solid var(--surface-border);background:#0003;overflow:hidden}.lyrics-panel-title{margin:0;padding:.85rem 1.15rem;font-family:var(--font-display);font-size:1.15rem;font-weight:400;border-bottom:1px solid var(--surface-border);color:var(--text-muted)}.lyrics-scroll{max-height:360px;overflow-y:auto;padding:1rem 1.15rem 1.15rem}.lyrics-scroll::-webkit-scrollbar{width:6px}.lyrics-scroll::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:999px}.lyrics-section{margin-bottom:1.25rem}.lyrics-section:last-child{margin-bottom:0}.lyrics-section-label{display:inline-block;margin-bottom:.5rem;padding:.2rem .55rem;border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-soft)}.lyrics-lines p{margin:0 0 .35rem;line-height:1.65;font-size:.95rem}.lyrics-lines p:last-child{margin-bottom:0}.lyrics-empty{margin:0;color:var(--text-muted);font-size:.9rem;letter-spacing:.2em}.view-tabs{display:flex;gap:.35rem;padding:.25rem;border-radius:12px;border:1px solid var(--surface-border);background:#00000040}.view-tab{padding:.5rem 1rem;border:none;border-radius:9px;background:transparent;color:var(--text-muted);font-weight:600;font-size:.88rem;cursor:pointer;text-decoration:none;transition:background .15s ease,color .15s ease}.view-tab:hover{color:var(--text);background:#ffffff0a}.view-tab.active{background:var(--accent-soft);color:var(--text)}.songs-grid{display:grid;gap:1.25rem;margin-bottom:1.25rem}.song-result{padding:1rem;border-radius:14px;border:1px solid var(--surface-border);background:#0000002e}.song-result .player-card,.player-card-loading,.player-card-error{margin-bottom:0}.waveform.compact{height:36px;flex-shrink:0}.error-text{color:var(--error-text);font-size:.88rem}.variant-badge{display:inline-block;margin-bottom:.35rem;padding:.15rem .5rem;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-2);background:#9b7ede2e}.actions-inline{margin-top:.75rem}.btn-sm{padding:.5rem .85rem;font-size:.82rem}.gallery-panel h2{margin:0}.gallery-radio-header{margin-bottom:1.25rem}.gallery-radio-header .panel-desc{margin:.35rem 0 0}.empty-gallery{margin:0}.gallery-radio-player{margin-bottom:1.5rem}.gallery-radio-player .cd-lyrics-player{margin:0}.gallery-delete-btn{flex-shrink:0;font-size:1.1rem;line-height:1}.radio-cover-strip{display:flex;gap:1rem;overflow-x:auto;padding:.5rem 0 .75rem;scrollbar-width:thin}.radio-cover-item{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.45rem;width:88px}.radio-cover-title{width:100%;color:var(--text-muted);font-size:.68rem;line-height:1.3;text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.radio-cover-item:has(.cd-disc--active) .radio-cover-title{color:var(--text)}.icon-btn{width:1.75rem;height:1.75rem;border:none;border-radius:8px;background:#ffffff0f;color:var(--text-muted);font-size:1.1rem;line-height:1;cursor:pointer;transition:background .15s ease,color .15s ease}.icon-btn:hover{background:var(--error-bg);color:var(--error-text)}.footer{margin-top:2.5rem;text-align:center;color:var(--text-muted);font-size:.78rem}:root{--bg: #0c0a0f;--surface: rgba(22, 18, 30, .82);--surface-border: rgba(255, 255, 255, .08);--text: #f4f0f7;--text-muted: #a89bb3;--accent: #e879a8;--accent-soft: rgba(232, 121, 168, .18);--accent-2: #9b7ede;--success: #7dd3a8;--error-bg: rgba(220, 80, 80, .15);--error-text: #ff9a9a;--radius: 16px;--font: "DM Sans", system-ui, sans-serif;--font-display: "Instrument Serif", Georgia, serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button,input,textarea,select{font:inherit}
