:root{--bg:#07000f;--bg-card:#ffffff0a;--bg-card-hover:#ffffff14;--border:#ffffff14;--border-hover:#ff6bb766;--text:#e2d9f3;--text-muted:#9d8ec4;--pink:#ff6fb7;--pink-light:#f9a8d4;--purple:#a78bfa;--purple-light:#c4b5fd;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Poppins,system-ui,sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);background-image:radial-gradient(70% 50% at 5% 0,#ff6bb724 0%,#0000 60%),radial-gradient(60% 45% at 95% 100%,#a78bfa24 0%,#0000 60%),radial-gradient(100% 60% at 50% 40%,#ec48990a 0%,#0000 70%);min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:linear-gradient(#ff6fb7,#a78bfa);border-radius:99px}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif}button{cursor:pointer;font-family:Poppins,sans-serif}a{color:inherit}.gradient-text{background:linear-gradient(135deg,#ff6fb7 0%,#c084fc 50%,#a78bfa 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.learn-page{width:100%;max-width:1140px;margin:0 auto;padding:0 24px 80px;position:relative}.learn-topbar{align-items:center;gap:10px;margin-bottom:32px;padding:20px 0 0;display:flex}.back-btn{color:#e2d9f3b3;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-family:Poppins,sans-serif;font-size:13px;font-weight:500;transition:background .2s,border-color .2s,color .2s;display:inline-flex}.back-btn:hover{color:#f9a8d4;background:#ff6bb71a;border-color:#ff6bb74d}.breadcrumb{color:#e2d9f359;align-items:center;gap:6px;font-size:13px;display:flex}.breadcrumb-sep{opacity:.4}.breadcrumb-current{color:#e2d9f3a6;white-space:nowrap;text-overflow:ellipsis;max-width:220px;font-weight:500;overflow:hidden}.song-hero{align-items:flex-start;gap:20px;margin-bottom:36px;display:flex}.song-hero-rank{letter-spacing:-3px;flex-shrink:0;font-size:48px;font-weight:900;line-height:1}.song-hero-rank.rank-gold{background:linear-gradient(160deg,#ffe259,#ffa751,#ffe259);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 12px #ffd70066);-webkit-background-clip:text;background-clip:text}.song-hero-rank.rank-silver{background:linear-gradient(160deg,#e8e8e8,#9e9e9e,#e8e8e8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.song-hero-rank.rank-bronze{background:linear-gradient(160deg,#d4956a,#7d4a1a,#d4956a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.song-hero-rank.rank-default{background:linear-gradient(135deg,#a78bfa,#ff6fb7);-webkit-text-fill-color:transparent;opacity:.6;-webkit-background-clip:text;background-clip:text}.song-hero-info{flex:1;min-width:0}.song-hero-artist{color:#ff6fb7;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;font-size:12px;font-weight:700}.song-hero-title{color:#f3f4f6;letter-spacing:-1px;margin-bottom:4px;font-size:clamp(24px,4vw,38px);font-weight:800;line-height:1.1}.song-hero-title-ko{color:#e2d9f373;margin-bottom:12px;font-family:Noto Sans KR,Poppins,sans-serif;font-size:16px}.song-hero-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.song-hero-views{color:#c4b5fdb3;background:#a78bfa1a;border-radius:10px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.song-hero-channel{color:#e2d9f359;font-size:12px}.video-section{margin-bottom:56px}.video-wrapper{aspect-ratio:16/9;background:#000;border-radius:18px;width:100%;max-width:780px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 0 0 1px #ff6bb71f,0 20px 60px #0009,0 0 80px #ff6bb714}.video-wrapper iframe{border:none;width:100%;height:100%;display:block;position:absolute;inset:0}.vocab-section{max-width:900px;margin:0 auto}.vocab-header{text-align:center;margin-bottom:32px}.vocab-title{color:#f3f4f6;letter-spacing:-.8px;margin-bottom:20px;font-size:clamp(22px,3vw,30px);font-weight:800}.vocab-progress{margin-bottom:24px}.vocab-progress-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.vocab-progress-label{color:#e2d9f399;font-size:13px;font-weight:600}.vocab-progress-count{background:linear-gradient(135deg,#ff6fb7,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:13px;font-weight:700}.vocab-progress-bar{background:#ffffff14;border-radius:99px;width:100%;height:6px;overflow:hidden}.vocab-progress-fill{background:linear-gradient(90deg,#ff6fb7,#a78bfa);border-radius:99px;min-width:4px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.vocab-filters{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.filter-tab{color:#e2d9f380;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:20px;padding:7px 18px;font-family:Poppins,sans-serif;font-size:13px;font-weight:600;transition:all .2s}.filter-tab:hover{color:#e2d9f3cc;background:#ff6bb714;border-color:#ff6bb733}.filter-tab.active{color:#f9a8d4;background:linear-gradient(135deg,#ff6bb72e,#a78bfa2e);border-color:#ff6bb766}.vocab-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px;display:grid}.flip-card{perspective:1200px;cursor:pointer;height:190px}.flip-card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,0,.2,1);position:relative}.flip-card.flipped .flip-card-inner{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{backface-visibility:hidden;border-radius:16px;position:absolute;inset:0;overflow:hidden}.flip-card-front{text-align:center;background:#ffffff0a;border:1px solid #ffffff14;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:20px;transition:border-color .2s,background .2s;display:flex}.flip-card:hover .flip-card-front{background:#fff1;border-color:#ff6bb740}.flip-card.status-known .flip-card-front{background:#4ade800a;border-color:#4ade804d}.flip-card.status-review .flip-card-front{background:#fb923c0a;border-color:#fb923c4d}.card-pos-tag{text-transform:uppercase;letter-spacing:1px;color:#c4b5fd;background:#a78bfa1f;border:1px solid #a78bfa33;border-radius:8px;padding:2px 8px;font-size:10px;font-weight:700}.card-korean{color:#f3f4f6;letter-spacing:-1px;font-family:Noto Sans KR,Poppins,sans-serif;font-size:36px;font-weight:800;line-height:1}.card-romanization{color:#e2d9f373;font-size:13px;font-style:italic}.card-roman-row{align-items:center;gap:6px;display:flex}.speak-btn{color:#a78bfa;cursor:pointer;background:#a78bfa1a;border:1px solid #a78bfa4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-family:inherit;transition:background .2s,border-color .2s,transform .15s;display:inline-flex}.speak-btn:hover{background:#a78bfa38;border-color:#a78bfa8c;transform:scale(1.1)}.speak-btn.speaking{color:#ff6fb7;background:#ff6bb72e;border-color:#ff6bb780;animation:.8s ease-in-out infinite alternate speak-pulse}.speak-btn-sm{width:22px;height:22px}.speak-btn-sm svg{width:12px;height:12px}@keyframes speak-pulse{0%{box-shadow:0 0 #ff6bb766}to{box-shadow:0 0 0 5px #ff6bb700}}.speak-waves{align-items:center;gap:2px;height:14px;display:flex}.speak-waves span{background:#ff6fb7;border-radius:2px;width:2px;animation:.6s ease-in-out infinite alternate wave-bar;display:block}.speak-waves span:first-child{height:6px;animation-delay:0s}.speak-waves span:nth-child(2){height:12px;animation-delay:.15s}.speak-waves span:nth-child(3){height:8px;animation-delay:.3s}@keyframes wave-bar{0%{opacity:.6;transform:scaleY(.4)}to{opacity:1;transform:scaleY(1)}}.card-hint{color:#e2d9f338;align-items:center;gap:4px;margin-top:6px;font-size:11px;display:flex}.status-dot{border-radius:50%;width:8px;height:8px;position:absolute;top:12px;right:12px}.status-dot.dot-known{background:#4ade80;box-shadow:0 0 6px #4ade8099}.status-dot.dot-review{background:#fb923c;box-shadow:0 0 6px #fb923c99}.flip-card-back{background:linear-gradient(145deg,#ff6bb71a,#a78bfa1a);border:1px solid #ff6bb733;flex-direction:column;justify-content:space-between;padding:16px;display:flex;transform:rotateY(180deg)}.back-top{flex-direction:column;gap:4px;display:flex}.back-korean-row{align-items:center;gap:6px;display:flex}.back-korean-small{color:#e2d9f366;font-family:Noto Sans KR,Poppins,sans-serif;font-size:12px}.back-english{color:#f3f4f6;letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1.2}.back-example{background:#0003;border-radius:10px;margin-top:4px;padding:8px 10px}.back-example-ko{color:#f9a8d4;margin-bottom:2px;font-family:Noto Sans KR,Poppins,sans-serif;font-size:11px;line-height:1.5}.back-example-en{color:#e2d9f366;font-size:10px;font-style:italic;line-height:1.4}.back-actions{gap:6px;display:flex}.btn-known,.btn-review{cursor:pointer;letter-spacing:.2px;border:none;border-radius:10px;flex:1;padding:7px 6px;font-family:Poppins,sans-serif;font-size:11px;font-weight:700;transition:opacity .15s,transform .15s}.btn-known{color:#4ade80;background:#4ade8026;border:1px solid #4ade804d}.btn-known:hover{background:#4ade8040;transform:translateY(-1px)}.btn-review{color:#fb923c;background:#fb923c1f;border:1px solid #fb923c40}.btn-review:hover{background:#fb923c38;transform:translateY(-1px)}.vocab-empty{text-align:center;color:#e2d9f359;grid-column:1/-1;padding:48px 0;font-size:15px}.vocab-empty-icon{margin-bottom:12px;font-size:32px;display:block}.vocab-reset{justify-content:center;margin-top:32px;display:flex}.reset-btn{color:#e2d9f366;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:8px 20px;font-family:Poppins,sans-serif;font-size:13px;font-weight:500;transition:all .2s;display:flex}.reset-btn:hover{color:#e2d9f3a6;border-color:#ff6bb740}@media (width<=768px){.learn-page{padding:0 16px 60px}.song-hero{flex-direction:column;gap:12px}.vocab-grid{grid-template-columns:repeat(2,1fr);gap:10px}.flip-card{height:180px}.card-korean{font-size:30px}.back-english{font-size:18px}.breadcrumb{display:none}}@media (width<=480px){.vocab-grid{grid-template-columns:1fr 1fr;gap:8px}.flip-card{height:165px}.card-korean{font-size:26px}.back-english{font-size:16px}.back-example{display:none}}.auth-backdrop{z-index:1000;-webkit-backdrop-filter:blur(10px);background:#07000fbf;justify-content:center;align-items:center;padding:20px;animation:.2s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.auth-modal{background:#12081ef2;border:1px solid #ff6bb733;border-radius:24px;width:100%;max-width:420px;padding:36px 32px 32px;animation:.28s cubic-bezier(.34,1.56,.64,1) modal-in;position:relative;box-shadow:0 0 0 1px #ffffff0a,0 24px 80px #000000b3,0 0 60px #ff6bb714}@keyframes modal-in{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-close{color:#e2d9f380;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:18px;line-height:1;transition:background .2s,color .2s;display:flex;position:absolute;top:16px;right:16px}.auth-close:hover{color:#f9a8d4;background:#ff6bb71f}.auth-logo{justify-content:center;align-items:center;gap:8px;margin-bottom:24px;display:flex}.auth-logo-star{color:#ff6fb7;font-size:18px;animation:10s linear infinite spin-slow;display:inline-block}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-logo-text{letter-spacing:-.5px;background:linear-gradient(135deg,#ff6fb7,#c084fc,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.auth-tabs{background:#ffffff0a;border:1px solid #ffffff12;border-radius:12px;margin-bottom:28px;padding:4px;display:flex}.auth-tab{color:#e2d9f373;cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;padding:9px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600;transition:background .2s,color .2s}.auth-tab.active{color:#f9a8d4;background:linear-gradient(135deg,#ff6bb733,#a78bfa33);box-shadow:0 1px 4px #0000004d}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-label{color:#e2d9f3a6;letter-spacing:.2px;font-size:13px;font-weight:600}.auth-input-wrap{position:relative}.auth-input{color:#f3f4f6;box-sizing:border-box;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-family:Poppins,sans-serif;font-size:15px;transition:border-color .2s,background .2s,box-shadow .2s}.auth-input::placeholder{color:#e2d9f340}.auth-input:focus{background:#ff6bb70d;border-color:#ff6bb780;box-shadow:0 0 0 3px #ff6bb71a}.auth-input.has-toggle{padding-right:46px}.pw-toggle{color:#e2d9f359;cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.pw-toggle:hover{color:#e2d9f3b3}.auth-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444440;border-radius:10px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:13px;line-height:1.45;display:flex}.auth-error svg{flex-shrink:0;margin-top:1px}.auth-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff6fb7,#c084fc);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:13px;font-family:Poppins,sans-serif;font-size:15px;font-weight:700;transition:opacity .2s,transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 20px #ff6bb74d}.auth-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 6px 28px #ff6bb773}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-switch{text-align:center;color:#e2d9f366;margin-top:20px;font-size:13px}.auth-switch-btn{color:#f9a8d4;cursor:pointer;background:0 0;border:none;padding:0 2px;font-family:Poppins,sans-serif;font-size:13px;font-weight:600;transition:color .2s}.auth-switch-btn:hover{color:#ff6fb7}.auth-success{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:8px 0 16px;display:flex}.auth-success-icon{color:#4ade80;background:linear-gradient(135deg,#4ade8033,#4ade801a);border:1px solid #4ade8059;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.auth-success h3{color:#f3f4f6;letter-spacing:-.3px;font-size:18px;font-weight:700}.auth-success p{color:#e2d9f38c;max-width:280px;font-size:14px;line-height:1.6}.auth-success-close{color:#4ade80;cursor:pointer;background:#4ade801f;border:1px solid #4ade804d;border-radius:20px;margin-top:8px;padding:10px 28px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600;transition:background .2s}.auth-success-close:hover{background:#4ade8038}.app{width:100%;max-width:1140px;margin:0 auto;padding:0 24px;position:relative}.bg-orbs{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.orb{filter:blur(80px);opacity:.18;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#ff6fb7,#0000 70%);width:500px;height:500px;animation:18s ease-in-out infinite alternate orb-drift;top:-120px;left:-100px}.orb-2{background:radial-gradient(circle,#a78bfa,#0000 70%);width:400px;height:400px;animation:22s ease-in-out infinite alternate-reverse orb-drift;bottom:0;right:-80px}.orb-3{background:radial-gradient(circle,#f472b6,#0000 70%);width:300px;height:300px;animation:12s ease-in-out infinite orb-pulse;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes orb-drift{0%{transform:translate(0)}to{transform:translate(40px,30px)}}@keyframes orb-pulse{0%,to{opacity:.06;transform:translate(-50%,-50%)scale(1)}50%{opacity:.12;transform:translate(-50%,-50%)scale(1.2)}}.sparkles{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.sparkle{color:#ff6fb7;opacity:0;animation:10s ease-in-out infinite sparkle-float;position:absolute}.s1{font-size:11px;animation-duration:8s;animation-delay:0s;top:12%;left:4%}.s2{color:#a78bfa;font-size:16px;animation-duration:10s;animation-delay:1.8s;top:8%;left:88%}.s3{font-size:8px;animation-duration:7s;animation-delay:3.2s;top:75%;left:25%}.s4{color:#a78bfa;font-size:14px;animation-duration:9s;animation-delay:.5s;top:55%;left:72%}.s5{font-size:10px;animation-duration:11s;animation-delay:2.5s;top:88%;left:50%}.s6{color:#c084fc;font-size:7px;animation-duration:8s;animation-delay:4.5s;top:45%;left:12%}.s7{color:#f9a8d4;font-size:12px;animation-duration:9s;animation-delay:1s;top:40%;left:95%}@keyframes sparkle-float{0%{opacity:0;transform:translateY(0)rotate(0)scale(.6)}20%{opacity:.7}50%{opacity:.4;transform:translateY(-28px)rotate(180deg)scale(1)}80%{opacity:.7}to{opacity:0;transform:translateY(-56px)rotate(360deg)scale(.6)}}.header{z-index:200;-webkit-backdrop-filter:blur(24px);background:#07000fbf;border-bottom:1px solid #ff6bb71a;margin:0 -24px;padding:0 24px;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:24px;max-width:1140px;height:64px;margin:0 auto;display:flex}.logo{flex-shrink:0;align-items:center;gap:8px;display:flex}.logo-star{color:#ff6fb7;font-size:18px;animation:10s linear infinite spin-slow;display:inline-block}.logo-text{letter-spacing:-.5px;background:linear-gradient(135deg,#ff6fb7,#c084fc,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.nav{flex:1;justify-content:center;gap:2px;display:flex}.nav-link{color:#e2d9f38c;border-radius:20px;padding:6px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s,background .2s}.nav-link:hover{color:#e2d9f3;background:#ff6bb714}.nav-link.nav-active{color:#ff6fb7;background:#ff6bb71a}.logo-btn{cursor:pointer;background:0 0;border:none;padding:0}.header-cta{color:#fff;background:linear-gradient(135deg,#ff6fb7,#a78bfa);border:none;border-radius:20px;flex-shrink:0;padding:8px 20px;font-size:13px;font-weight:600;transition:opacity .2s,transform .2s}.header-cta:hover{opacity:.88;transform:translateY(-1px)}.auth-btns{flex-shrink:0;align-items:center;gap:8px;display:flex}.nav-login-btn{color:#e2d9f3b3;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:20px;padding:7px 16px;font-family:Poppins,sans-serif;font-size:13px;font-weight:600;transition:border-color .2s,color .2s}.nav-login-btn:hover{color:#f9a8d4;border-color:#ff6bb766}.user-area{flex-shrink:0;align-items:center;gap:10px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#ff6fb7,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex;box-shadow:0 0 0 2px #ff6bb74d}.user-email{color:#e2d9f380;white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:13px;font-weight:400;overflow:hidden}.signout-btn{color:#e2d9f38c;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:6px 14px;font-family:Poppins,sans-serif;font-size:12px;font-weight:600;transition:background .2s,color .2s,border-color .2s}.signout-btn:hover{color:#f9a8d4;background:#ff6bb71a;border-color:#ff6bb74d}@media (width<=640px){.user-email{display:none}}.live-dot{background:#ff6fb7;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.8s ease-in-out infinite live-pulse;display:inline-block}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 #ff6bb780}50%{opacity:.7;transform:scale(1.2);box-shadow:0 0 0 4px #ff6bb700}}.hero{z-index:1;text-align:center;padding:88px 0 64px;position:relative}.hero-badge{color:#f9a8d4;letter-spacing:.2px;background:#ff6bb71a;border:1px solid #ff6bb747;border-radius:20px;align-items:center;gap:8px;margin-bottom:28px;padding:6px 16px;font-size:13px;font-weight:500;display:inline-flex}.hero-title{letter-spacing:-2.5px;color:#f3f4f6;margin-bottom:22px;font-size:clamp(44px,7vw,78px);font-weight:900;line-height:1.08}.hero-sub{color:#e2d9f399;max-width:480px;margin:0 auto 40px;font-size:17px;font-weight:400;line-height:1.75}.hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:48px;display:flex}.btn-primary{color:#fff;letter-spacing:.1px;background:linear-gradient(135deg,#ff6fb7,#c084fc);border:none;border-radius:50px;padding:14px 32px;font-size:15px;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 24px #ff6bb761}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 36px #ff6bb78c}.btn-ghost{color:#e2d9f3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0d;border:1px solid #ffffff1f;border-radius:50px;padding:14px 32px;font-size:15px;font-weight:500;transition:background .2s,border-color .2s,transform .2s}.btn-ghost:hover{background:#ffffff17;border-color:#ff6bb759;transform:translateY(-2px)}.hero-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:50px;align-items:center;gap:28px;padding:16px 36px;display:inline-flex}.stat{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-num{letter-spacing:-.5px;background:linear-gradient(135deg,#ff6fb7,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800}.stat-lbl{color:#e2d9f373;text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:600}.stat-sep{background:#ffffff17;flex-shrink:0;width:1px;height:30px}.top10{z-index:1;padding-bottom:80px;position:relative}.section-head{text-align:center;margin-bottom:48px}.section-tag{color:#ff6fb7;text-transform:uppercase;letter-spacing:2px;align-items:center;gap:7px;margin-bottom:16px;font-size:12px;font-weight:700;display:inline-flex}.section-title{letter-spacing:-1.2px;color:#f3f4f6;margin-bottom:12px;font-size:clamp(28px,4.5vw,46px);font-weight:800;line-height:1.18}.section-sub{color:#e2d9f373;font-size:14px;font-weight:400}.songs-list{flex-direction:column;gap:10px;list-style:none;display:flex}.song-card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff0a;border:1px solid #ffffff12;border-radius:18px;align-items:center;gap:18px;padding:16px 22px 16px 18px;transition:background .25s,border-color .25s,transform .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden}.song-card:after{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#ff6bb70d,#a78bfa0d);transition:opacity .25s;position:absolute;inset:0}.song-card:hover{background:#fff1;border-color:#ff6bb747;transform:translateY(-2px);box-shadow:0 8px 32px #ff6bb71f}.song-card:hover:after{opacity:1}.rank-badge{text-align:center;flex-shrink:0;min-width:42px}.rank-number{letter-spacing:-2px;font-size:32px;font-weight:900;line-height:1}.rank-gold .rank-number{background:linear-gradient(160deg,#ffe259,#ffa751,#ffe259);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 10px #ffd70073);-webkit-background-clip:text;background-clip:text}.rank-silver .rank-number{background:linear-gradient(160deg,#e8e8e8,#9e9e9e,#e8e8e8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.rank-bronze .rank-number{background:linear-gradient(160deg,#d4956a,#7d4a1a,#d4956a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.rank-default .rank-number{background:linear-gradient(135deg,#a78bfa,#ff6fb7);-webkit-text-fill-color:transparent;opacity:.65;-webkit-background-clip:text;background-clip:text}.thumbnail-link{flex-shrink:0}.thumbnail-wrapper{border-radius:12px;width:164px;height:92px;position:relative;overflow:hidden}.thumbnail{object-fit:cover;width:100%;height:100%;transition:transform .35s,opacity .3s;display:block}.song-card:hover .thumbnail{transform:scale(1.06)}.thumbnail-overlay{opacity:0;background:#00000073;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:absolute;inset:0}.thumbnail-link:hover .thumbnail-overlay{opacity:1}.play-btn{background:#ffffffeb;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .2s;display:flex;transform:scale(.85)}.thumbnail-link:hover .play-btn{transform:scale(1)}.play-btn svg{fill:#07000f;margin-left:2px}.song-info{flex:1;min-width:0}.artist-name{color:#ff6fb7;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:4px;font-size:11px;font-weight:700}.song-title{color:#f3f4f6;letter-spacing:-.4px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:19px;font-weight:700;overflow:hidden}.song-title-ko{color:#e2d9f373;margin-bottom:10px;font-family:Noto Sans KR,Poppins,sans-serif;font-size:13px;font-weight:400}.song-meta{align-items:center;gap:12px;margin-bottom:12px;display:flex}.views-badge{color:#c4b5fdb3;background:#a78bfa1a;border-radius:10px;align-items:center;gap:4px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-flex}.views-badge svg{color:#a78bfa}.channel-name{color:#e2d9f34d;white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:11px;font-weight:400;overflow:hidden}.study-btn{color:#f9a8d4;letter-spacing:.2px;background:#ff6bb71a;border:1px solid #ff6bb747;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:background .2s,border-color .2s,transform .2s;display:inline-flex}.study-btn:hover{background:#ff6bb733;border-color:#ff6bb780;transform:translate(3px)}.study-btn svg{transition:transform .2s}.study-btn:hover svg{transform:translate(3px)}.footer{z-index:1;text-align:center;border-top:1px solid #ffffff0f;flex-direction:column;align-items:center;gap:8px;padding:40px 0 48px;display:flex;position:relative}.footer-logo{align-items:center;gap:8px;margin-bottom:4px;display:flex}.footer-tagline{color:#e2d9f361;font-size:14px;font-weight:400}.footer-copy{color:#e2d9f333;font-size:12px}@media (width<=768px){.app{padding:0 16px}.header{margin:0 -16px;padding:0 16px}.nav{display:none}.hero{padding:56px 0 48px}.hero-stats{gap:18px;padding:14px 24px}.stat-num{font-size:18px}.song-card{gap:12px;padding:12px 14px}.rank-badge{min-width:34px}.rank-number{font-size:24px}.thumbnail-wrapper{width:120px;height:68px}.song-title{font-size:16px}.channel-name{display:none}}@media (width<=480px){.hero-title{letter-spacing:-1.5px}.thumbnail-wrapper{width:96px;height:54px}.song-meta{margin-bottom:8px}.hero-stats{border-radius:16px;flex-wrap:wrap;justify-content:center}.stat-sep{display:none}}
