@charset "UTF-8";.header{position:relative;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px clamp(16px,4vw,36px)}.header__brand{display:flex;align-items:center;gap:12px}.header__mark{width:40px;height:40px;border-radius:50%;object-fit:contain;padding:4px;background:radial-gradient(circle at 50% 45%,var(--bg-2),var(--bg));border:1px solid var(--border);box-shadow:0 0 16px var(--glow)}.header__titles{display:flex;flex-direction:column;line-height:1}.header__title{margin:0;font-family:var(--font-display);font-size:clamp(1.05rem,2.2vw,1.4rem);font-weight:700;letter-spacing:.02em}.header__tag{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--text-dim);margin-top:4px}.header__actions{display:flex;align-items:center;gap:8px}.header__upload{width:auto;padding:0 14px!important;gap:8px}.header__upload-label{font-size:.85rem;font-weight:500}.header__badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--accent);color:var(--bg);font-size:.65rem;font-weight:600;display:grid;place-items:center;box-shadow:0 0 8px var(--glow)}.icon-btn{position:relative;display:inline-grid;grid-auto-flow:column;align-items:center;place-items:center;height:42px;min-width:42px;padding:0;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:background .18s var(--ease),border-color .18s var(--ease),transform .18s var(--ease);text-decoration:none}.icon-btn:hover{background:var(--surface-strong);border-color:var(--accent);transform:translateY(-1px)}.icon-btn:active{transform:translateY(0)}.theme-menu{position:relative}.theme-menu__pop{position:absolute;top:calc(100% + 10px);right:0;width:190px;padding:6px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 18px 50px #0000008c;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:grid;gap:2px;z-index:40;animation:pop .16s var(--ease)}.theme-menu__item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;border-radius:10px;background:transparent;color:var(--text);font-size:.88rem;text-align:left;transition:background .15s var(--ease)}.theme-menu__item:hover{background:var(--surface-strong)}.theme-menu__item.is-active{background:var(--accent-soft);color:var(--accent)}.theme-menu__swatch{display:inline-flex;border-radius:5px;overflow:hidden;box-shadow:0 0 0 1px var(--border)}.theme-menu__swatch i{display:block;width:9px;height:18px}@keyframes pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:560px){.header__hide-sm,.header__upload-label{display:none}.header__upload{width:42px;padding:0}.header__tag{display:none}}.visualizer{position:relative;width:100%;height:100%;display:grid;place-items:center;overflow:hidden}.visualizer__canvas{display:block}.visualizer__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:clamp(60px,11vmin,110px);height:clamp(60px,11vmin,110px);border:none;background:transparent;border-radius:50%;display:grid;place-items:center;padding:0;transition:transform .25s var(--ease)}.visualizer__center:hover{transform:translate(-50%,-50%) scale(1.06)}.visualizer__logo{width:56%;height:56%;object-fit:contain;pointer-events:none;filter:drop-shadow(0 0 12px var(--glow))}.visualizer__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--text);background:radial-gradient(circle,#0000008c,#00000026 70%);border-radius:50%;opacity:0;transition:opacity .2s var(--ease)}.visualizer__center:hover .visualizer__overlay,.visualizer__center:not(.is-playing) .visualizer__overlay{opacity:1}.visualizer__nowplaying{position:absolute;bottom:clamp(12px,4vh,40px);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;pointer-events:none;max-width:80vw}.visualizer__title{font-family:var(--font-display);font-weight:600;font-size:clamp(1rem,2.4vw,1.5rem);letter-spacing:.01em;text-shadow:0 2px 18px rgba(0,0,0,.7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80vw}.visualizer__artist{font-size:clamp(.78rem,1.6vw,.95rem);color:var(--text-dim);text-shadow:0 2px 12px rgba(0,0,0,.7)}.player{position:relative;z-index:20;display:flex;flex-direction:column;gap:10px;padding:14px clamp(16px,4vw,36px) clamp(16px,3vh,26px);background:linear-gradient(to top,var(--bg) 30%,rgba(0,0,0,0))}.player__seek{display:flex;align-items:center;gap:12px}.player__time{font-size:.72rem;color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:38px;text-align:center}.player__track-wrap{flex:1}.player__range,.player__vol-range{background:linear-gradient(to right,var(--accent) 0 var(--progress, 0%),var(--surface-strong) var(--progress, 0%) 100%)}.player__row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}.player__meta{display:flex;flex-direction:column;min-width:0;line-height:1.25}.player__meta-title{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player__meta-artist{font-size:.78rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player__controls{display:flex;align-items:center;gap:6px;justify-self:center}.player__btn{display:grid;place-items:center;width:40px;height:40px;border:none;border-radius:50%;background:transparent;color:var(--text-dim);transition:color .16s var(--ease),background .16s var(--ease),transform .16s var(--ease)}.player__btn:hover{color:var(--text);background:var(--surface)}.player__btn.is-on{color:var(--accent);background:var(--accent-soft)}.player__play{display:grid;place-items:center;width:54px;height:54px;border:none;border-radius:50%;background:var(--accent);color:var(--bg);box-shadow:0 6px 24px var(--glow);transition:transform .16s var(--ease)}.player__play:hover{transform:scale(1.06)}.player__play:active{transform:scale(.97)}.player__play.is-loading{animation:pulse 1s ease-in-out infinite}.player__volume{display:flex;align-items:center;gap:8px;justify-self:end;width:100%;max-width:160px}.player__vol-range{height:4px}@keyframes pulse{0%,to{box-shadow:0 6px 24px var(--glow)}50%{box-shadow:0 6px 34px var(--glow);opacity:.85}}@media(max-width:720px){.player__row{grid-template-columns:1fr;justify-items:center;gap:10px}.player__meta{align-items:center;text-align:center;order:-1}.player__volume{max-width:220px;justify-self:center}}.playlist-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;background:#00000080;opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}.playlist-scrim.is-open{opacity:1;pointer-events:auto}.playlist{position:fixed;top:0;right:0;z-index:46;display:flex;flex-direction:column;width:min(380px,88vw);height:100%;padding:20px;background:var(--bg-2);border-left:1px solid var(--border);box-shadow:-20px 0 60px #00000080;transform:translate(100%);transition:transform .32s var(--ease)}.playlist.is-open{transform:translate(0)}.playlist__head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.playlist__title{margin:0;font-family:var(--font-display);font-size:1.3rem}.playlist__count{font-size:.74rem;color:var(--text-dim)}.playlist__list{list-style:none;margin:0;padding:0;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.playlist__item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);transition:background .16s var(--ease)}.playlist__item:hover{background:var(--surface)}.playlist__item.is-active{background:var(--accent-soft)}.playlist__play{flex:none;display:grid;place-items:center;width:34px;height:34px;border:1px solid var(--border);border-radius:50%;background:var(--surface);color:var(--text);transition:all .16s var(--ease)}.playlist__play:hover{border-color:var(--accent);color:var(--accent)}.playlist__item.is-active .playlist__play{background:var(--accent);color:var(--bg);border-color:var(--accent)}.playlist__info{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:transparent;border:none;text-align:left;padding:0}.playlist__name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.playlist__item.is-active .playlist__name{color:var(--accent)}.playlist__artist{display:flex;align-items:center;gap:6px;font-size:.76rem;color:var(--text-dim)}.playlist__tag{font-style:normal;font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;padding:1px 6px;border-radius:999px;background:var(--surface-strong);color:var(--text-dim)}.playlist__remove{flex:none;display:grid;place-items:center;width:30px;height:30px;border:none;border-radius:8px;background:transparent;color:var(--text-dim);opacity:.7;transition:all .16s var(--ease)}.playlist__remove:hover{color:#ff6b6b;background:#ff6b6b1f;opacity:1}.playlist__add{margin-top:14px;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.9rem;font-weight:500;transition:all .18s var(--ease)}.playlist__add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.about{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:20px}.about__scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade .2s var(--ease)}.about__card{position:relative;width:min(460px,100%);max-height:90vh;overflow-y:auto;padding:28px;border-radius:var(--radius-lg);background:var(--bg-2);border:1px solid var(--border);box-shadow:0 30px 80px #0009;animation:rise .24s var(--ease)}.about__close{position:absolute;top:16px;right:16px}.about__mark{display:block;width:56px;height:56px;border-radius:50%;object-fit:contain;padding:6px;background:radial-gradient(circle at 50% 45%,var(--bg),#000);border:1px solid var(--border);box-shadow:0 0 22px var(--glow);margin-bottom:16px}.about__title{margin:0 0 8px;font-family:var(--font-display);font-size:1.6rem}.about__lead{margin:0 0 18px;color:var(--text-dim);line-height:1.55;font-size:.92rem}.about__section{margin-top:18px}.about__section h3{margin:0 0 6px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.about__section p{margin:0;color:var(--text-dim);line-height:1.55;font-size:.9rem}.about__keys{list-style:none;margin:8px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}.about__keys li{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-dim)}.about__keys kbd{min-width:46px;padding:4px 8px;border-radius:7px;background:var(--surface-strong);border:1px solid var(--border);font-family:var(--font-body);font-size:.74rem;text-align:center;color:var(--text)}.about__footer{margin-top:24px;padding-top:18px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.88rem;color:var(--text-dim)}.about__github{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);color:var(--text);text-decoration:none;font-weight:500;transition:all .16s var(--ease)}.about__github:hover{border-color:var(--accent);color:var(--accent)}@media(max-width:480px){.about__keys{grid-template-columns:1fr}}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center;padding:24px;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .18s var(--ease)}.drop-overlay.is-active{opacity:1}.drop-overlay__inner{display:flex;flex-direction:column;align-items:center;gap:12px;width:min(520px,90vw);padding:48px;border-radius:var(--radius-lg);border:2px dashed var(--accent);background:var(--accent-soft);color:var(--text);text-align:center}.drop-overlay__title{margin:6px 0 0;font-family:var(--font-display);font-size:1.5rem;font-weight:600}.drop-overlay__sub{margin:0;color:var(--text-dim);font-size:.92rem}.app{position:relative;display:flex;flex-direction:column;height:100dvh;background:radial-gradient(120% 80% at 50% -10%,var(--bg-2) 0%,var(--bg) 60%),var(--bg);overflow:hidden}.app__glow{position:absolute;top:46%;left:50%;width:min(80vmin,720px);height:min(80vmin,720px);transform:translate(-50%,-50%);background:radial-gradient(circle,var(--glow) 0%,transparent 62%);opacity:.4;filter:blur(40px);pointer-events:none;z-index:0}.app__stage{position:relative;z-index:10;flex:1;min-height:0;display:grid;place-items:center;padding:8px clamp(8px,3vw,32px)}:root{--bg: #05070d;--bg-2: #0a1018;--surface: rgba(255, 255, 255, .04);--surface-strong: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .1);--text: #eef2f7;--text-dim: rgba(238, 242, 247, .6);--accent: #5eead4;--accent-soft: rgba(94, 234, 212, .16);--glow: rgba(94, 234, 212, .5);--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--radius-sm: 10px;--radius: 16px;--radius-lg: 24px;--ease: cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}button{font-family:inherit;color:inherit;cursor:pointer}a{color:inherit}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:5px;border-radius:999px;background:var(--surface-strong);outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--glow);transition:transform .15s var(--ease)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25)}input[type=range]::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--glow)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--surface-strong);border-radius:999px}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
