@font-face{font-family:Main;src:url(/assets/Main.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}:root{--bg: transparent;--card: rgba(255, 255, 255, .82);--accent: #7c3aed;--muted: #6b7280;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--radius: 16px;--shadow: 0 4px 24px rgba(100, 60, 150, .1);--jd-pink: #d946a8;--jd-teal: #0d9488;--jd-purple: #7c3aed}*{box-sizing:border-box}html{font-size:clamp(14px,1.5vw,16px)}#root{width:100%;align-self:stretch}body{margin:0;padding:80px 20px 20px;min-height:100vh;font-family:Main,system-ui,-apple-system,sans-serif;color:#3b2d54;display:flex;align-items:center;justify-content:center;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;width:100%;height:100%;background:url(/assets/background.png) center/cover no-repeat,linear-gradient(135deg,#fbc2d5,#e0c3fc 25%,#c4b5fd 45%,#bae6fd 70%,#c2f0e0);z-index:-2;will-change:transform;transform:none}body:after{content:none}@media(max-width:768px){body{padding:80px 16px 16px}body:before{position:fixed;inset:0;width:100%;height:100%;transform:none}}.navbar{position:fixed;top:0;left:0;right:0;background:#ffffff80;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.4);padding:16px 24px;z-index:1000;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:1.2rem;font-weight:700;color:var(--jd-purple);text-decoration:none}.navbar-user{display:flex;align-items:center;gap:12px;color:#4a4458;font-size:.95rem}.hamburger{width:32px;height:32px;background:#7c3aed0f;border:1px solid rgba(124,58,237,.12);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:all .3s ease;padding:0}.hamburger:hover{background:#7c3aed1f}.hamburger span{width:18px;height:2px;background:#7c3aed;border-radius:2px;transition:all .3s ease}.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.menu{position:fixed;top:64px;right:24px;background:#fffffff2;border-radius:var(--radius);padding:16px;box-shadow:0 8px 32px #643c961f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(200,180,230,.25);min-width:200px;opacity:0;pointer-events:none;transform:translateY(-10px);transition:all .3s ease;z-index:999}.menu.show{opacity:1;pointer-events:all;transform:translateY(0)}.menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#3b2d54;text-decoration:none;font-size:.95rem;border:none;background:transparent;width:100%;font-family:inherit}.menu-item:hover{background:#7c3aed0f}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover{background:#ef44440f}.menu-divider{height:1px;background:#c8b4e633;margin:8px 0}.card{background:var(--card);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5)}@media(max-width:768px){.card{padding:24px}}label{display:block;font-size:.95rem;color:#3b2d54;margin-bottom:8px;font-weight:500}input,select{width:100%;padding:12px 16px;border-radius:12px;border:1px solid rgba(150,130,180,.3);background:#fffffff2;color:#3b2d54;font-size:1rem;transition:all .2s ease;font-family:inherit}input:focus,select:focus{outline:none;border-color:var(--jd-purple);background:#fff;box-shadow:0 0 0 3px #7c3aed1a}input::placeholder{color:#9ca3af}.field{margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:12px;border:0;cursor:pointer;font-weight:600;font-size:.95rem;text-decoration:none;font-family:inherit}.btn.primary{background:var(--jd-purple);color:#fff}.btn.ghost{background:#fffc;border:1px solid rgba(150,130,180,.25);color:#4a4458}.btn.download{background:var(--jd-teal);color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.msg{display:flex;gap:12px;align-items:flex-start;padding:16px;border-radius:12px;font-size:.9rem;margin:16px 0}.msg.error{background:#ef44440f;border:1px solid rgba(239,68,68,.2);color:#b91c1c}.msg.success{background:#10b9810f;border:1px solid rgba(16,185,129,.2);color:#065f46}.msg.info{background:#0d94880f;border:1px solid rgba(13,148,136,.2);color:#0d7377}.msg.warning{background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);color:#92400e}.preview{white-space:pre-wrap;background:#ffffffb3;padding:14px 16px;border-radius:10px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.875rem;min-height:100px;overflow:auto;border:1px solid rgba(200,180,230,.2);color:#3b2d54}.muted{color:var(--muted);font-size:.9rem}footer{text-align:center;margin-top:20px;color:var(--muted);font-size:.85rem}.page-wrap{width:100%;max-width:860px;margin:auto;display:grid;grid-template-columns:1fr;gap:24px;position:relative;z-index:1}@media(min-width:768px){.page-wrap:has(aside){grid-template-columns:3fr 2fr}}.page-header h1{margin:0;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:#2d2140}.page-header p{margin:8px 0 0;color:var(--muted);font-size:1rem;line-height:1.5}.input-wrap{position:relative}.input-wrap input{padding-right:40px}.input-status-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-weight:600;pointer-events:none}.input-hint{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:.85rem;color:var(--muted)}.input-hint.success{color:var(--success)}.input-hint.error{color:var(--danger)}.input-hint.warning{color:var(--warning)}.pw-row{display:flex;align-items:stretch;gap:8px}.pw-row input{flex:1;min-width:0}.pw-toggle{background:#7c3aed0f;border:1px solid rgba(124,58,237,.15);color:#6b7280;padding:0 14px;border-radius:10px;cursor:pointer;font-size:.875rem;font-weight:500;flex-shrink:0;font-family:inherit;transition:all .2s ease;white-space:nowrap}.pw-toggle:hover{background:#7c3aed1f;color:#3b2d54}.strength-bar-wrap{margin-top:8px}.strength-bar{height:4px;background:#7c3aed14;border-radius:2px;overflow:hidden;margin-bottom:6px}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-labels{font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:4px}.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;align-items:center}.aside-panel{display:flex;flex-direction:column;gap:16px;padding:28px;box-shadow:var(--shadow)}@media(max-width:768px){.aside-panel{padding:24px}}.home-wrap{width:100%;max-width:1200px;margin:auto;display:grid;grid-template-columns:1fr;gap:24px;position:relative;z-index:1;padding-bottom:48px}.home-about{text-align:center;padding:8px 0}.home-about-title{font-size:clamp(1.45rem,4vw,2rem);font-weight:700;margin:0 0 12px;letter-spacing:-.02em;background:linear-gradient(90deg,#0d9488,#9333ea,#d946a8);-webkit-background-clip:text;background-clip:text;color:transparent}.home-about-line{width:72px;height:4px;margin:0 auto 20px;border-radius:4px;background:linear-gradient(90deg,#0d9488,#d946a8)}.home-about-text{margin:0 auto 28px;max-width:720px;color:#3b2d54;line-height:1.65;font-size:1.05rem}.home-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;align-items:start}.home-platform-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:#fff6;border:1px solid rgba(167,139,250,.2)}.feature-icon{width:40px;height:40px;margin-bottom:12px;color:var(--jd-purple);display:flex;align-items:center;justify-content:center;background:#7c3aed14;border-radius:10px}.home-discord-btn{display:block;text-align:center;padding:11px 20px;background:#fff;color:#5865f2;border-radius:10px;font-weight:600;text-decoration:none;margin-top:10px;font-size:.92rem;transition:transform .15s ease,box-shadow .15s ease}.home-discord-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0000001f}.hero{background:#5032822e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius);padding:clamp(24px,5vw,48px) clamp(20px,4vw,32px);text-align:center;box-shadow:0 4px 24px #643c961a;position:relative;z-index:2}.hero--home{background:linear-gradient(145deg,#ffffff6b,#a78bfa1f 45%,#2dd4bf1a);border:1px solid rgba(255,255,255,.55);box-shadow:0 4px 24px #643c9614,inset 0 1px #fff9;padding:clamp(20px,4vw,36px) clamp(18px,3vw,28px)}.home-hero-inner{max-width:560px;margin:0 auto}.home-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:20px}.home-hero-btn{padding:12px 28px!important;font-size:.98rem!important;text-decoration:none;min-width:0}.hero .home-hero-compat{margin:10px 0 0;font-size:.8rem;line-height:1.4;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#3c2d5aa6;max-width:none}.home-hero-divider{height:1px;margin:22px auto 0;max-width:280px;background:linear-gradient(90deg,transparent,rgba(124,58,237,.25),transparent)}.home-hero-quick{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:16px}.home-hero-quick-link{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;border-radius:999px;font-size:.88rem;font-weight:600;text-decoration:none;color:#4c1d95;background:#ffffffbf;border:1px solid rgba(124,58,237,.22);box-shadow:0 1px 3px #3c28640f;transition:background .15s ease,box-shadow .15s ease,transform .15s ease}.home-hero-quick-link:hover{background:#fff;border-color:#7c3aed66;box-shadow:0 4px 14px #7c3aed1f;transform:translateY(-1px);color:#5b21b6}.home-hero-quick-link:focus-visible{outline:2px solid var(--jd-purple);outline-offset:2px}.hero h1{margin:0 0 16px;font-size:clamp(1.8rem,5vw,3rem);font-weight:700;color:var(--jd-purple);letter-spacing:-.02em}.hero.hero--home h1{margin-bottom:10px}.hero p{color:#ffffffe6;font-size:1.1rem;line-height:1.6;max-width:600px;margin:0 auto 32px}.hero .home-hero-tagline{font-size:clamp(.95rem,2vw,1.08rem);line-height:1.55;max-width:520px;margin:0 auto;color:#2d2140e0;font-weight:500}.home-page{padding-bottom:48px}.home-about{background:#ffffff4d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius);padding:clamp(28px,4vw,44px) clamp(20px,3vw,32px);text-align:center;box-shadow:0 8px 32px #643c961a}.home-about-title{font-size:clamp(1.35rem,4vw,2rem);font-weight:700;margin:0 0 12px;letter-spacing:-.02em;background:linear-gradient(90deg,#5eead4,#c084fc 45%,#f472b6);-webkit-background-clip:text;background-clip:text;color:transparent}.home-about-line{width:72px;height:4px;margin:0 auto 22px;border-radius:4px;background:linear-gradient(90deg,#5eead4,#c084fc,#f472b6)}.home-about-lead{margin:0 auto 28px;max-width:640px;font-size:1.02rem;line-height:1.65;color:#ffffffed;text-align:center}.home-features-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;text-align:left}.home-feature-card .home-feature-icon{color:var(--jd-purple);margin-bottom:4px;opacity:.85}.home-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;align-items:stretch}.home-info-card-title{margin:0 0 14px;font-size:1.15rem;color:#2d2140}.home-game-tags{display:flex;flex-wrap:wrap;gap:8px}.home-game-tag{padding:6px 12px;border-radius:8px;background:#a78bfa1f;border:1px solid rgba(167,139,250,.25);color:#6d28d9;font-size:.82rem;font-weight:500}.home-platform-list{display:grid;gap:10px}.home-platform-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:#ffffff73;border:1px solid rgba(167,139,250,.2)}.home-platform-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.home-platform-name{font-weight:600;color:#2d2140;font-size:.92rem}.home-platform-desc{font-size:.78rem;color:var(--muted)}.home-discord-cta{display:block;text-align:center;padding:11px 20px;background:#fff;color:#5865f2;border-radius:10px;font-weight:600;text-decoration:none;margin-top:10px;font-size:.92rem;transition:transform .15s ease,box-shadow .15s ease}.home-discord-cta:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0000001f}@media(min-width:960px){.home-info-grid{grid-template-columns:repeat(3,1fr)}}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:32px}.feature{background:#fff9;padding:20px;border-radius:12px;border:1px solid rgba(255,255,255,.7);transition:all .3s ease;text-align:left;box-shadow:0 4px 12px #0000000d;color:#3b2d54}@media(min-width:768px){.feature:hover{background:#fffc;border-color:var(--jd-purple);transform:translateY(-4px);box-shadow:0 8px 20px #643c9626}}.feature h3{margin:0 0 8px;font-size:1rem;color:#2d2140}.feature p{margin:0;font-size:.9rem;color:var(--muted);line-height:1.5}.auth-grid{display:grid;grid-template-columns:1fr;gap:24px}@media(min-width:768px){.auth-grid{grid-template-columns:1fr 1fr}}.tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid rgba(200,180,230,.15);padding-bottom:12px;flex-wrap:wrap}.tab-btn{padding:8px 20px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;background:transparent;border:none;color:var(--muted);font-size:1rem;font-family:inherit}.tab-btn.active{background:#0d94881f;color:#0d9488}.tab-btn:hover{background:#7c3aed0f;color:#3b2d54}.divider{text-align:center;position:relative;margin:24px 0}.divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:#c8b4e633}.divider span{background:var(--card);padding:0 12px;position:relative;color:var(--muted);font-size:.9rem}.link-stack{display:flex;flex-direction:column;gap:12px;margin-top:16px}.glass{background:#fff9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius)}.profile-wrap{width:100%;max-width:900px;margin:0 auto;padding:0 16px;position:relative;z-index:1;align-self:flex-start}.profile-wrap-center{display:flex;align-items:center;justify-content:center;min-height:60vh;align-self:center}.profile-content{display:flex;flex-direction:column;gap:24px;padding-bottom:40px}.profile-header-centered{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0 8px}.profile-avatar-row{display:flex;align-items:center;gap:14px}.profile-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#7c3aed33,#0d948833);border:2px solid rgba(124,58,237,.25);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #7c3aed1a;flex-shrink:0}.profile-avatar span{font-size:1.6rem;font-weight:700;color:#3b2d54}.profile-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-username{margin:0;font-size:.9rem;color:var(--muted);font-weight:500}.profile-greeting-row{display:flex;align-items:center;gap:10px}.profile-greeting{margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;color:#2d2140;white-space:nowrap}.profile-edit-icon-btn{width:34px;height:34px;border-radius:999px;border:1px solid rgba(124,58,237,.2);background:#7c3aed0f;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.profile-edit-icon-btn:hover{background:#7c3aed26;border-color:#7c3aed59;color:#3b2d54}.profile-edit-inline{display:flex;align-items:center;gap:8px}.profile-nickname-input{width:160px;font-size:clamp(1.4rem,3.5vw,1.8rem);font-weight:700;background:#ffffffb3;padding:4px 12px;border-radius:10px;height:auto}.profile-icon-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.profile-icon-btn-ok{color:var(--jd-teal)}.profile-icon-btn-ok:hover{background:#0d94881a}.profile-icon-btn-cancel{color:var(--danger)}.profile-icon-btn-cancel:hover{background:#ef44441a}.profile-not-found{padding:48px 40px;text-align:center;max-width:440px}.profile-not-found-title{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:#2d2140}.profile-not-found-text{margin:0;color:var(--muted);line-height:1.6}.profile-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:540px){.profile-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.profile-stats-grid{grid-template-columns:repeat(5,1fr)}}.stat-card{padding:20px;display:flex;flex-direction:column;gap:8px;cursor:default}.stat-card-label{display:flex;align-items:center;gap:6px;color:#3c28508c;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-card:hover .stat-card-label{color:var(--jd-purple)}.stat-card-value{font-size:1.6rem;font-weight:700;color:#2d2140}.song-carousel{padding:24px;overflow:hidden}.song-carousel-header{display:flex;align-items:center;justify-content:space-between}.song-carousel-title{margin:0;font-size:1.1rem;font-weight:600;color:#2d2140}.song-carousel-toggle{padding:6px 14px;font-size:.85rem;gap:4px}.song-carousel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0;color:var(--muted);opacity:.5}.song-carousel-empty p{margin:12px 0 0;font-size:.9rem}.song-carousel-sort-bar{display:flex;align-items:center;gap:8px;padding:12px 0 4px;color:var(--muted);flex-wrap:wrap}.sort-pill{padding:4px 12px;border-radius:20px;border:1px solid rgba(124,58,237,.15);background:#7c3aed0a;color:var(--muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;white-space:nowrap}.sort-pill:hover{background:#7c3aed1a;color:#3b2d54}.sort-pill.active{background:#7c3aed1f;border-color:#7c3aed59;color:var(--jd-purple)}.song-carousel-list{display:flex;gap:12px;overflow-x:auto;padding:16px 0 8px}.song-card{min-width:180px;width:180px;flex-shrink:0;overflow:hidden;cursor:default}.song-card-cover{aspect-ratio:1 / 1;background:linear-gradient(135deg,#7c3aed1a,#0d94881a);display:flex;align-items:center;justify-content:center;overflow:hidden}.song-card-cover img{width:100%;height:100%;object-fit:cover}.song-card-placeholder-icon{color:#7c3aed4d}.song-card:hover .song-card-placeholder-icon{color:#7c3aed80;transition:color .2s ease}.song-card-info{padding:12px}.song-card-title{margin:0;font-size:.9rem;font-weight:600;color:#2d2140;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card-artist{margin:2px 0 0;font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-card-score{margin:6px 0 0;font-size:.8rem;font-weight:500;color:var(--jd-purple)}.profile-skeleton{display:flex;flex-direction:column;gap:32px;padding:40px 0;align-items:center}.profile-skeleton-header{display:flex;align-items:center;gap:14px}.skeleton{background:#7c3aed0f;border-radius:12px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-circle{width:72px;height:72px;border-radius:50%}.skeleton-text-sm{width:120px;height:16px}.skeleton-text-lg{width:260px;height:32px}.skeleton-card{height:96px}.skeleton-section{width:100%;max-width:900px;height:200px}@keyframes skeleton-pulse{0%,to{opacity:.3}50%{opacity:.7}}.toast-container{position:fixed;top:76px;right:20px;z-index:3000;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:380px;width:100%}.toast{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:12px;background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(200,180,230,.2);box-shadow:0 8px 32px #643c961f;font-size:.9rem;color:#3b2d54;pointer-events:auto;animation:toast-slide-in .28s ease forwards}.toast-exit{animation:toast-slide-out .28s ease forwards}.toast-icon{flex-shrink:0;display:flex;align-items:center}.toast-message{flex:1;min-width:0}.toast-close{flex-shrink:0;width:26px;height:26px;border-radius:6px;border:none;background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;padding:0}.toast-close:hover{background:#7c3aed0f;color:#3b2d54}.toast-success{border-color:#10b98140}.toast-success .toast-icon{color:var(--success)}.toast-error{border-color:#ef444440}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-color:#f59e0b40}.toast-warning .toast-icon{color:var(--warning)}.toast-info{border-color:#7c3aed40}.toast-info .toast-icon{color:var(--jd-purple)}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media(max-width:480px){.toast-container{right:12px;left:12px;max-width:none}}.star-decoration{position:absolute;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none}@keyframes star-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(8deg)}}.songlist-wrap{width:100%;max-width:1100px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.songlist-header{margin-bottom:20px}.songlist-header h1{margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;color:#2d2140}.songlist-count{margin:4px 0 0;color:var(--muted);font-size:.9rem}.songlist-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.songlist-search{flex:1;min-width:200px;padding:10px 16px;border-radius:10px;border:1px solid rgba(124,58,237,.15);background:var(--card);font-size:.9rem;outline:none;transition:border-color .2s}.songlist-search:focus{border-color:var(--accent)}.songlist-filter-pills{display:flex;gap:8px}.songlist-select{padding:8px 12px;border-radius:10px;border:1px solid rgba(124,58,237,.15);background:var(--card);font-size:.85rem;cursor:pointer;outline:none}.songlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.songlist-card{border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:default}.songlist-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #7c3aed1f}.songlist-card-cover{position:relative;aspect-ratio:1;overflow:hidden;background:#7c3aed0d}.songlist-card-cover img{width:100%;height:100%;object-fit:cover}.songlist-card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted)}.songlist-card-placeholder.small{width:48px;height:48px}.songlist-difficulty-badge{position:absolute;top:8px;right:8px;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:600;color:#fff}.songlist-card-info{padding:10px 12px}.songlist-card-title{margin:0;font-size:.9rem;font-weight:600;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.songlist-card-artist{margin:2px 0 0;font-size:.78rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.songlist-card-meta{display:flex;gap:8px;margin-top:6px;font-size:.72rem;color:var(--muted)}@media(max-width:480px){.songlist-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}}.leaderboard-wrap{width:100%;max-width:900px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.leaderboard-title{margin:0 0 20px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;color:#2d2140}.leaderboard-song-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-top:12px}.leaderboard-song-btn{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid rgba(124,58,237,.1);border-radius:12px;background:var(--card);cursor:pointer;text-align:left;transition:border-color .2s,transform .15s}.leaderboard-song-btn:hover{border-color:var(--accent);transform:translateY(-2px)}.leaderboard-song-btn img{width:48px;height:48px;border-radius:8px;object-fit:cover}.lb-song-title{display:block;font-weight:600;font-size:.88rem;color:#1e293b}.lb-song-artist{display:block;font-size:.78rem;color:var(--muted)}.leaderboard-selected{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding:16px;border-radius:14px;background:var(--card);border:1px solid rgba(124,58,237,.1)}.leaderboard-cover{width:64px;height:64px;border-radius:10px;object-fit:cover}.leaderboard-selected h2{margin:0;font-size:1.1rem;color:#1e293b}.leaderboard-selected p{margin:2px 0 0;color:var(--muted);font-size:.85rem}.leaderboard-table-wrap{border-radius:14px;overflow:hidden}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table th{padding:12px 16px;text-align:left;font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(124,58,237,.08)}.leaderboard-table td{padding:10px 16px;font-size:.9rem;border-bottom:1px solid rgba(124,58,237,.05)}.leaderboard-rank{width:50px;font-weight:600}.leaderboard-medal{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:700;font-size:.8rem;color:#fff}.medal-1{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.medal-2{background:linear-gradient(135deg,#94a3b8,#64748b)}.medal-3{background:linear-gradient(135deg,#d97706,#b45309)}.leaderboard-name{font-weight:500;color:#1e293b}.leaderboard-score{font-weight:600;color:var(--jd-purple);font-variant-numeric:tabular-nums}.leaderboard-highlight{background:#7c3aed0f}.leaderboard-highlight .leaderboard-name{color:var(--jd-purple);font-weight:600}.dotw-wrap{width:100%;max-width:1000px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.dotw-header{margin-bottom:24px}.dotw-header h1{margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;color:#2d2140}.dotw-week{margin:4px 0 0;color:var(--muted);font-size:.9rem}.dotw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.dotw-card{border-radius:14px;overflow:hidden;transition:transform .2s}.dotw-card:hover{transform:translateY(-4px)}.dotw-card-cover{aspect-ratio:16/9;overflow:hidden;background:#7c3aed0d}.dotw-card-cover img{width:100%;height:100%;object-fit:cover}.dotw-card-body{padding:14px 16px}.dotw-song-title{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.dotw-song-artist{margin:2px 0 0;font-size:.82rem;color:var(--muted)}.dotw-winner{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(124,58,237,.08)}.dotw-winner-name{display:block;font-weight:600;font-size:.9rem;color:var(--jd-pink)}.dotw-winner-score{display:block;font-size:.78rem;color:var(--muted)}.profile-enhanced{display:flex;flex-direction:column;gap:16px;margin:20px 0}.profile-playtime{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:12px;font-size:.92rem;color:#1e293b}.profile-most-played{padding:16px 18px;border-radius:12px}.profile-most-played h3{margin:0 0 12px;font-size:.95rem;font-weight:600;color:#1e293b}.profile-most-played-card{display:flex;align-items:center;gap:14px}.profile-most-played-cover{width:56px;height:56px;border-radius:10px;object-fit:cover}.profile-most-played-title{display:block;font-weight:600;font-size:.92rem;color:#1e293b}.profile-most-played-artist{display:block;font-size:.8rem;color:var(--muted)}.profile-most-played-count{display:block;font-size:.78rem;color:var(--jd-pink);font-weight:500;margin-top:2px}.profile-top-scores{padding:16px 18px;border-radius:12px}.profile-top-scores h3{margin:0 0 12px;font-size:.95rem;font-weight:600;color:#1e293b}.profile-top-scores-list{display:flex;flex-direction:column;gap:8px}.profile-top-score-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:10px;background:#7c3aed08}.profile-top-score-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}.rank-1{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.rank-2{background:linear-gradient(135deg,#94a3b8,#64748b)}.rank-3{background:linear-gradient(135deg,#d97706,#b45309)}.profile-top-score-item img{width:40px;height:40px;border-radius:8px;object-fit:cover}.profile-top-score-title{display:block;font-weight:600;font-size:.85rem;color:#1e293b}.profile-top-score-artist{display:block;font-size:.75rem;color:var(--muted)}.profile-top-score-value{margin-left:auto;font-weight:700;font-size:.95rem;color:var(--jd-purple);font-variant-numeric:tabular-nums}.profile-difficulty-stats{padding:16px 18px;border-radius:12px}.profile-difficulty-stats h3{margin:0 0 12px;font-size:.95rem;font-weight:600;color:#1e293b}.profile-difficulty-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.profile-difficulty-item{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border-radius:10px;background:#7c3aed08}.profile-difficulty-label{font-weight:600;font-size:.9rem;color:#1e293b}.profile-difficulty-count{font-size:.78rem;color:var(--muted)}.profile-difficulty-avg,.profile-difficulty-best{font-size:.75rem;color:var(--muted)}.admin-logs-wrap{width:100%;max-width:960px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.admin-logs-header{margin-bottom:16px}.admin-logs-header h1{margin:0 0 12px;font-size:clamp(1.4rem,3.5vw,1.8rem);font-weight:700;color:#2d2140}.admin-logs-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.admin-logs-tabs{display:flex;gap:6px}.admin-logs-autoscroll{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--muted);cursor:pointer}.admin-logs-files{display:flex;align-items:center;gap:6px;margin-bottom:12px;font-size:.82rem;color:var(--muted);flex-wrap:wrap}.admin-logs-file-badge{padding:2px 8px;border-radius:6px;background:#7c3aed0f;font-size:.75rem;font-family:monospace}.admin-logs-viewer{border-radius:14px;padding:16px;max-height:600px;overflow-y:auto;font-family:monospace;font-size:.78rem;line-height:1.6;background:#0f0f1eeb;color:#e2e8f0}.log-line{white-space:pre-wrap;word-break:break-all;padding:1px 0}.log-error{color:#f87171}.log-warn{color:#fbbf24}.log-info{color:#60a5fa}.log-debug{color:#94a3b8}.admin-songdb-wrap{width:100%;max-width:900px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.admin-songdb-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.admin-songdb-header h1{margin:0;font-size:clamp(1.4rem,3.5vw,1.8rem);font-weight:700;color:#2d2140}.admin-songdb-list{display:flex;flex-direction:column;gap:8px}.admin-songdb-item{border-radius:12px;overflow:hidden;border:1px solid rgba(124,58,237,.08)}.admin-songdb-item-header{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background .15s}.admin-songdb-item-header:hover{background:#7c3aed08}.admin-songdb-item-cover{width:44px;height:44px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#7c3aed0d}.admin-songdb-item-cover img{width:100%;height:100%;object-fit:cover}.admin-songdb-item-info{flex:1;min-width:0}.admin-songdb-item-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:#1e293b}.admin-songdb-dev-badge{padding:1px 6px;border-radius:4px;background:var(--warning);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.04em}.admin-songdb-item-artist{display:block;font-size:.78rem;color:var(--muted)}.admin-songdb-item-meta{display:flex;gap:12px;font-size:.78rem;color:var(--muted);flex-shrink:0}.admin-songdb-item-edit{overflow:hidden;border-top:1px solid rgba(124,58,237,.06)}.admin-songdb-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:16px}.admin-songdb-field{display:flex;flex-direction:column;gap:6px}.admin-songdb-field label{font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.admin-songdb-field input,.admin-songdb-field select{padding:8px 12px;border-radius:8px;border:1px solid rgba(124,58,237,.15);background:#fff;font-size:.85rem;outline:none}.admin-songdb-field input:focus,.admin-songdb-field select:focus{border-color:var(--accent)}.admin-songdb-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.admin-songdb-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;background:#7c3aed14;font-size:.78rem;color:var(--jd-purple)}.admin-songdb-tag button{background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--danger);padding:0 2px;line-height:1}.admin-songdb-colors{display:flex;flex-direction:column;gap:6px}.admin-songdb-color-row{display:flex;align-items:center;gap:8px;font-size:.8rem}.admin-songdb-color-row span{min-width:100px;color:var(--muted);font-size:.75rem}.admin-songdb-actions{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid rgba(124,58,237,.06);flex-wrap:wrap}.danger-text{color:var(--danger)!important}.admin-songdb-confirm-delete{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--danger)}@media(max-width:600px){.admin-songdb-edit-grid{grid-template-columns:1fr}}.color-editor{padding:16px;border-bottom:1px solid rgba(124,58,237,.06)}.color-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.color-editor-header h4{margin:0;font-size:.9rem;font-weight:600;color:#2d2140}.color-pickers{display:flex;gap:14px;flex-wrap:wrap}.color-picker-item{display:flex;flex-direction:column;gap:4px}.color-picker-item label{font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.color-picker-row{display:flex;align-items:center;gap:6px}.color-picker-row input[type=color]{width:36px;height:36px;border:2px solid rgba(124,58,237,.15);border-radius:8px;cursor:pointer;padding:2px;background:#fff}.color-picker-row input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-row input[type=color]::-webkit-color-swatch{border:none;border-radius:5px}.color-hex-input{width:90px;padding:6px 8px;border-radius:6px;border:1px solid rgba(124,58,237,.15);font-family:monospace;font-size:.75rem;background:#fff}.color-preview-container{margin-top:14px}.color-preview{box-shadow:0 4px 20px #0003}.color-preview-secondary{margin-top:10px;padding:8px 12px;border-radius:8px;background:#7c3aed08}@media(max-width:500px){.color-pickers{flex-direction:column;gap:10px}}.ce-wrap{width:100%;max-width:1100px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.ce-wrap h1{margin:0 0 16px;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:#2d2140}.ce-loading,.ce-empty{text-align:center;padding:60px;color:var(--muted);font-size:.9rem}.ce-layout{display:flex;gap:16px;min-height:70vh}.ce-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.ce-sidebar .songlist-search{margin-bottom:4px;padding:7px 12px;font-size:.8rem}.ce-song-list{flex:1;overflow-y:auto;max-height:75vh;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin}.ce-song-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid rgba(124,58,237,.06);background:var(--card);cursor:pointer;text-align:left;transition:all .15s;width:100%}.ce-song-btn:hover{border-color:var(--accent)}.ce-song-btn.active{border-color:var(--accent);background:#7c3aed0f;box-shadow:0 0 0 2px #7c3aed26}.ce-song-thumb{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0}.ce-song-btn-info{flex:1;min-width:0}.ce-song-btn-title{display:block;font-weight:600;font-size:.78rem;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ce-song-btn-artist{display:block;font-size:.65rem;color:var(--muted)}.ce-mini-colors{display:flex;gap:2px;flex-shrink:0}.ce-mini-colors div{width:10px;height:10px;border-radius:2px}.ce-editor{flex:1;min-width:0}.ce-editor-header{margin-bottom:16px}.ce-editor-header h2{margin:0;font-size:1.3rem;font-weight:700;color:#2d2140}.ce-editor-header p{margin:2px 0 0;color:var(--muted);font-size:.85rem}.ce-section{margin-bottom:24px}.ce-section h3{margin:0 0 10px;font-size:.9rem;font-weight:600;color:#2d2140}.ce-preview{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;box-shadow:0 4px 24px #00000040}.ce-preview-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.ce-preview-layer{position:absolute;inset:0}.ce-preview-coach{position:absolute;right:0;bottom:0;height:95%;object-fit:contain;z-index:1}.ce-preview-info{position:absolute;left:14px;bottom:14px;display:flex;align-items:center;gap:10px;z-index:2}.ce-preview-cover{width:44px;height:44px;border-radius:8px;border:2px solid rgba(255,255,255,.3)}.ce-preview-title{font-size:1rem;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6)}.ce-preview-artist{font-size:.75rem;color:#fffc;text-shadow:0 1px 4px rgba(0,0,0,.5)}.ce-preview-menu{display:flex;flex-direction:column;justify-content:space-between;padding:20px}.ce-menu-sim{display:flex;align-items:center;gap:14px}.ce-menu-cover{width:64px;height:64px;border-radius:10px;border:2px solid rgba(255,255,255,.2)}.ce-menu-title{font-size:1.1rem;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)}.ce-menu-artist{font-size:.8rem;color:#ffffffb3}.ce-menu-bar{display:flex;gap:6px;align-items:flex-end}.ce-menu-thumb{width:48px;height:48px;border-radius:8px;border:2px solid rgba(255,255,255,.15)}.ce-color-row{display:flex;gap:20px;margin-top:12px;flex-wrap:wrap}.ce-picker{display:flex;flex-direction:column;gap:4px}.ce-picker label{font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.ce-picker-controls{display:flex;align-items:center;gap:8px}.ce-picker-controls input[type=color]{width:40px;height:40px;border:2px solid rgba(124,58,237,.15);border-radius:10px;cursor:pointer;padding:2px;background:#fff}.ce-picker-controls input[type=color]::-webkit-color-swatch-wrapper{padding:0}.ce-picker-controls input[type=color]::-webkit-color-swatch{border:none;border-radius:7px}.ce-picker-hex{width:100px;padding:8px 10px;border-radius:8px;border:1px solid rgba(124,58,237,.15);font-family:monospace;font-size:.8rem;background:#fff;text-transform:uppercase}.ce-picker-swatch{width:28px;height:28px;border-radius:6px;border:1px solid rgba(0,0,0,.1)}.ce-save-btn{width:100%;margin-top:8px;padding:12px;font-size:.95rem}@media(max-width:700px){.ce-layout{flex-direction:column}.ce-sidebar{width:100%}.ce-song-list{max-height:200px}}
