/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-white:#fff;--spacing:.25rem;--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-neon-blue:#00d4ff}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.right-0{right:calc(var(--spacing) * 0)}.bottom-0{bottom:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.z-0{z-index:0}.z-\[60\]{z-index:60}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-0{height:calc(var(--spacing) * 0)}.h-\[3px\]{height:3px}.h-full{height:100%}.w-0{width:calc(var(--spacing) * 0)}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.overflow-hidden{overflow:hidden}.border{border-style:var(--tw-border-style);border-width:1px}.bg-neon-blue{background-color:var(--color-neon-blue)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.bg-white\/10{background-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.opacity-0{opacity:0}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-1000{--tw-duration:1s;transition-duration:1s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg:#08080f;--bg2:#0e0e1a;--bg3:#131320;--pink:#ff2d55;--cyan:#00f0ff;--yellow:#ffe600;--green:#39ff14;--text:#e8e8f0;--muted:#5a5a7a;--border:#1e1e32}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:VT323,monospace;font-size:18px;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:9999;display:var(--scanline-display,block);background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000026 2px 4px);position:fixed;inset:0}body:after{content:"";pointer-events:none;z-index:9998;background:radial-gradient(#0000 60%,#000000b3 100%);position:fixed;inset:0}.app{max-width:1280px;margin:0 auto;padding:24px 32px 48px}.header{text-align:center;padding:32px 0 28px;position:relative}.header-logo{letter-spacing:6px;color:var(--yellow);text-shadow:0 0 10px var(--yellow), 0 0 30px var(--yellow), 0 0 60px #ffe60066, 4px 4px 0 #ff640080;font-family:"Press Start 2P",monospace;font-size:42px;line-height:1.2;animation:8s infinite flicker}.header-sub{color:var(--pink);letter-spacing:8px;text-shadow:0 0 8px var(--pink);text-transform:uppercase;margin-top:10px;font-family:"Press Start 2P",monospace;font-size:10px}.header-divider{background:linear-gradient(90deg, transparent, var(--cyan), var(--pink), var(--yellow), var(--cyan), transparent);height:2px;box-shadow:0 0 12px var(--cyan);margin-top:24px}@keyframes flicker{0%,95%,to{opacity:1}96%{opacity:.85}97%{opacity:1}98%{opacity:.9}99%{opacity:1}}.header-logo:hover{animation:.3s infinite glitch}@keyframes glitch{0%{text-shadow:4px 0 var(--pink), -4px 0 var(--cyan), 0 0 10px var(--yellow), 0 0 30px var(--yellow)}25%{text-shadow:-4px 0 var(--pink), 4px 0 var(--cyan), 0 0 10px var(--yellow), 0 0 30px var(--yellow)}50%{text-shadow:0 4px var(--pink), 0 -4px var(--cyan), 0 0 10px var(--yellow), 0 0 30px var(--yellow)}75%{text-shadow:2px -2px var(--pink), -2px 2px var(--cyan), 0 0 10px var(--yellow), 0 0 30px var(--yellow)}to{text-shadow:4px 0 var(--pink), -4px 0 var(--cyan), 0 0 10px var(--yellow), 0 0 30px var(--yellow)}}.main-grid{grid-template-columns:1fr 320px;gap:24px;margin-top:28px;display:grid}.pixel-box{background:var(--bg2);border:2px solid var(--border);padding:24px;position:relative}.pixel-box:before{content:"";pointer-events:none;border:1px solid #00f0ff1f;position:absolute;inset:-4px}.box-title{letter-spacing:3px;color:var(--cyan);text-shadow:0 0 8px var(--cyan);align-items:center;gap:10px;margin-bottom:20px;font-family:"Press Start 2P",monospace;font-size:9px;display:flex}.box-title:after{content:"";background:linear-gradient(90deg, var(--cyan), transparent);opacity:.4;flex:1;height:1px}.import-row{gap:0;display:flex}.import-input{background:var(--bg);border:2px solid var(--muted);color:var(--cyan);letter-spacing:1px;border-right:none;outline:none;flex:1;padding:10px 16px;font-family:VT323,monospace;font-size:20px;transition:border-color .2s}.import-input::placeholder{color:var(--muted)}.import-input:focus{border-color:var(--cyan);box-shadow:inset 0 0 12px #00f0ff12,0 0 8px #00f0ff33}.import-btn{background:var(--cyan);color:var(--bg);border:2px solid var(--cyan);cursor:pointer;letter-spacing:1px;white-space:nowrap;padding:10px 18px;font-family:"Press Start 2P",monospace;font-size:8px;transition:all .15s}.import-btn:hover{background:var(--bg);color:var(--cyan);box-shadow:0 0 16px var(--cyan)}.import-btn:active{transform:translateY(1px)}.import-btn:disabled{opacity:.4;cursor:not-allowed}.song-list{flex-direction:column;gap:4px;max-height:460px;padding-right:4px;display:flex;overflow-y:auto}.song-list::-webkit-scrollbar{width:6px}.song-list::-webkit-scrollbar-track{background:var(--bg)}.song-list::-webkit-scrollbar-thumb{background:var(--muted)}.song-item{background:var(--bg3);border:1px solid var(--border);cursor:grab;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:8px 12px 8px 8px;transition:all .15s;display:flex;position:relative}.song-item:hover{border-color:var(--pink);background:#16162a;box-shadow:0 0 10px #ff2d5526}.song-item:hover .drag-handle{color:var(--pink)}.drag-handle{color:var(--muted);cursor:grab;flex-shrink:0;padding:0 4px;font-size:22px;line-height:1}.song-num{color:var(--muted);text-align:center;flex-shrink:0;width:20px;font-family:"Press Start 2P",monospace;font-size:8px}.song-thumb{background:var(--bg);border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:36px;display:flex;position:relative;overflow:hidden}.song-thumb img{object-fit:cover;width:100%;height:100%}.song-thumb-placeholder{width:100%;height:100%;color:var(--muted);background:repeating-linear-gradient(45deg,#1a1a2e,#1a1a2e 4px,#0e0e1a 4px 8px);justify-content:center;align-items:center;font-size:18px;display:flex}.song-info{flex:1;min-width:0}.song-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:20px;line-height:1.1;overflow:hidden}.song-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:16px;overflow:hidden}.song-timestamp{color:var(--yellow);text-shadow:0 0 6px var(--yellow);letter-spacing:1px;flex-shrink:0;font-family:"Press Start 2P",monospace;font-size:9px}.song-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:20px;line-height:1;transition:color .15s}.song-remove:hover{color:var(--pink)}.empty-state{text-align:center;color:var(--muted);padding:48px 24px}.empty-icon{opacity:.5;margin-bottom:12px;font-size:48px;display:block}.empty-text{letter-spacing:1px;font-family:"Press Start 2P",monospace;font-size:8px;line-height:2}.generate-wrap{justify-content:center;margin-top:20px;display:flex}.generate-btn{letter-spacing:2px;color:var(--bg);background:var(--pink);cursor:pointer;text-transform:uppercase;border:none;padding:18px 48px;font-family:"Press Start 2P",monospace;font-size:13px;transition:all .15s;position:relative;box-shadow:4px 4px #0009,0 0 20px #ff2d5566}.generate-btn:before{content:"";z-index:-1;background:#ff2d5540;position:absolute;inset:2px -2px -2px 2px}.generate-btn:hover{background:var(--yellow);transform:translate(-1px,-1px);box-shadow:4px 4px #0009,0 0 30px #ffe60080}.generate-btn:active{transform:translate(2px,2px);box-shadow:2px 2px #0009}.generate-btn:disabled{background:var(--muted);cursor:not-allowed;box-shadow:none;transform:none}.settings-col{flex-direction:column;gap:20px;display:flex}.toggle-list{flex-direction:column;gap:16px;display:flex}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.toggle-row:last-child{border-bottom:none}.toggle-label{color:var(--text);letter-spacing:1px;font-size:20px}.toggle-desc{color:var(--muted);margin-top:2px;font-size:14px}.toggle-switch{flex-shrink:0;width:52px;height:26px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-track{background:var(--bg);border:2px solid var(--muted);cursor:pointer;transition:all .2s;position:absolute;inset:0}.toggle-track:after{content:"";background:var(--muted);width:18px;height:18px;transition:all .2s;position:absolute;top:2px;left:2px}input:checked+.toggle-track{border-color:var(--green);box-shadow:0 0 10px #39ff1466}input:checked+.toggle-track:after{background:var(--green);box-shadow:0 0 8px var(--green);left:28px}.duration-display{text-align:center;margin-bottom:16px}.duration-value{color:var(--yellow);text-shadow:0 0 12px var(--yellow);font-family:"Press Start 2P",monospace;font-size:28px}.duration-unit{color:var(--muted);letter-spacing:2px;margin-top:4px;font-family:"Press Start 2P",monospace;font-size:9px}.pixel-slider{appearance:none;background:var(--bg);border:2px solid var(--muted);cursor:pointer;outline:none;width:100%;height:8px}.pixel-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--yellow);cursor:pointer;width:20px;height:20px;box-shadow:0 0 10px var(--yellow);border:none}.pixel-slider::-webkit-slider-runnable-track{background:linear-gradient(90deg, var(--yellow) var(--pct,0%), var(--bg) var(--pct,0%));border:none;height:4px}.slider-labels{color:var(--muted);justify-content:space-between;margin-top:8px;font-size:16px;display:flex}.transition-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.transition-option{background:var(--bg);border:2px solid var(--border);cursor:pointer;text-align:center;padding:12px 8px;transition:all .15s;position:relative}.transition-option:hover{border-color:var(--cyan);box-shadow:0 0 8px #00f0ff33}.transition-option.selected{border-color:var(--pink);background:#ff2d551a;box-shadow:0 0 12px #ff2d5540}.transition-option.selected:before{content:"▶";color:var(--pink);font-size:10px;position:absolute;top:4px;right:6px}.transition-icon{margin-bottom:6px;font-size:28px;line-height:1;display:block}.transition-name{letter-spacing:1px;color:var(--text);font-family:"Press Start 2P",monospace;font-size:6px}.transition-option.selected .transition-name{color:var(--pink);text-shadow:0 0 6px var(--pink)}.stat-bar{border:2px solid var(--border);gap:0;margin-bottom:20px;display:flex;overflow:hidden}.stat-item{text-align:center;background:var(--bg2);border-right:1px solid var(--border);flex:1;padding:12px 8px}.stat-item:last-child{border-right:none}.stat-val{color:var(--cyan);text-shadow:0 0 8px var(--cyan);font-family:"Press Start 2P",monospace;font-size:14px;display:block}.stat-lbl{color:var(--muted);margin-top:4px;font-size:14px;display:block}.tweaks-panel{background:var(--bg2);border:2px solid var(--cyan);z-index:1000;width:260px;padding:20px;position:fixed;bottom:24px;right:24px;box-shadow:0 0 20px #00f0ff33}.tweaks-title{color:var(--cyan);text-shadow:0 0 6px var(--cyan);letter-spacing:2px;margin-bottom:16px;font-family:"Press Start 2P",monospace;font-size:8px}.tweak-row{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.tweak-row:last-child{margin-bottom:0}.tweak-lbl{color:var(--text);font-size:16px}.tweak-select{background:var(--bg);border:1px solid var(--muted);color:var(--cyan);cursor:pointer;padding:4px 8px;font-family:VT323,monospace;font-size:16px}.loading-dots:after{content:"";animation:1.5s infinite dots}@keyframes dots{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}@media (width<=768px){.app{padding:12px 12px 32px}.header{padding:16px 0 14px}.header-logo{letter-spacing:3px;font-size:18px}.header-sub{letter-spacing:4px;margin-top:6px;font-size:7px}.header-divider{margin-top:14px}.stat-bar{grid-template-columns:1fr 1fr;margin-bottom:14px;display:grid}.stat-item{padding:10px 6px}.stat-val,.stat-lbl{font-size:12px}.main-grid{grid-template-columns:1fr;gap:16px;margin-top:16px}.pixel-box{padding:14px}.box-title{letter-spacing:2px;margin-bottom:14px;font-size:7px}.import-input{padding:8px 10px;font-size:16px}.import-btn{padding:8px 12px;font-size:7px}.song-list{max-height:320px}.song-item{gap:8px;padding:6px 8px 6px 6px}.song-thumb{width:36px;height:28px}.song-title{font-size:16px}.song-artist{font-size:13px}.song-timestamp{font-size:7px}.song-num{width:16px;font-size:7px}.generate-btn{width:100%;padding:14px 24px;font-size:10px}.toggle-label{font-size:16px}.toggle-desc{font-size:12px}.duration-value{font-size:22px}.duration-unit{font-size:7px}.transition-icon{font-size:22px}.transition-name{font-size:5px}.top-bar{padding:12px 16px}.top-title{letter-spacing:2px;font-size:8px}.top-track-info{font-size:6px}.top-elapsed{font-size:7px}.countdown-wrap{padding:0 16px;bottom:72px}.countdown-wrap.controls-up{bottom:120px}.controls{gap:10px;padding:14px 12px 18px}.ctrl-song-info{gap:8px}.ctrl-thumb{width:40px;height:30px}.ctrl-song-title{font-size:16px}.ctrl-song-artist{font-size:13px}.ctrl-center{gap:4px}.ctrl-btn{width:36px;height:36px}.ctrl-btn.primary{width:44px;height:44px}.ctrl-track-num{min-width:44px;font-size:6px}.back-btn{padding:6px 8px;font-size:6px}.center-num{font-size:80px!important}.corner{width:20px;height:20px}.corner-tl{top:6px;left:6px}.corner-tr{top:6px;right:6px}.corner-bl{bottom:6px;left:6px}.corner-br{bottom:6px;right:6px}.game-over-title{font-size:clamp(24px,8vw,48px)}.game-over-label{letter-spacing:4px;font-size:clamp(8px,2vw,12px)}.game-over-sub{letter-spacing:3px;font-size:clamp(6px,1.5vw,9px)}.end-stats-grid{grid-template-columns:1fr;gap:8px;width:min(400px,90vw)}.end-stat-card{text-align:left;align-items:center;gap:12px;padding:12px 10px;display:flex}.end-stat-icon{margin-bottom:0;font-size:22px}.end-stat-val{font-size:clamp(14px,3vw,20px)}.end-btn-row{flex-direction:column;gap:10px;width:min(300px,85vw)}.end-btn{justify-content:center;width:100%;padding:14px 24px;font-size:clamp(7px,1.5vw,9px)}.rank-badge{padding:8px 20px;font-size:clamp(14px,3vw,18px)}.ticker-item{padding:0 20px;font-size:7px}}.drink-flash{background:var(--pink);opacity:0;z-index:299;pointer-events:none;transition:opacity 50ms;position:fixed;inset:0}.drink-flash.bang{opacity:.7}.drink-overlay{z-index:300;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drink-msg{color:var(--yellow);text-shadow:0 0 20px var(--yellow), 0 0 60px var(--yellow), 6px 6px 0 #000c;letter-spacing:4px;text-align:center;opacity:0;pointer-events:none;text-transform:uppercase;font-family:"Press Start 2P",monospace;font-size:clamp(48px,10vw,120px);transition:opacity .12s,transform .12s;transform:scale(.4)rotate(-3deg)}.drink-msg.show{opacity:1;transform:scale(1)rotate(-2deg)}.drink-msg.hide{opacity:0;transition:opacity .4s,transform .4s;transform:scale(1.3)rotate(1deg)}.top-bar{z-index:150;opacity:0;background:linear-gradient(#000000d9 0%,#0000 100%);justify-content:space-between;align-items:center;padding:20px 32px;transition:opacity .3s;display:flex;position:fixed;top:0;left:0;right:0}.top-bar.visible{opacity:1}.top-title{color:var(--yellow);text-shadow:0 0 10px var(--yellow);letter-spacing:3px;font-family:"Press Start 2P",monospace;font-size:11px}.top-track-info{color:var(--cyan);text-shadow:0 0 8px var(--cyan);letter-spacing:2px;font-family:"Press Start 2P",monospace;font-size:8px}.top-elapsed{color:var(--muted);letter-spacing:2px;font-family:"Press Start 2P",monospace;font-size:10px}.countdown-wrap{z-index:150;opacity:.55;padding:0 32px;transition:opacity .3s,bottom .3s;position:fixed;bottom:88px;left:0;right:0}.countdown-wrap.controls-up{opacity:1;bottom:148px}.countdown-bar-bg{background:#ffffff1a;height:4px;position:relative}.countdown-bar-fill{background:linear-gradient(90deg, var(--pink), var(--yellow));height:100%;box-shadow:0 0 8px var(--yellow);transition:width .25s linear;position:relative}.countdown-bar-fill:after{content:"";background:#fff;width:3px;height:12px;position:absolute;top:-4px;right:-2px;box-shadow:0 0 6px #fff}.countdown-timer{color:var(--yellow);text-shadow:0 0 6px var(--yellow);letter-spacing:1px;font-family:"Press Start 2P",monospace;font-size:8px;position:absolute;top:-22px;right:0}.controls{z-index:150;opacity:0;background:linear-gradient(#0000 0%,#000000b3 30%,#000000f2 100%);align-items:center;gap:24px;padding:24px 32px 28px;transition:opacity .3s,transform .3s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(8px)}.controls.visible{opacity:1;transform:translateY(0)}.ctrl-song-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.ctrl-thumb{background:var(--bg2);border:1px solid #333;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:40px;display:flex;overflow:hidden}.ctrl-thumb img{object-fit:cover;width:100%;height:100%}.ctrl-thumb-placeholder{width:100%;height:100%;color:var(--muted);background:repeating-linear-gradient(45deg,#1a1a2e,#1a1a2e 4px,#0e0e1a 4px 8px);justify-content:center;align-items:center;display:flex}.ctrl-song-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:22px;line-height:1.1;overflow:hidden}.ctrl-song-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:17px;overflow:hidden}.ctrl-center{flex-shrink:0;align-items:center;gap:8px;display:flex}.ctrl-btn{color:var(--text);cursor:pointer;background:0 0;border:2px solid #ffffff26;justify-content:center;align-items:center;width:44px;height:44px;font-family:VT323,monospace;font-size:18px;transition:all .15s;display:flex;position:relative}.ctrl-btn:hover{border-color:var(--pink);color:var(--pink);box-shadow:0 0 12px #ff2d5559}.ctrl-btn.primary{border-color:var(--yellow);width:56px;height:56px;color:var(--yellow);font-size:22px;box-shadow:0 0 10px #ffe60033}.ctrl-btn.primary:hover{border-color:var(--yellow);color:var(--yellow);background:#ffe60014;box-shadow:0 0 20px #ffe60080}.ctrl-btn.active{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 10px #00f0ff4d}.ctrl-track-num{color:var(--muted);letter-spacing:1px;text-align:center;min-width:60px;margin:0 4px;font-family:"Press Start 2P",monospace;font-size:8px}.ctrl-right{flex:1;justify-content:flex-end;align-items:center;gap:8px;display:flex}.volume-wrap{align-items:center;gap:8px;max-width:0;transition:max-width .3s;display:flex;overflow:hidden}.volume-wrap.open{max-width:120px}.volume-slider{appearance:none;cursor:pointer;background:#fff3;outline:none;width:90px;height:4px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--cyan);cursor:pointer;width:14px;height:14px;box-shadow:0 0 6px var(--cyan)}.back-btn{letter-spacing:1px;color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #333;align-items:center;gap:6px;padding:8px 12px;font-family:"Press Start 2P",monospace;font-size:8px;text-decoration:none;transition:all .15s;display:inline-flex}.back-btn:hover{color:var(--text);border-color:var(--muted)}.corner{z-index:160;pointer-events:none;opacity:.4;width:32px;height:32px;position:fixed}.corner-tl{border-top:2px solid var(--cyan);border-left:2px solid var(--cyan);top:12px;left:12px}.corner-tr{border-top:2px solid var(--cyan);border-right:2px solid var(--cyan);top:12px;right:12px}.corner-bl{border-bottom:2px solid var(--cyan);border-left:2px solid var(--cyan);bottom:12px;left:12px}.corner-br{border-bottom:2px solid var(--cyan);border-right:2px solid var(--cyan);bottom:12px;right:12px}.center-countdown{pointer-events:none;z-index:290;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.center-num{color:var(--yellow);text-shadow:0 0 30px var(--yellow), 0 0 80px #ffe60080, 6px 6px 0 #000000b3;opacity:0;letter-spacing:4px;font-family:"Press Start 2P",monospace;line-height:1;transition:opacity .15s,transform .15s;transform:scale(1.4)}.center-num.urgent{color:var(--pink);text-shadow:0 0 30px var(--pink), 0 0 80px #ff2d5580, 6px 6px 0 #000000b3}.center-num.visible{opacity:1;transform:scale(1)}@keyframes numPop{0%{transform:scale(1.35)}40%{transform:scale(.95)}70%{transform:scale(1.04)}to{transform:scale(1)}}.center-num.pop{animation:.35s cubic-bezier(.2,1.4,.5,1) forwards numPop}.center-ring{border:3px solid var(--yellow);opacity:0;pointer-events:none;border-radius:50%;width:180px;height:180px;position:absolute;transform:scale(.6)}@keyframes ringPulse{0%{opacity:.7;transform:scale(.6)}to{opacity:0;transform:scale(2.2)}}.center-ring.fire{animation:.6s ease-out forwards ringPulse}.center-ring.urgent{border-color:var(--pink)}.wipe-overlay{background:var(--bg);z-index:298;pointer-events:none;opacity:0;clip-path:inset(0 100% 0 0);transition:clip-path .3s ease-in,opacity .15s;position:fixed;inset:0}.wipe-overlay.wiping{clip-path:inset(0 0% 0 0);opacity:1}.song-badge{color:var(--bg);background:var(--pink);letter-spacing:2px;z-index:160;opacity:0;padding:6px 14px;font-family:"Press Start 2P",monospace;font-size:8px;transition:opacity .3s;position:fixed;top:20px;left:50%;transform:translate(-50%);box-shadow:0 0 16px #ff2d5566,3px 3px #00000080}.song-badge.visible{opacity:1}.unmute-prompt{z-index:160;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.unmute-pill{color:var(--cyan);text-shadow:0 0 10px var(--cyan);letter-spacing:2px;border:2px solid var(--cyan);pointer-events:none;background:#08080fcc;padding:16px 32px;font-family:"Press Start 2P",monospace;font-size:10px;animation:2s infinite pulse;box-shadow:0 0 30px #00f0ff66}@keyframes pulse{50%{opacity:.5}}.challenge-overlay{z-index:300;cursor:pointer;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex;position:fixed;inset:0}.challenge-title{color:var(--pink);text-shadow:0 0 20px var(--pink), 0 0 40px var(--pink);letter-spacing:4px;font-family:"Press Start 2P",monospace;font-size:clamp(28px,8vw,72px)}.challenge-text{color:var(--text);text-align:center;letter-spacing:1px;max-width:600px;padding:0 24px;font-family:VT323,monospace;font-size:clamp(24px,4vw,42px)}.challenge-dismiss{color:var(--muted);letter-spacing:2px;margin-top:16px;font-family:"Press Start 2P",monospace;font-size:8px}.auto-skip-notice{z-index:170;color:var(--pink);text-shadow:0 0 10px var(--pink);letter-spacing:2px;background:#000000b3;padding:8px 20px;font-family:"Press Start 2P",monospace;font-size:10px;position:fixed;top:24px;left:50%;transform:translate(-50%)}.ad-notice{z-index:150;color:var(--muted);letter-spacing:1px;font-family:"Press Start 2P",monospace;font-size:7px;position:fixed;top:80px;right:24px}#fireworks-canvas{pointer-events:none;z-index:1;position:fixed;inset:0}.end-stage{z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:0;display:flex;position:fixed;inset:0}.game-over-wrap{text-align:center;opacity:0;margin-bottom:12px;animation:.5s cubic-bezier(.2,1.4,.5,1) .3s forwards dropIn;position:relative}@keyframes dropIn{0%{opacity:0;transform:translateY(-60px)scale(.7)}to{opacity:1;transform:translateY(0)scale(1)}}.game-over-label{color:var(--pink);letter-spacing:8px;text-shadow:0 0 12px var(--pink);margin-bottom:8px;font-family:"Press Start 2P",monospace;font-size:clamp(12px,2vw,18px);animation:1.2s step-end 1.5s infinite blink;display:block}.game-over-title{color:var(--yellow);letter-spacing:4px;text-shadow:0 0 20px var(--yellow), 0 0 50px #ffe60080, 5px 5px 0 #c8640099, 10px 10px 0 #6432004d;font-family:"Press Start 2P",monospace;font-size:clamp(32px,6vw,72px);line-height:1.1;animation:6s infinite titleFlicker}@keyframes titleFlicker{0%,93%,to{opacity:1}94%{opacity:.8}95%{opacity:1}97%{opacity:.85}98%{opacity:1}}.game-over-sub{color:var(--cyan);letter-spacing:5px;text-shadow:0 0 10px var(--cyan);margin-top:10px;font-family:"Press Start 2P",monospace;font-size:clamp(7px,1.2vw,11px);display:block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.end-divider{background:linear-gradient(90deg, transparent, var(--pink), var(--yellow), var(--cyan), transparent);width:min(600px,85vw);height:2px;box-shadow:0 0 10px var(--cyan);opacity:0;margin:20px 0;animation:.4s .9s forwards fadeIn}@keyframes fadeIn{to{opacity:1}}.end-stats-grid{opacity:0;grid-template-columns:repeat(3,1fr);gap:12px;width:min(600px,85vw);margin-bottom:28px;animation:.5s 1.1s forwards fadeIn;display:grid}.end-stat-card{background:var(--bg2);border:2px solid var(--border);text-align:center;padding:16px 12px;position:relative;overflow:hidden}.end-stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.end-stat-card:first-child:before{background:var(--pink);box-shadow:0 0 8px var(--pink)}.end-stat-card:nth-child(2):before{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}.end-stat-card:nth-child(3):before{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}.end-stat-icon{margin-bottom:6px;font-size:28px;line-height:1;display:block}.end-stat-val{font-family:"Press Start 2P",monospace;font-size:clamp(16px,2.5vw,26px);line-height:1;display:block}.end-stat-card:first-child .end-stat-val{color:var(--pink);text-shadow:0 0 10px var(--pink)}.end-stat-card:nth-child(2) .end-stat-val{color:var(--yellow);text-shadow:0 0 10px var(--yellow)}.end-stat-card:nth-child(3) .end-stat-val{color:var(--cyan);text-shadow:0 0 10px var(--cyan)}.end-stat-lbl{color:var(--muted);letter-spacing:1px;margin-top:6px;font-size:16px;display:block}.rank-wrap{text-align:center;opacity:0;margin-bottom:28px;animation:.4s 1.4s forwards fadeIn}.rank-label{color:var(--muted);letter-spacing:4px;margin-bottom:8px;font-family:"Press Start 2P",monospace;font-size:8px;display:block}.rank-badge{letter-spacing:2px;border:2px solid;padding:10px 28px;font-family:"Press Start 2P",monospace;font-size:clamp(16px,2.5vw,22px);display:inline-block;position:relative}.rank-S{color:var(--yellow);border-color:var(--yellow);box-shadow:0 0 20px #ffe60066}.rank-A{color:var(--green);border-color:var(--green);box-shadow:0 0 20px #39ff144d}.rank-B{color:var(--cyan);border-color:var(--cyan);box-shadow:0 0 20px #00f0ff4d}.rank-C{color:var(--pink);border-color:var(--pink);box-shadow:0 0 20px #ff2d554d}.rank-badge:before{content:"RANK";background:var(--bg);letter-spacing:3px;color:var(--muted);padding:0 6px;font-size:7px;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.end-btn-row{opacity:0;gap:16px;animation:.5s cubic-bezier(.2,1.3,.5,1) 1.7s forwards riseIn;display:flex}@keyframes riseIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.end-btn{letter-spacing:2px;cursor:pointer;text-transform:uppercase;border:none;justify-content:center;align-items:center;gap:10px;padding:18px 36px;font-family:"Press Start 2P",monospace;font-size:clamp(8px,1.2vw,11px);transition:all .15s;display:inline-flex;position:relative}.end-btn:after{content:"";z-index:-1;width:100%;height:100%;transition:all .15s;position:absolute;bottom:-6px;right:-6px}.btn-play{background:var(--green);color:var(--bg);box-shadow:6px 6px #00000080,0 0 20px #39ff144d}.btn-play:after{background:#39ff144d}.btn-play:hover{transform:translate(-2px,-2px);box-shadow:8px 8px #00000080,0 0 30px #39ff1480}.btn-play:active{transform:translate(3px,3px);box-shadow:3px 3px #00000080}.btn-menu{color:var(--text);background:0 0;border:2px solid #fff3;box-shadow:4px 4px #0006}.btn-menu:after{background:#ffffff0d}.btn-menu:hover{border-color:var(--pink);color:var(--pink);transform:translate(-2px,-2px);box-shadow:6px 6px #00000080,0 0 16px #ff2d554d}.btn-menu:active{transform:translate(3px,3px);box-shadow:1px 1px #00000080}.ticker-wrap{background:var(--pink);z-index:20;align-items:center;height:32px;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.ticker-track{white-space:nowrap;gap:0;animation:18s linear infinite ticker;display:flex}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.ticker-item{color:var(--bg);letter-spacing:3px;padding:0 32px;font-family:"Press Start 2P",monospace;font-size:9px}.ticker-sep{color:#0006;padding:0 4px;font-size:10px}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
