@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700&family=Noto+Serif+SC:wght@400;500;600;700&display=swap";.site-header{z-index:100;height:var(--header-h);background:var(--ink-alpha-40);-webkit-backdrop-filter:blur(12px);transition:background .3s;position:fixed;top:0;left:0;right:0}.site-header.nav-transparent{-webkit-backdrop-filter:none;background:0 0}.header-inner{max-width:var(--container);justify-content:space-between;align-items:center;height:100%;margin:0 auto;padding:0 24px;display:flex}.logo{font-family:var(--serif);color:var(--ivory);letter-spacing:.05em;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;display:flex}.logo-img{width:auto;height:40px;filter:contrast(1.15) brightness(1.08) drop-shadow(0 0 .5px var(--ivory-alpha-15));flex-shrink:0;display:block}.nav-links{gap:32px;list-style:none;display:flex}.nav-links a{color:var(--ivory);padding:4px 0;font-size:.9375rem;transition:color .3s;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--cinnabar)}.nav-links a.active:after{content:"";background:var(--cinnabar);height:2px;position:absolute;bottom:-2px;left:0;right:0}.header-right{align-items:center;gap:12px;display:flex}.btn-user{color:var(--ivory);opacity:.7;border:1px solid var(--ivory-alpha-15);cursor:pointer;white-space:nowrap;background:0 0;border-radius:9999px;padding:4px 14px;font-size:.8125rem;transition:all .2s}.btn-user:hover{opacity:1;border-color:var(--ivory-alpha-40)}.modal-overlay{z-index:300;opacity:0;pointer-events:none;background:#0009;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--ivory);color:var(--ink);border-radius:var(--radius-md);width:360px;max-width:90vw;padding:32px;box-shadow:0 20px 60px #00000080}body.theme-dark .modal{color:var(--ink)}body.theme-dark .modal .form-input{color:var(--ink);border-color:var(--silver);background:#fff}body.theme-dark .modal .form-input::placeholder{color:#12273366}.modal-title{font-family:var(--serif);color:var(--ink);margin-bottom:12px;font-size:1.125rem;font-weight:600}.modal-message{color:#122733b3;margin-bottom:24px;font-size:.9375rem;line-height:1.6}.modal-username{color:var(--cinnabar);font-weight:500}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.btn-modal{border-radius:var(--radius-sm);cursor:pointer;font-size:.9375rem;font-weight:500;font-family:var(--sans);padding:10px 24px;transition:all .2s}.btn-modal-cancel{border:1px solid var(--silver);color:#122733b3;background:0 0}.btn-modal-cancel:hover{border-color:var(--ink);color:var(--ink)}.btn-modal-confirm{background:var(--cinnabar);border:1px solid var(--cinnabar);color:var(--ivory)}.btn-modal-confirm:hover{background:var(--cinnabar-bright);border-color:var(--cinnabar-bright)}.menu-toggle{flex-direction:column;gap:5px;padding:8px;display:none}.menu-toggle span{background:var(--ivory);width:22px;height:2px;transition:all .3s;display:block}.mobile-drawer{background:var(--ink);z-index:200;width:280px;height:100vh;transition:right .35s var(--ease-out);padding:80px 32px 32px;display:none;position:fixed;top:0;right:-280px}.mobile-drawer.open{right:0}.mobile-drawer-overlay{background:var(--ink-alpha-60);z-index:199;opacity:0;transition:opacity .3s;display:none;position:fixed;inset:0}.mobile-drawer-overlay.open{opacity:1}.mobile-drawer nav{flex-direction:column;gap:24px;display:flex}.mobile-drawer nav a{color:var(--ivory);font-size:1.125rem;font-family:var(--serif);transition:color .3s}.mobile-drawer nav a:hover{color:var(--cinnabar)}.drawer-close{color:var(--ivory);padding:8px;font-size:1.5rem;position:absolute;top:20px;right:20px}@media (width<=768px){.nav-links{display:none}.menu-toggle{display:flex}.mobile-drawer{display:block}.mobile-drawer-overlay{pointer-events:none;display:block}.mobile-drawer-overlay.open{pointer-events:auto}}.login-page{min-height:100dvh;color:var(--ivory-alpha-85);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.login-card{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-lg);flex-direction:column;align-items:center;width:100%;max-width:380px;padding:32px;display:flex}.login-logo{font-family:var(--serif);color:var(--ivory);margin-bottom:32px;font-size:1.5rem;font-weight:700}.login-logo .accent{color:var(--cinnabar)}.qr-login{flex-direction:column;align-items:center;height:365px;display:flex}.qr-login-title{font-family:var(--serif);color:var(--ivory);margin-bottom:20px;font-size:1.125rem;font-weight:600}.qr-code-wrap{justify-content:center;align-items:center;display:flex;position:relative}.qr-code-wrap>iframe{background:0 0;border:none;display:block}.qr-code-img{object-fit:contain;width:100%;height:100%}.qr-code-loading{color:var(--ink);opacity:.4;font-size:.875rem}.qr-login-hint{color:var(--ivory-alpha-55);margin-top:16px;font-size:.875rem}.qr-countdown{color:var(--cinnabar)}.qr-login-error,.qr-login-expired{flex-direction:column;align-items:center;gap:16px;display:flex}.qr-login-error p,.qr-login-expired p{color:var(--ivory-alpha-65);font-size:.9375rem}.h5-login{text-align:center;flex-direction:column;align-items:center;display:flex}.h5-login-icon{color:var(--cinnabar);margin-bottom:16px}.h5-login-title{font-family:var(--serif);color:var(--ivory);margin-bottom:8px;font-size:1.125rem;font-weight:600}.h5-login-hint{color:var(--ivory-alpha-55);margin-bottom:24px;font-size:.875rem}.btn-wechat{color:var(--ivory);border-radius:var(--radius-full);cursor:pointer;font-size:1rem;font-weight:500;font-family:var(--sans);background:#07c160;border:none;align-items:center;gap:8px;padding:12px 32px;transition:background .2s;display:inline-flex}.btn-wechat:hover{background:#06ad56}.btn-wechat:active{background:#059a4c}.callback-page{min-height:100dvh;color:var(--ivory-alpha-85);justify-content:center;align-items:center;display:flex}.callback-page p{color:var(--ivory-alpha-55);font-size:.9375rem}.site-footer{background:var(--ink);color:var(--ivory);border-top:1px solid var(--ivory-alpha-15);padding:64px 0 24px;position:relative}.site-footer:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--cinnabar) 50%, transparent 100%);opacity:.6;height:2px;position:absolute;top:0;left:0;right:0}.site-layout .site-footer{flex-shrink:0}.footer-container{max-width:var(--container);margin:0 auto;padding:0 24px}.footer-grid{grid-template-columns:1.6fr 1fr 1.2fr;align-items:start;gap:48px;display:grid}.footer-col{min-width:0}.footer-col-title{font-family:var(--serif);color:var(--ivory);letter-spacing:.05em;margin-bottom:20px;padding-bottom:10px;font-size:.9375rem;font-weight:600;position:relative}.footer-col-title:after{content:"";background:var(--cinnabar);width:20px;height:2px;position:absolute;bottom:0;left:0}.footer-logo{font-family:var(--serif);color:var(--ivory);letter-spacing:.05em;align-items:baseline;gap:6px;margin-bottom:16px;font-size:1.5rem;font-weight:700;display:inline-flex}.footer-logo:hover{color:var(--ivory)}.footer-logo-accent{color:var(--cinnabar)}.footer-tagline{color:var(--ivory-alpha-65);margin-bottom:8px;font-size:.8125rem;line-height:1.8}.footer-tagline--muted{color:var(--ivory-alpha-40);font-size:.75rem}.footer-link-list{flex-direction:column;gap:12px;list-style:none;display:flex}.footer-link-list a{color:var(--ivory-alpha-65);font-size:.875rem;transition:color .25s;display:inline-block}.footer-link-list a:hover{color:var(--cinnabar);transform:translate(2px)}.footer-info-list{flex-direction:column;gap:14px;list-style:none;display:flex}.footer-info-list li{flex-direction:column;gap:4px;display:flex}.footer-info-label{color:var(--ivory-alpha-40);letter-spacing:.08em;text-transform:uppercase;font-size:.6875rem}.footer-info-value{color:var(--ivory-alpha-85);font-size:.875rem;line-height:1.5}.footer-info-link{color:var(--ivory-alpha-85);transition:color .25s}.footer-info-link:hover{color:var(--cinnabar)}.footer-wechat{position:relative}.footer-wechat-trigger{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;text-align:left;background:0 0;border:none;align-items:center;gap:6px;padding:0;transition:color .25s;display:inline-flex}.footer-wechat-trigger:after{content:"";opacity:.7;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B33020' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M7 7h10v10H7z'/><path d='M3 3l3 3M21 3l-3 3M3 21l3-3M21 21l-3-3'/></svg>");background-repeat:no-repeat;background-size:contain;flex-shrink:0;width:12px;height:12px;transition:opacity .25s,transform .25s;display:inline-block}.footer-wechat-trigger:hover{color:var(--cinnabar)}.footer-wechat-trigger:hover:after,.footer-wechat.is-open .footer-wechat-trigger:after{opacity:1;transform:scale(1.1)}.footer-wechat-qr{z-index:50;background:var(--ivory);border-radius:var(--radius-md);width:164px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;visibility:hidden;transition:opacity .2s var(--ease-out), visibility .2s;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;padding:12px;display:flex;position:absolute;bottom:calc(100% + 12px);left:0}.footer-wechat-qr:after{content:"";border:6px solid #0000;border-top-color:var(--ivory);filter:drop-shadow(0 2px 1px #0000000f);position:absolute;top:100%;left:32px}.footer-wechat-qr img{border-radius:var(--radius-sm);flex-shrink:0;display:block;width:140px!important;max-width:140px!important;height:140px!important;max-height:140px!important}.footer-wechat-qr-tip{color:var(--ink);letter-spacing:.05em;white-space:nowrap;flex-shrink:0;font-size:.75rem}.footer-wechat-trigger:hover .footer-wechat-qr,.footer-wechat-trigger:focus-visible .footer-wechat-qr,.footer-wechat.is-open .footer-wechat-qr{opacity:1;visibility:visible;pointer-events:auto}.footer-divider{background:var(--ivory-alpha-15);height:1px;margin:48px 0 24px}.footer-meta{flex-direction:column;align-items:center;gap:12px;display:flex}.footer-copyright{color:var(--ivory-alpha-55);letter-spacing:.02em;font-size:.8125rem}.footer-beian{color:var(--ivory-alpha-40);flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;font-size:.75rem;display:inline-flex}.footer-beian-link{color:var(--ivory-alpha-55);align-items:center;gap:4px;transition:color .25s;display:inline-flex}.footer-beian-link:hover{color:var(--cinnabar)}.footer-beian-sep{opacity:.5}.footer-police-shield{color:var(--cinnabar);align-items:center;display:inline-flex}body.theme-dark .site-footer{background:0 0}body.theme-dark .site-footer .footer-col-title{color:var(--ivory)}body.theme-dark .site-footer .footer-divider{background:var(--ivory-alpha-15)}@media (width<=1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}.footer-col--brand{grid-column:1/-1}}@media (width<=640px){.site-footer{border-top:4px solid var(--cinnabar);margin-top:48px;padding:48px 0 24px;box-shadow:0 -8px 24px #00000040}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-col--brand{grid-column:auto}.footer-divider{margin:32px 0 20px}.footer-beian{gap:8px;font-size:.6875rem}.footer-wechat-qr{left:0;transform:translateY(0)}}.mobile-tabbar{background:var(--ink);z-index:100;padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom));display:none;position:fixed;bottom:0;left:0;right:0}.mobile-tabbar-inner{justify-content:space-around;display:flex}.mobile-tabbar a{color:var(--ivory);opacity:.5;flex-direction:column;align-items:center;gap:2px;padding:4px 12px;font-size:.625rem;transition:opacity .2s;display:flex}.mobile-tabbar a.active{opacity:1;color:var(--cinnabar)}.mobile-tabbar svg{fill:currentColor;width:22px;height:22px}@media (width<=768px){.mobile-tabbar{display:block}}.floating-player-btn{bottom:calc(60px + env(safe-area-inset-bottom) + 16px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--ivory-alpha-15);z-index:200;background:#122733eb;border-radius:12px;align-items:center;gap:12px;height:56px;padding:0 12px;text-decoration:none;transition:transform .2s,opacity .2s;display:flex;position:fixed;left:16px;right:16px;box-shadow:0 4px 24px #00000080}.floating-player-btn:active{transform:scale(.98)}.floating-player-btn.hidden{opacity:0;pointer-events:none;transform:translateY(8px)}.floating-player-cover{background:linear-gradient(135deg,#104e61,#086977);border-radius:8px;flex-shrink:0;width:40px;height:40px;overflow:hidden}.floating-player-cover img{object-fit:cover;width:100%;height:100%}.floating-player-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.floating-player-title{color:var(--ivory);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.floating-player-artist{color:var(--ivory-alpha-55);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.floating-player-toggle{background:var(--cinnabar,#b33020);width:36px;height:36px;color:var(--ivory);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.floating-player-toggle:hover{background:var(--cinnabar-bright,#b71a1c)}@media (width>=769px){.floating-player-btn{width:320px;bottom:24px;left:auto;right:24px}}.hero{text-align:center;background:var(--ink);min-height:100dvh;padding-top:var(--header-h);isolation:isolate;justify-content:center;align-items:stretch;display:flex;position:relative;overflow:hidden}.hero:after{content:"";z-index:11;pointer-events:none;mix-blend-mode:soft-light;opacity:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:-50%}.hero-stage{z-index:1;width:100%;max-width:var(--container);aspect-ratio:4/3;justify-content:center;align-items:center;margin:0 auto;display:flex;position:relative;overflow:hidden;container-type:size}.hero-bg-glow{z-index:0;pointer-events:none;background:radial-gradient(85% 70% at 82% 15%,#b33020f2 0%,#b71a1cbf 18%,#b3302066 40%,#6a303333 60%,#0000 80%),radial-gradient(80% 70% at 15% 90%,#122733fa 0%,#104e61d9 25%,#08697773 50%,#0000 75%),radial-gradient(240px at 12% 28%,#0869778c 0%,#0000 65%),radial-gradient(65% 50% at 55% 100%,#104e61b3 0%,#0000 60%),linear-gradient(155deg,#122733 0%,#104e61 28%,#122733 50%,#6a3033 78%,#b33020 100%);position:absolute;inset:0}.hero-bg-fallback{z-index:0;pointer-events:none;background-image:url(/ui/%E8%83%8C%E6%99%AF%20%E6%97%A0%E9%A3%98%E5%B8%A6.webp);background-position:50%;background-repeat:no-repeat;background-size:cover;position:absolute;inset:0}.hero-layer{pointer-events:none;-webkit-user-select:none;user-select:none;background-repeat:no-repeat;background-size:contain;position:absolute}.hero-layer-skyline{z-index:0;aspect-ratio:1080/417;opacity:.85;pointer-events:none;-webkit-user-select:none;user-select:none;background-image:url(/ui/%E5%8F%A0%E5%BA%95_%E5%9F%8E%E5%B8%82%E5%89%AA%E5%BD%B1.webp);background-position:bottom;background-repeat:no-repeat;background-size:contain;width:100%;max-width:1500px;margin:0 auto;position:absolute;bottom:0;left:0;right:0;transform:translateY(8%);-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 12% 88%,#0000 100%)}.hero-top-group{z-index:4;pointer-events:none;filter:drop-shadow(170px -105px 24px #fde1bd40)drop-shadow(170px -105px 48px #fde1bd26);animation:12s ease-in-out infinite alternate heroShapesFloat;position:absolute;inset:0}@keyframes heroShapesFloat{0%{transform:translateY(0)scale(1)}to{transform:translateY(-12px)scale(1.015)}}.hero-horse-head{aspect-ratio:1080/938;background-image:url(/ui/%E4%B8%8A-%E9%A9%AC%E5%A4%B4.webp);background-position:50%;background-repeat:no-repeat;background-size:contain;width:48%;position:absolute;top:10.8cqw;left:50%;transform:translate(-50%)}.hero-figure-top{aspect-ratio:609/530;filter:drop-shadow(0 0 8px #fde1bd99);background-image:url(/ui/%E5%B0%8F%E4%BA%BA-%E4%B8%8A.webp);background-position:50%;background-repeat:no-repeat;background-size:contain;width:9%;animation:4s ease-in-out infinite alternate heroFiguresGlow;position:absolute;top:18cqw;left:calc(50% + 6.25cqw)}.hero-cow-head{z-index:4;aspect-ratio:1080/820;opacity:.95;filter:drop-shadow(0 0 24px #fde1bd40)drop-shadow(0 0 48px #fde1bd26);pointer-events:none;background-image:url(/ui/%E4%B8%8B-%E7%BE%8A%E5%A4%B4.webp);background-position:50%;background-repeat:no-repeat;background-size:contain;width:58%;position:absolute;top:33.3cqw;left:50%;transform:translate(-50%)}.hero-actions-group{opacity:0;animation:fadeInUp .8s .8s var(--ease-out) forwards;flex-direction:column;align-items:center;gap:8px;display:flex}.hero-figure-bottom{aspect-ratio:699/812;filter:drop-shadow(0 0 8px #fde1bd99);background-image:url(/ui/%E5%B0%8F%E4%BA%BA-%E4%B8%8B.webp);background-position:50%;background-repeat:no-repeat;background-size:contain;width:8%;min-width:64px;animation:4s ease-in-out infinite alternate heroFiguresGlow;transform:translate(-40px,40px)}@keyframes heroFiguresGlow{0%{filter:brightness()drop-shadow(0 0 8px #fde1bd99)}to{filter:brightness(1.2)drop-shadow(0 0 18px #fde1bde6)}}.hero-bg{pointer-events:none;z-index:7;background:radial-gradient(at 20%,#b3302014 0%,#0000 60%),radial-gradient(at 80%,#0869771a 0%,#0000 60%);animation:8s ease-in-out infinite alternate heroPulse;position:absolute;inset:0}@keyframes heroPulse{0%{opacity:.2}to{opacity:.6}}.hero-content,.hero-line{z-index:10;position:relative}.hero-snow{pointer-events:none;z-index:9;position:absolute;inset:0;overflow:hidden}.hero-snowflake{opacity:0;will-change:transform, opacity;background:#fff6d0;border-radius:9999px;width:1.5px;height:7px;animation:linear infinite snowFall;position:absolute;top:-20px;transform:rotate(-45deg);box-shadow:0 0 3px #fff6d0b3,0 0 6px #fff0b466}.hero-snowflake:first-child{--drift:60vw;height:6px;animation-duration:11s;animation-delay:0s;left:2%}.hero-snowflake:nth-child(2){--drift:55vw;height:8px;animation-duration:14s;animation-delay:2s;left:6%}.hero-snowflake:nth-child(3){--drift:65vw;height:5px;animation-duration:10s;animation-delay:4s;left:10%}.hero-snowflake:nth-child(4){--drift:58vw;height:7px;animation-duration:13s;animation-delay:1s;left:14%}.hero-snowflake:nth-child(5){--drift:52vw;height:6px;animation-duration:15s;animation-delay:6s;left:18%}.hero-snowflake:nth-child(6){--drift:62vw;height:8px;animation-duration:12s;animation-delay:3s;left:22%}.hero-snowflake:nth-child(7){--drift:60vw;height:5px;animation-duration:11s;animation-delay:8s;left:26%}.hero-snowflake:nth-child(8){--drift:55vw;height:7px;animation-duration:14s;animation-delay:2.5s;left:30%}.hero-snowflake:nth-child(9){--drift:68vw;height:6px;animation-duration:10s;animation-delay:5s;left:34%}.hero-snowflake:nth-child(10){--drift:58vw;height:8px;animation-duration:13s;animation-delay:1.5s;left:38%}.hero-snowflake:nth-child(11){--drift:52vw;height:5px;animation-duration:12s;animation-delay:7s;left:42%}.hero-snowflake:nth-child(12){--drift:65vw;height:7px;animation-duration:15s;animation-delay:3.5s;left:46%}.hero-snowflake:nth-child(13){--drift:60vw;height:6px;animation-duration:11s;animation-delay:9s;left:50%}.hero-snowflake:nth-child(14){--drift:55vw;height:8px;animation-duration:14s;animation-delay:.5s;left:54%}.hero-snowflake:nth-child(15){--drift:63vw;height:5px;animation-duration:10s;animation-delay:6.5s;left:58%}.hero-snowflake:nth-child(16){--drift:58vw;height:7px;animation-duration:13s;animation-delay:4.5s;left:62%}.hero-snowflake:nth-child(17){--drift:52vw;height:6px;animation-duration:12s;animation-delay:8.5s;left:66%}.hero-snowflake:nth-child(18){--drift:62vw;height:8px;animation-duration:15s;animation-delay:2s;left:70%}.hero-snowflake:nth-child(19){--drift:60vw;height:5px;animation-duration:11s;animation-delay:5.5s;left:74%}.hero-snowflake:nth-child(20){--drift:55vw;height:7px;animation-duration:14s;animation-delay:7.5s;left:78%}.hero-snowflake:nth-child(21){--drift:68vw;height:6px;animation-duration:13s;animation-delay:1s;left:82%}.hero-snowflake:nth-child(22){--drift:58vw;height:8px;animation-duration:12s;animation-delay:4s;left:86%}.hero-snowflake:nth-child(23){--drift:60vw;height:5px;animation-duration:16s;animation-delay:9.5s;left:90%}.hero-snowflake:nth-child(24){--drift:52vw;height:7px;animation-duration:13s;animation-delay:3s;left:94%}.hero-snowflake:nth-child(25){--drift:63vw;height:6px;animation-duration:15s;animation-delay:6s;left:98%}.hero-snowflake:nth-child(26){--drift:65vw;height:8px;animation-duration:17s;animation-delay:.5s;left:4%}.hero-snowflake:nth-child(27){--drift:55vw;height:5px;animation-duration:16s;animation-delay:8s;left:16%}.hero-snowflake:nth-child(28){--drift:60vw;height:7px;animation-duration:18s;animation-delay:5s;left:28%}.hero-snowflake:nth-child(29){--drift:57vw;height:6px;animation-duration:12s;animation-delay:2.2s;left:8%}.hero-snowflake:nth-child(30){--drift:62vw;height:5px;animation-duration:16s;animation-delay:4.5s;left:12%}.hero-snowflake:nth-child(31){--drift:54vw;height:8px;animation-duration:11s;animation-delay:7.2s;left:20%}.hero-snowflake:nth-child(32){--drift:66vw;height:6px;animation-duration:14s;animation-delay:1.2s;left:24%}.hero-snowflake:nth-child(33){--drift:58vw;height:5px;animation-duration:13s;animation-delay:5.8s;left:32%}.hero-snowflake:nth-child(34){--drift:60vw;height:7px;animation-duration:15s;animation-delay:3.2s;left:36%}.hero-snowflake:nth-child(35){--drift:56vw;height:6px;animation-duration:12s;animation-delay:8.2s;left:40%}.hero-snowflake:nth-child(36){--drift:64vw;height:5px;animation-duration:16s;animation-delay:.8s;left:44%}.hero-snowflake:nth-child(37){--drift:58vw;height:8px;animation-duration:11s;animation-delay:6.2s;left:48%}.hero-snowflake:nth-child(38){--drift:62vw;height:6px;animation-duration:14s;animation-delay:2.8s;left:52%}.hero-snowflake:nth-child(39){--drift:54vw;height:5px;animation-duration:13s;animation-delay:9.2s;left:56%}.hero-snowflake:nth-child(40){--drift:60vw;height:7px;animation-duration:15s;animation-delay:4.2s;left:60%}.hero-snowflake:nth-child(41){--drift:56vw;height:6px;animation-duration:12s;animation-delay:7.8s;left:64%}.hero-snowflake:nth-child(42){--drift:64vw;height:5px;animation-duration:16s;animation-delay:1.8s;left:68%}.hero-snowflake:nth-child(43){--drift:58vw;height:8px;animation-duration:11s;animation-delay:5.2s;left:72%}.hero-snowflake:nth-child(44){--drift:62vw;height:6px;animation-duration:14s;animation-delay:3.8s;left:76%}.hero-snowflake:nth-child(45){--drift:54vw;height:5px;animation-duration:13s;animation-delay:8.8s;left:80%}.hero-snowflake:nth-child(46){--drift:60vw;height:7px;animation-duration:15s;animation-delay:.2s;left:84%}.hero-snowflake:nth-child(47){--drift:56vw;height:6px;animation-duration:12s;animation-delay:6.8s;left:88%}.hero-snowflake:nth-child(48){--drift:64vw;height:5px;animation-duration:16s;animation-delay:2.5s;left:92%}.hero-snowflake:nth-child(49){--drift:58vw;height:7px;animation-duration:13s;animation-delay:4.8s;left:96%}.hero-snowflake:nth-child(50){--drift:62vw;height:6px;animation-duration:14s;animation-delay:7.5s;left:1%}.hero-snowflake:nth-child(51){--drift:60vw;height:5px;animation-duration:12s;animation-delay:1.5s;left:3%}.hero-snowflake:nth-child(52){--drift:55vw;height:7px;animation-duration:15s;animation-delay:3.5s;left:7%}.hero-snowflake:nth-child(53){--drift:64vw;height:6px;animation-duration:11s;animation-delay:5.5s;left:11%}.hero-snowflake:nth-child(54){--drift:58vw;height:8px;animation-duration:14s;animation-delay:7.5s;left:15%}.hero-snowflake:nth-child(55){--drift:62vw;height:5px;animation-duration:13s;animation-delay:.5s;left:19%}.hero-snowflake:nth-child(56){--drift:54vw;height:6px;animation-duration:16s;animation-delay:2.5s;left:23%}.hero-snowflake:nth-child(57){--drift:66vw;height:7px;animation-duration:12s;animation-delay:4.5s;left:27%}.hero-snowflake:nth-child(58){--drift:58vw;height:5px;animation-duration:15s;animation-delay:6.5s;left:31%}.hero-snowflake:nth-child(59){--drift:60vw;height:6px;animation-duration:11s;animation-delay:8.5s;left:35%}.hero-snowflake:nth-child(60){--drift:56vw;height:8px;animation-duration:14s;animation-delay:1s;left:39%}.hero-snowflake:nth-child(61){--drift:64vw;height:5px;animation-duration:13s;animation-delay:3s;left:-28%}.hero-snowflake:nth-child(62){--drift:58vw;height:7px;animation-duration:16s;animation-delay:5s;left:-24%}.hero-snowflake:nth-child(63){--drift:62vw;height:6px;animation-duration:12s;animation-delay:7s;left:-20%}.hero-snowflake:nth-child(64){--drift:54vw;height:5px;animation-duration:15s;animation-delay:9s;left:-16%}.hero-snowflake:nth-child(65){--drift:60vw;height:7px;animation-duration:11s;animation-delay:.2s;left:-12%}.hero-snowflake:nth-child(66){--drift:56vw;height:6px;animation-duration:14s;animation-delay:2.2s;left:-8%}.hero-snowflake:nth-child(67){--drift:64vw;height:8px;animation-duration:13s;animation-delay:4.2s;left:-32%}.hero-snowflake:nth-child(68){--drift:58vw;height:5px;animation-duration:16s;animation-delay:6.2s;left:-22%}.hero-snowflake:nth-child(69){--drift:62vw;height:7px;animation-duration:12s;animation-delay:8.2s;left:-10%}.hero-snowflake:nth-child(70){--drift:54vw;height:6px;animation-duration:15s;animation-delay:1.2s;left:-18%}.hero-snowflake:nth-child(71){--drift:60vw;height:5px;animation-duration:11s;animation-delay:3.2s;left:-26%}.hero-snowflake:nth-child(72){--drift:66vw;height:7px;animation-duration:14s;animation-delay:5.2s;left:-14%}.hero-snowflake:nth-child(73){--drift:58vw;height:6px;animation-duration:13s;animation-delay:7.2s;left:-30%}.hero-snowflake:nth-child(74){--drift:62vw;height:5px;animation-duration:16s;animation-delay:9.2s;left:-6%}.hero-snowflake:nth-child(75){--drift:56vw;height:7px;animation-duration:12s;animation-delay:.8s;left:-34%}.hero-snowflake:nth-child(76){--drift:64vw;height:5px;animation-duration:15s;animation-delay:2.8s;left:-19%}.hero-snowflake:nth-child(77){--drift:58vw;height:6px;animation-duration:11s;animation-delay:4.8s;left:-25%}.hero-snowflake:nth-child(78){--drift:60vw;height:8px;animation-duration:14s;animation-delay:6.8s;left:-15%}.hero-snowflake:nth-child(79){--drift:62vw;height:5px;animation-duration:13s;animation-delay:8.8s;left:-21%}.hero-snowflake:nth-child(80){--drift:54vw;height:6px;animation-duration:16s;animation-delay:1.8s;left:-11%}@property --drift{syntax:"<length>";inherits:false;initial-value:30vw}@keyframes snowFall{0%{opacity:0;transform:translate(0)rotate(-45deg)}10%{opacity:.4}90%{opacity:.4}to{opacity:0;transform:translate(var(--drift), 105vh) rotate(-45deg)}}.hero-content{z-index:10;flex-direction:column;justify-content:center;gap:48px;padding:0;display:flex;position:relative}.hero-subtitle{font-family:var(--serif);color:var(--cinnabar);letter-spacing:.3em;opacity:0;animation:fadeInUp .8s .2s var(--ease-out) forwards;font-size:1.125rem}.hero-title{font-family:var(--serif);color:var(--ivory);font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.2}.hero-desc{color:var(--ivory);opacity:.4;max-width:560px;margin:0 auto 20px;font-size:.8rem}.hero-actions{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.hero-tagline{font-family:var(--serif);color:var(--ivory);opacity:0;letter-spacing:.2em;animation:fadeInUp .8s 1s var(--ease-out) forwards;margin-top:28px;font-size:.875rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-line{opacity:0;animation:fadeInUp .8s 1.2s var(--ease-out) forwards;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:absolute;bottom:60px;left:0;right:0}.hero-line span{color:var(--ivory);opacity:.4;letter-spacing:.1em;font-size:.75rem}.hero-line-mouse{border:2px solid var(--ivory);opacity:.4;border-radius:10px;width:20px;height:32px;position:relative}.hero-line-mouse:after{content:"";background:var(--ivory);border-radius:3px;width:3px;height:6px;animation:2s ease-in-out infinite scrollDot;position:absolute;top:6px;left:50%;transform:translate(-50%)}@keyframes scrollDot{0%,to{opacity:1;transform:translate(-50%)translateY(0)}50%{opacity:.3;transform:translate(-50%)translateY(8px)}}.btn-hero-primary{z-index:1;background:var(--cinnabar);color:var(--ivory);box-shadow:var(--shadow-cinnabar);padding:14px 40px;font-size:1rem;animation:3s ease-in-out infinite breathe;position:relative}.btn-hero-primary:hover{background:var(--cinnabar-bright);transform:translateY(-2px)}@keyframes breathe{0%,to{box-shadow:0 4px 20px #b330204d}50%{box-shadow:0 4px 40px #b3302080}}.btn-hero-secondary{z-index:1;border:1px solid var(--ivory-alpha-40);color:var(--ivory);padding:14px 40px;font-size:1rem;position:relative}.btn-hero-secondary:hover{border-color:var(--cinnabar);background:var(--ivory-alpha-08);color:var(--cinnabar)}.overview-grid{grid-template-columns:1fr 1fr;gap:16px;margin-top:28px;display:grid}.overview-item{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);padding:16px 20px}.overview-label{color:var(--ivory-alpha-40);margin-bottom:4px;font-size:.75rem}.overview-value{color:var(--ivory-alpha-85);font-size:1rem;font-weight:500}@media (width<=640px){.overview-grid{grid-template-columns:1fr}}.h-scroller{scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:20px;padding:4px 0 16px;display:flex;overflow-x:auto}.h-scroller::-webkit-scrollbar{display:none}.h-scroller .card{scroll-snap-align:start;background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-sm);flex:0 0 220px}.h-scroller .card:hover{background:var(--ivory-alpha-08);box-shadow:0 8px 32px #00000080}.h-scroller .rank-clef{color:#f0d060;text-shadow:0 0 6px #f0d060cc,0 0 16px #f0d06080,0 0 40px #f0d06040;font-size:4rem}.h-scroller .card-title{font-family:var(--serif);color:var(--ivory);font-size:1.5rem;font-weight:700}.h-scroller .card-title-row{gap:16px}.h-scroller .clef-author{font-size:.625rem}.h-scroller-pagination{justify-content:center;gap:8px;margin-top:24px;display:none}.h-scroller-dot{background:var(--ivory-alpha-15);cursor:pointer;border-radius:9999px;width:8px;height:8px;transition:width .3s,background .3s;position:relative;overflow:hidden}.h-scroller-dot:hover{background:var(--ivory-alpha-40)}.h-scroller-dot.active{background:var(--ivory-alpha-15);width:32px}.h-scroller-dot.active:after{content:"";background:var(--cinnabar);border-radius:9999px;width:0;height:100%;animation:4s linear forwards dotProgress;position:absolute;top:0;left:0}@keyframes dotProgress{0%{width:0}to{width:100%}}@media (width>=769px){.h-scroller-pagination{display:flex}}@media (width<=768px){.hero{min-height:calc(100dvh - var(--header-h))}.hero-line{display:none}.h-scroller{scroll-snap-type:y mandatory;flex-direction:column;max-height:none;overflow:visible auto}.h-scroller .card{scroll-snap-align:start;flex:none;width:100%}}@media (width<=480px){.hero-title{font-size:1.5rem}}.card{border-radius:var(--radius-md);border:1px solid var(--ivory-alpha-08);box-shadow:var(--shadow-sm);color:var(--ivory);background:#104e6159;transition:all .3s;overflow:hidden}.card:hover{box-shadow:var(--shadow-md);border-color:var(--ivory-alpha-15);transform:translateY(-4px)}.card-cover{background:linear-gradient(135deg,#104e61 0%,#086977 100%);width:100%;padding-top:100%;position:relative;overflow:hidden}.card-cover img{object-fit:cover;width:100%;transition:transform .4s;position:absolute;inset:0}.card:hover .card-cover img{transform:scale(1.05)}.card-cover-overlay{opacity:0;background:#12273380;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.card:hover .card-cover-overlay{opacity:1}.card-cover-overlay .play-icon{background:var(--cinnabar);width:48px;height:48px;box-shadow:var(--shadow-cinnabar);border-radius:50%;justify-content:center;align-items:center;display:flex}.card-cover-overlay .play-icon:after{content:"";border-style:solid;border-width:8px 0 8px 14px;border-color:transparent transparent transparent var(--ivory);width:0;height:0;margin-left:3px;display:block}.card-body{padding:16px}.card-title{color:var(--ivory);white-space:nowrap;text-overflow:ellipsis;margin-top:15px;margin-left:10px;font-size:1rem;font-weight:600;overflow:hidden}.card-meta{color:var(--ivory-alpha-55);justify-content:space-between;align-items:center;font-size:.8125rem;display:flex}.card-meta .votes{align-items:center;gap:4px;display:flex}.card-meta .votes:before{content:"♥";color:var(--cinnabar)}.badge{border-radius:var(--radius-full);align-items:center;padding:4px 12px;font-size:.75rem;font-weight:500;display:inline-flex}.badge-ongoing{background:var(--cinnabar-alpha-12);color:var(--cinnabar)}.badge-ended,.badge-pending{background:var(--ivory-alpha-08);color:var(--ivory-alpha-65)}.badge-approved{background:var(--cinnabar-alpha-12);color:var(--cinnabar)}.badge-rejected{color:var(--cinnabar-bright);background:#6a30334d}body.theme-dark .badge{color:var(--ivory)}.player-page{color:var(--ivory);background:var(--ink);position:fixed;inset:0;overflow:hidden}.player-bg-blur{z-index:0;filter:blur(60px)brightness(.4)saturate(1.2);pointer-events:none;background-position:50%;background-size:cover;position:absolute;inset:-80px}.player-bg-blur:after{content:"";background:linear-gradient(#12273366,#122733b3);position:absolute;inset:0}.player-page>.container,.player-slide .container{z-index:1;flex-direction:column;justify-content:space-between;align-items:center;height:100%;display:flex;position:relative}.stage-tabs{justify-content:center;gap:8px;max-width:640px;margin:0 auto 12px;display:flex}.tab-btn{border-radius:var(--radius-full);color:var(--ivory-alpha-40);background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);padding:6px 24px;font-size:.8125rem;transition:all .25s}.tab-btn.active{color:var(--ivory);background:var(--cinnabar);border-color:var(--cinnabar)}.tab-btn:hover:not(.active){color:var(--ivory-alpha-70);background:var(--ivory-alpha-08)}.player-stage{flex:0 auto;justify-content:center;align-items:stretch;width:50%;min-height:0;margin-bottom:0;padding-top:16px;display:flex;overflow:hidden}.stage-panels{scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;width:100%;max-width:640px;height:100%;display:flex;overflow-x:auto}.stage-panels::-webkit-scrollbar{display:none}.stage-panel{scroll-snap-align:start;flex:0 0 100%;height:100%}.bio-panel{justify-content:center;align-items:center;display:flex}.bio-inner{max-width:520px;padding:24px 32px}.bio-inner h4{font-family:var(--serif);color:var(--ivory);opacity:.9;margin-bottom:8px;font-size:1rem}.bio-inner h4:not(:first-child){margin-top:24px}.bio-inner p{color:var(--ivory-alpha-55);text-indent:2em;margin-bottom:0;font-size:.875rem;line-height:1.9}.player-lyrics-wrap{width:100%;height:100%}.lyrics-container{scrollbar-width:none;width:100%;height:100%;position:relative;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000,#000 10% 90%,#0000);mask-image:linear-gradient(#0000,#000 10% 90%,#0000)}.lyrics-container::-webkit-scrollbar{display:none}.lyrics-line{text-align:center;color:var(--ivory);opacity:.15;cursor:pointer;font-size:.9375rem;line-height:1.6;font-family:var(--serif);padding:10px 16px;transition:all .25s}.lyrics-line.near{opacity:.3}.lyrics-line.adjacent{opacity:.55}.lyrics-line.active{opacity:1;color:var(--cinnabar);font-size:1.0625rem;font-weight:600}.lyrics-back-btn{border-radius:var(--radius-full);color:var(--ivory);opacity:0;pointer-events:none;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#12273399;padding:4px 12px;font-size:.75rem;transition:opacity .3s;position:absolute;bottom:8px;right:8px}.lyrics-back-btn.visible{opacity:1;pointer-events:auto}.player-info-bar{text-align:center;width:100%;margin:48px 0 24px;padding:0}.player-info-top{padding-top:48px}.player-info-bottom{flex-shrink:0;margin-top:100px}.player-song-title{font-family:var(--serif);margin-bottom:2px;font-size:1.5rem;font-weight:600}.player-artist{opacity:.4;margin-bottom:8px;font-size:.9375rem}.player-bar-row{align-items:center;gap:16px;width:100%;display:flex}.player-bar-row .player-progress{flex:1}.player-progress{align-items:center;gap:10px;display:flex}.progress-time{font-family:var(--mono);color:var(--ivory);opacity:.4;min-width:38px;font-size:.75rem}.progress-bar{background:var(--ivory-alpha-15);cursor:pointer;border-radius:2px;flex:1;height:3px;position:relative}.progress-bar:hover{height:5px}.progress-filled{background:var(--cinnabar);border-radius:2px;width:0%;height:100%;transition:width .1s linear;position:relative}.progress-handle{background:var(--cinnabar);opacity:0;border-radius:50%;width:10px;height:10px;transition:opacity .2s;position:absolute;top:50%;right:-5px;transform:translateY(-50%)}.progress-bar:hover .progress-handle{opacity:1}.btn-vote-inline{border-radius:var(--radius-full);background:var(--cinnabar);height:44px;color:var(--ivory);white-space:nowrap;flex-shrink:0;justify-content:center;align-items:center;gap:5px;padding:0 14px;font-size:.75rem;font-weight:600;transition:all .3s;display:inline-flex;position:relative}.btn-vote-inline:hover{background:var(--cinnabar-bright)}.btn-vote-inline.voted{background:var(--ivory-alpha-15);color:var(--ivory);opacity:.5;cursor:default}.btn-play-toggle{background:var(--cinnabar);width:44px;height:44px;color:var(--ivory);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:transform .2s,opacity .2s;display:inline-flex}.btn-play-toggle:hover{transform:scale(1.08)}.btn-play-toggle:active{transform:scale(.95)}.btn-play-toggle:disabled{opacity:.5;cursor:not-allowed}.btn-action-icon{background:var(--ivory-alpha-08);width:32px;height:32px;color:var(--ivory);opacity:.6;border-radius:32px;flex-shrink:0;justify-content:center;align-items:center;transition:all .25s;display:inline-flex}.btn-action-icon:hover{opacity:1;background:var(--ivory-alpha-15)}.vote-hint{color:var(--ivory);opacity:.25;text-align:center;margin-top:8px;font-size:.6875rem}.swipe-hint{z-index:50;border-radius:var(--radius-full);color:var(--ivory);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ivory-alpha-15);pointer-events:none;opacity:0;background:#122733d9;padding:10px 28px;font-size:.875rem;font-weight:500;transition:opacity .4s,transform .4s;position:fixed;left:50%;transform:translate(-50%)}.swipe-hint.top{top:80px}.swipe-hint.bottom{bottom:72px}.swipe-hint.show{opacity:1}@keyframes hintFlash{0%{opacity:0;transform:translate(-50%)translateY(8px)}15%{opacity:1;transform:translate(-50%)translateY(0)}85%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-4px)}}.swipe-hint.flash{animation:2s forwards hintFlash}.player-page .bio-content h4{color:var(--ivory);opacity:.8}.player-page .bio-content p{color:var(--ivory);opacity:.45}@keyframes voteBump{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.vote-float{color:var(--cinnabar);pointer-events:none;font-size:1.25rem;font-weight:700;animation:.8s ease-out forwards voteFloat;position:absolute;top:0;left:50%;transform:translate(-50%)}@keyframes voteFloat{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-32px)}}.player-slides{position:absolute;inset:0;overflow:hidden}.player-slide{z-index:1;will-change:transform;position:absolute;inset:0;overflow:hidden}.player-slide.player-drag-neighbor{z-index:0}.player-slide.player-slide-transition{z-index:2;transition:transform .35s cubic-bezier(.22,1,.36,1)}.player-slide.player-slide-transition.player-drag-neighbor{z-index:0}.btn-vote{background:var(--cinnabar);color:var(--ivory);border-radius:var(--radius-full);padding:12px 36px;font-size:.9375rem;font-weight:600;transition:all .3s}.btn-vote:hover{background:var(--cinnabar-bright);transform:scale(1.05)}.btn-vote.voted{background:var(--silver);color:var(--ink-alpha-40);cursor:default;transform:none}.btn-vote.disabled{background:var(--silver);color:var(--ink-alpha-40);cursor:not-allowed;transform:none}.boundary-hint{z-index:50;border-radius:var(--radius-full);color:var(--ivory);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ivory-alpha-15);pointer-events:none;opacity:0;background:#122733d9;padding:10px 24px;font-size:.875rem;transition:opacity .3s;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.boundary-hint.visible{opacity:1}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.bio-inner{padding:16px 20px}}.step-indicator{justify-content:center;align-items:center;gap:0;margin-bottom:48px;display:flex}.step-item{flex-direction:column;align-items:center;gap:6px;display:flex}.step-num{border:2px solid var(--ivory-alpha-15);width:32px;height:32px;color:var(--ivory-alpha-40);border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;transition:all .3s;display:flex}.step-item.active .step-num,.step-item.done .step-num{border-color:var(--cinnabar);background:var(--cinnabar);color:var(--ivory)}.step-label{color:var(--ivory-alpha-40);font-size:.875rem}.step-item.active .step-label,.step-item.done .step-label{color:var(--ivory)}.step-connector{background:var(--ivory-alpha-15);flex:1;align-self:flex-start;min-width:40px;max-width:80px;height:2px;margin:15px 4px 0}.step-item.done+.step-connector,.step-connector.done{background:var(--cinnabar)}.form-group{margin-bottom:20px}.form-label{color:var(--ivory-alpha-85);margin-bottom:8px;font-size:.875rem;font-weight:600;display:block}.form-label .required{color:var(--cinnabar);margin-left:2px}.form-input,.form-textarea{border:1px solid var(--ivory-alpha-15);border-radius:var(--radius-sm);background:var(--ivory-alpha-04);width:100%;color:var(--ivory);outline:none;padding:12px 16px;font-size:1rem;transition:all .2s}.form-input:focus,.form-textarea:focus{border-color:var(--cinnabar);box-shadow:0 0 0 3px var(--cinnabar-alpha-12)}.form-input::placeholder,.form-textarea::placeholder{color:var(--ivory-alpha-40)}.form-textarea{resize:vertical;min-height:120px}.char-count{text-align:right;color:var(--ivory-alpha-40);margin-top:4px;font-size:.75rem}.form-step{display:none}.form-step.active{animation:fadeIn .4s var(--ease-out);display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.checkbox-group{align-items:flex-start;gap:10px;margin-bottom:16px;display:flex}.checkbox-group input[type=checkbox]{width:18px;height:18px;accent-color:var(--cinnabar);flex-shrink:0;margin-top:2px}.checkbox-group label{color:var(--ivory-alpha-85);font-size:.875rem;line-height:1.5}.guide-banner{background:var(--cinnabar-alpha-12);border:1px solid var(--cinnabar-alpha-30);border-radius:var(--radius-md);align-items:center;gap:20px;margin-bottom:32px;padding:16px 24px;display:flex}.guide-banner h4{color:var(--cinnabar);margin-bottom:4px;font-size:.9375rem}.guide-banner p{color:var(--ivory-alpha-65);font-size:.8125rem;line-height:1.6}@media (width<=640px){.guide-banner{flex-direction:column;align-items:flex-start}}.lyrics-type-toggle{gap:8px;margin-bottom:12px;display:flex}.lyrics-type-btn{border-radius:var(--radius-full);border:1px solid var(--ivory-alpha-15);color:var(--ivory-alpha-65);background:0 0;padding:4px 16px;font-size:.8125rem;transition:all .2s}.lyrics-type-btn.active{border-color:var(--cinnabar);color:var(--cinnabar);background:var(--cinnabar-alpha-12)}.work-upload-item{border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);background:var(--ivory-alpha-04);color:var(--ivory);margin-bottom:24px;padding:24px}.work-upload-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.work-upload-header h4{font-family:var(--serif);color:var(--ivory)}.floating-cta{z-index:50;position:fixed;bottom:32px;right:32px}.floating-cta .btn{box-shadow:var(--shadow-md);animation:3s ease-in-out infinite floatPulse}@keyframes floatPulse{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.confirm-box{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);color:var(--ivory-alpha-85);margin-bottom:24px;padding:24px}.confirm-notice{border-radius:var(--radius-md);background:var(--cinnabar-alpha-12);border:1px solid var(--cinnabar-alpha-30);color:var(--ivory);padding:16px 20px;font-size:.875rem;line-height:1.8}@media (width<=768px){.step-indicator{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:32px}.step-item{flex-direction:row;gap:10px}.step-connector{width:2px;height:16px;min-width:unset;max-width:unset;background:var(--ivory-alpha-40);margin:4px 0 4px 15px;margin-top:unset;flex:none;align-self:flex-start}.floating-cta{bottom:80px;right:16px}}.upload-zone{border:2px dashed var(--ivory-alpha-15);border-radius:var(--radius-md);background:var(--ivory-alpha-04);cursor:pointer;min-height:120px;color:var(--ivory-alpha-85);flex-direction:column;justify-content:center;align-items:center;padding:24px;transition:all .2s;display:flex}.upload-zone:hover,.upload-zone.dragover{border-color:var(--cinnabar);background:var(--cinnabar-alpha-12)}.upload-zone-icon{opacity:.4;color:var(--ivory-alpha-55);margin-bottom:8px;font-size:2rem}.upload-zone-text{color:var(--ivory-alpha-55);font-size:.875rem}.upload-preview{background:var(--ivory-alpha-04);border-radius:var(--radius-sm);color:var(--ivory);align-items:center;gap:12px;padding:12px;display:flex}.upload-file-list{flex-direction:column;gap:8px;margin-top:12px;display:flex}.upload-preview-cover{border-radius:var(--radius-sm);background:linear-gradient(135deg,#104e61,#086977);width:60px;height:60px;overflow:hidden}.upload-preview-cover img{object-fit:cover;width:100%;height:100%}.upload-preview-info{flex:1;font-size:.875rem}.upload-preview-name{color:var(--ivory);margin-bottom:2px;font-weight:600}.upload-preview-size{color:var(--ivory-alpha-55);font-size:.75rem}.upload-remove{color:var(--ivory-alpha-55);padding:4px;font-size:1.25rem;transition:all .2s}.upload-remove:hover{color:var(--cinnabar)}body.theme-dark .upload-zone{background:var(--ivory-alpha-04);border-color:var(--ivory-alpha-15)}body.theme-dark .upload-zone:hover,body.theme-dark .upload-zone.dragover{background:var(--cinnabar-alpha-12);border-color:var(--cinnabar)}body.theme-dark .upload-preview{background:var(--ivory-alpha-04)}body.theme-dark .upload-remove{color:var(--ivory-alpha-55)}body.theme-dark .upload-remove:hover{color:var(--cinnabar)}.my-work-card{background:var(--ivory-alpha-04);border-radius:var(--radius-md);border:1px solid var(--ivory-alpha-08);color:var(--ivory);gap:16px;margin-bottom:12px;padding:20px;transition:box-shadow .3s,border-color .3s;display:flex}.my-work-card:hover{box-shadow:var(--shadow-sm);border-color:var(--ivory-alpha-15)}.my-work-thumb{border-radius:var(--radius-sm);background:linear-gradient(135deg,#104e61,#086977);flex-shrink:0;width:80px;height:80px;overflow:hidden}.my-work-thumb img{object-fit:cover;width:100%;height:100%}.my-work-info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.my-work-info .badge{align-self:flex-start}.my-work-title{color:var(--ivory);font-weight:600}.my-work-time{color:var(--ivory-alpha-55);font-size:.8125rem}.my-work-reason{color:var(--cinnabar);margin-top:4px;font-size:.8125rem}.reveal{opacity:0;transition:opacity .6s var(--ease-out), transform .6s var(--ease-out);transform:translateY(20px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}.list-hero{text-align:center;background:0 0;padding:80px 0 60px;position:relative;overflow:hidden}.list-hero:before{content:"";background:radial-gradient(ellipse at 30% 50%, var(--cinnabar-alpha-06) 0%, transparent 50%), radial-gradient(ellipse at 70% 50%, #0869771a 0%, transparent 50%);position:absolute;inset:0}.list-hero-content{z-index:2;position:relative}.list-hero h1{font-family:var(--serif);color:var(--ivory);margin-bottom:8px;font-size:2.25rem}.list-hero p{color:var(--ivory);opacity:.4;font-size:.9375rem}.list-hero-stats{justify-content:center;gap:48px;margin-top:32px;display:flex}.list-hero-stat{text-align:center}.list-hero-stat-num{font-family:var(--serif);color:var(--cinnabar);font-size:2rem;font-weight:700}.list-hero-stat-label{color:var(--ivory);opacity:.4;margin-top:4px;font-size:.8125rem}.filter-bar{justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 0;display:flex}.filter-sort{gap:8px;display:flex}.sort-btn{border-radius:var(--radius-full);border:1px solid var(--ivory-alpha-15);color:var(--ivory-alpha-65);background:var(--ivory-alpha-04);padding:6px 16px;font-size:.8125rem;transition:all .2s}.sort-btn.active,.sort-btn:hover{border-color:var(--cinnabar);color:var(--ivory);background:var(--cinnabar-alpha-30)}.grid>.card{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-sm);transition:transform .3s var(--ease-out), box-shadow .3s, background .3s;flex-direction:column;display:flex;overflow:hidden}.grid>.card:hover{background:var(--ivory-alpha-08);transform:translateY(-4px);box-shadow:0 8px 32px #00000080}.grid>.card .card-cover{flex-shrink:0;position:relative}.grid>.card .card-cover img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.grid>.card:hover .card-cover img{transform:scale(1.05)}.grid>.card .card-cover-overlay{opacity:0;background:#12273380;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.grid>.card:hover .card-cover-overlay{opacity:1}.card-cover-votes{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;background:#00000080;border-radius:3px;align-items:center;gap:3px;padding:4px 10px;font-size:.875rem;font-weight:600;display:flex;position:absolute;top:10px;right:10px}.card-cover-votes:before{content:"♥";color:var(--cinnabar);font-size:.8125rem}.grid>.card .card-body{border-top:1px solid var(--ivory-alpha-08);flex-direction:column;flex:1;justify-content:center;gap:4px;padding:12px 16px 14px;display:flex}.card-title-row{align-items:center;gap:16px;display:flex}.card-title-row .card-title{margin-bottom:0}.rank-clef{flex-shrink:0;font-size:4rem;line-height:1;position:relative}.rank-clef .clef-author{white-space:nowrap;color:var(--ivory-alpha-40);font-size:.625rem;position:absolute;top:12px;right:-30px}.rank-clef.rank-1{color:#ffd970;text-shadow:0 0 8px #ffd970e6,0 0 20px #ffd970b3,0 0 40px #c9a84c80,0 0 80px #c9a84c4d}.rank-clef.rank-2{color:#e0e0e0;text-shadow:0 0 8px #e0e0e0cc,0 0 20px #e0e0e099,0 0 40px #a0a0a066,0 0 80px #a0a0a033}.rank-clef.rank-3{color:#e8a060;text-shadow:0 0 8px #e8a060cc,0 0 20px #e8a06099,0 0 40px #b8733366,0 0 80px #b8733333}.grid>.card .card-title{font-family:var(--serif);color:var(--ivory);margin-bottom:0;font-size:1.5rem;font-weight:700}.pagination{justify-content:center;align-items:center;gap:4px;padding:32px 0;display:flex}.pagination button{border-radius:var(--radius-sm);border:1px solid var(--ivory-alpha-15);background:var(--ivory-alpha-08);min-width:36px;height:36px;color:var(--ivory-alpha-65);justify-content:center;align-items:center;font-size:.875rem;transition:all .2s;display:flex}.pagination button:hover{border-color:var(--cinnabar);color:var(--ivory)}.pagination button.active{background:var(--cinnabar);border-color:var(--cinnabar);color:var(--ivory)}@media (width<=768px){.filter-bar{flex-direction:column;align-items:stretch;gap:12px}.list-hero h1{font-size:1.75rem}.list-hero-stats{gap:24px}.list-hero-stat-num{font-size:1.5rem}}.track-grid{grid-template-columns:1fr;gap:16px;display:grid}.track-card{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);padding:20px 24px}.track-card-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.track-num{background:var(--cinnabar);width:28px;height:28px;color:var(--ivory);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8125rem;font-weight:600;display:inline-flex}.track-name{font-family:var(--serif);color:var(--ivory);font-size:1.0625rem;font-weight:600}.track-keywords{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.track-keyword{background:var(--cinnabar-alpha-12);color:var(--cinnabar);border-radius:9999px;padding:2px 10px;font-size:.75rem;display:inline-block}.track-desc{color:var(--ivory-alpha-65);text-indent:2em;font-size:.875rem;line-height:1.7}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--ivory-alpha-15);width:2px;position:absolute;top:4px;bottom:4px;left:9px}.timeline-item{padding-bottom:28px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--cinnabar);border:2px solid var(--ivory-alpha-15);border-radius:50%;width:12px;height:12px;position:absolute;top:6px;left:-20px}.timeline-content h4{font-family:var(--serif);color:var(--ivory);margin-bottom:4px;font-size:.9375rem}.timeline-content p{color:var(--ivory-alpha-40);font-size:.8125rem}.phase-card{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);margin-bottom:20px;padding:24px}.phase-card h4{font-family:var(--serif);color:var(--ivory);margin-bottom:4px;font-size:1.125rem}.phase-card .phase-time{color:var(--cinnabar);margin-bottom:12px;font-size:.8125rem}.phase-card ul{padding-left:0;list-style:none}.phase-card li{color:var(--ivory-alpha-70);margin-bottom:6px;padding-left:16px;font-size:.875rem;line-height:1.7;position:relative}.rule-section .phase-card li:before{content:"";background:var(--cinnabar);border-radius:50%;width:5px;height:5px;position:absolute;top:calc(50% - 2.5px);left:0}.register-methods{grid-template-columns:1fr;gap:16px;display:grid}.register-method{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);padding:20px 24px}.register-method h4{font-family:var(--serif);color:var(--ivory);margin-bottom:8px;font-size:1rem}.register-method p{color:var(--ivory-alpha-65);text-indent:2em;font-size:.875rem;line-height:1.7}.cta-block{text-align:center;border-top:1px solid var(--ivory-alpha-08);margin-top:40px;padding:40px 24px}.cta-block p{color:var(--ivory-alpha-70);font-size:1rem;line-height:1.8}.cta-block .cta-slogan{font-family:var(--serif);color:var(--ivory);margin-bottom:16px;font-size:1.25rem}.about-org{flex-direction:column;gap:16px;display:flex}.about-org-item{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);align-items:center;gap:16px;padding:16px;display:flex}.about-org-label{color:var(--ivory-alpha-40);white-space:nowrap;font-size:.75rem}.about-org-name{font-family:var(--serif);color:var(--ivory);font-size:1rem}.highlight-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.highlight-card{background:var(--ivory-alpha-04);border:1px solid var(--ivory-alpha-08);border-radius:var(--radius-md);padding:20px 24px}.highlight-card h4{font-family:var(--serif);color:var(--ivory);margin-bottom:8px;font-size:1rem}.highlight-card p{color:var(--ivory-alpha-65);text-indent:2em;font-size:.875rem;line-height:1.7}@media (width<=640px){.highlight-grid{grid-template-columns:1fr}}*,:before,:after{-webkit-tap-highlight-color:transparent;box-sizing:border-box;margin:0;padding:0}:root{--ink:#122733;--ink-2:#104e61;--ink-3:#086977;--cinnabar:#b33020;--cinnabar-bright:#b71a1c;--cinnabar-dark:#6a3033;--ivory:#fde1bd;--silver:#dcdddd;--cinnabar-alpha-06:#b330200f;--cinnabar-alpha-12:#b330201f;--cinnabar-alpha-30:#b330204d;--cinnabar-alpha-50:#b3302080;--ink-alpha-06:#1227330f;--ink-alpha-12:#1227331f;--ink-alpha-20:#12273333;--ink-alpha-40:#12273366;--ink-alpha-60:#12273399;--ink-alpha-85:#122733d9;--ivory-alpha-04:#fde1bd0a;--ivory-alpha-08:#fde1bd14;--ivory-alpha-15:#fde1bd26;--ivory-alpha-40:#fde1bd66;--ivory-alpha-55:#fde1bd8c;--ivory-alpha-65:#fde1bda6;--ivory-alpha-70:#fde1bdb3;--ivory-alpha-85:#fde1bdd9;--cyan-alpha-08:#08697714;--cyan-alpha-15:#08697726;--serif:"Noto Serif SC", "Source Han Serif SC", "STSong", Georgia, serif;--sans:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--mono:"Roboto Mono", "Menlo", monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000002e;--shadow-md:0 8px 24px #00000047;--shadow-lg:0 16px 48px #0006;--shadow-cinnabar:0 4px 20px var(--cinnabar-alpha-30);--container:1200px;--header-h:64px;--ease-out:cubic-bezier(.16, 1, .3, 1)}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--sans);background:var(--ivory);color:var(--ivory-alpha-85);-webkit-font-smoothing:antialiased;background:linear-gradient(#122733 0%,#104e61 60%,#122733 100%);line-height:1.6}body.theme-dark{color:var(--ivory-alpha-85);background:linear-gradient(#122733 0%,#104e61 60%,#122733 100%)}body.theme-dark .breadcrumb{color:var(--ivory-alpha-55)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit}.font-serif{font-family:var(--serif)}.font-sans{font-family:var(--sans)}.text-display{font-family:var(--serif);font-size:3rem;font-weight:700;line-height:1.2}.text-h1{font-family:var(--serif);font-size:2.25rem;font-weight:700;line-height:1.3}.text-h2{font-family:var(--serif);font-size:1.75rem;font-weight:600;line-height:1.3}.text-h3{font-size:1.25rem;font-weight:600}.text-body{font-size:1rem;font-weight:400}.text-caption{color:var(--ink);opacity:.6;font-size:.875rem}.text-micro{color:var(--ink);opacity:.5;font-size:.75rem}body .text-caption{color:var(--ivory-alpha-65);opacity:1}body .text-micro{color:var(--ivory-alpha-40);opacity:1}body.theme-dark .text-caption,body.theme-dark .text-micro{color:var(--ivory-alpha-40)}.text-cinnabar{color:var(--cinnabar)}.text-center{text-align:center}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}.section{padding:64px 0}.section-title{font-family:var(--serif);text-align:center;margin-bottom:48px;font-size:1.75rem;font-weight:600;position:relative}.section-title:after{content:"";background:var(--cinnabar);width:40px;height:2px;margin:12px auto 0;display:block}.grid{gap:24px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.btn{border-radius:var(--radius-sm);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:12px 32px;font-size:.9375rem;font-weight:600;transition:all .3s;display:inline-flex}.btn.block{width:100%}.btn-primary{background:var(--cinnabar);color:var(--ivory)}.btn-primary:hover{background:var(--cinnabar-bright);box-shadow:var(--shadow-cinnabar);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background:var(--silver);color:var(--ink-alpha-40);cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{border:1px solid var(--ivory-alpha-15);color:var(--ivory-alpha-85);background:0 0}.btn-secondary:hover{background:var(--ivory-alpha-08);border-color:var(--cinnabar);color:var(--ivory)}.page-with-header{padding-top:calc(var(--header-h) + 48px)}.site-layout{flex-direction:column;min-height:100vh;display:flex}.site-main{flex:1 0 auto}.rule-section{margin-bottom:40px}.rule-title{font-family:var(--serif);color:var(--ivory);border-bottom:1px solid var(--ivory-alpha-08);margin-bottom:16px;padding-bottom:8px;font-size:1.25rem}.rule-section p{color:var(--ivory-alpha-65);text-indent:2em;font-size:.9375rem;line-height:1.9}.rule-section ul{padding:0;list-style:none}.rule-section li{color:var(--ivory-alpha-65);padding:8px 0 8px 20px;font-size:.9375rem;line-height:1.8;position:relative}.rule-section li:before{content:"·";color:var(--cinnabar);font-weight:700;position:absolute;left:0}.notice-box{background:var(--cinnabar-alpha-06);border:1px solid var(--cinnabar-alpha-12);border-radius:var(--radius-md);margin-bottom:24px;padding:20px 24px}.notice-box ul{padding-left:0;list-style:none}.notice-box li{color:var(--ivory-alpha-70);margin-bottom:6px;padding-left:16px;font-size:.875rem;line-height:1.7;position:relative}.notice-box li:before{content:"";background:var(--cinnabar);border-radius:50%;width:5px;height:5px;position:absolute;top:1rem;left:0}.app-toast{z-index:9999;border-radius:var(--radius-full);color:var(--ivory);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ivory-alpha-15);pointer-events:none;opacity:0;background:#122733eb;padding:10px 28px;font-size:.875rem;transition:opacity .3s,transform .3s;position:fixed;top:20px;left:50%;transform:translate(-50%)translateY(-20px)}.app-toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=1024px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){:root{--header-h:56px}.text-display{font-size:2rem}.text-h1{font-size:1.75rem}.text-h2{font-size:1.5rem}.section{padding:48px 0}.section-title{margin-bottom:42px;font-size:1.5rem}.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.site-layout{padding-bottom:calc(60px + env(safe-area-inset-bottom))}}@media (width<=480px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.1s!important;animation-duration:.01ms!important}}
