:root{--bg:#050505;--bg-2:#0a0a0a;--fg:#f5f5f5;--magenta:#ff2d95;--cyan:#00f0ff;--yellow:#f8ff3a;--green:#2dff95;--grid:hsla(0,0%,100%,.04);--line:hsla(0,0%,100%,.08);--hangul:"Black Han Sans",sans-serif;--sans:"Space Grotesk",sans-serif;--mono:"JetBrains Mono",monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;overscroll-behavior:none}body{min-height:100dvh;height:100dvh;background:var(--bg);color:var(--fg);font-family:var(--sans);overflow:hidden;display:flex;flex-direction:column;position:relative;-webkit-tap-highlight-color:transparent;-moz-user-select:none;user-select:none;-webkit-user-select:none;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}body,button{touch-action:manipulation}.grid-bg{background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:32px 32px;z-index:0;-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 90%);mask-image:radial-gradient(ellipse at center,#000 30%,transparent 90%)}.grid-bg,.scanlines{position:fixed;inset:0;pointer-events:none}.scanlines{background:repeating-linear-gradient(0deg,hsla(0,0%,100%,.025),hsla(0,0%,100%,.025) 1px,transparent 0,transparent 3px);z-index:1;mix-blend-mode:overlay;opacity:.6}.noise{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.topbar{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:22px 36px;border-bottom:1px solid var(--line);position:relative;z-index:10}.rhythm-link{font-family:var(--mono);font-size:11px;letter-spacing:.25em;color:var(--magenta);text-decoration:none;border:1px solid rgba(255,45,149,.4);padding:8px 14px;border-radius:2px;transition:all .2s;text-shadow:0 0 12px rgba(255,45,149,.5)}.rhythm-link:hover{background:rgba(255,45,149,.12);box-shadow:0 0 20px rgba(255,45,149,.5)}.logo{display:flex;align-items:baseline;gap:10px;font-family:var(--hangul);font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;position:relative}.logo .symbol{font-family:var(--sans);color:var(--magenta);font-size:.7em;text-shadow:0 0 12px var(--magenta);animation:rotate-symbol 8s linear infinite;display:inline-block}.logo:after,.logo:before{content:attr(data-text);position:absolute;inset:0;font-family:var(--hangul);pointer-events:none;display:flex;gap:10px;align-items:baseline}.logo:before{color:var(--magenta);transform:translateX(-2px);animation:glitch-x 4s infinite}.logo:after,.logo:before{mix-blend-mode:screen;opacity:.5}.logo:after{color:var(--cyan);transform:translateX(2px);animation:glitch-x 4s infinite reverse}@keyframes rotate-symbol{to{transform:rotate(1turn)}}@keyframes glitch-x{0%,92%,to{transform:translateX(0)}93%{transform:translateX(-3px)}94%{transform:translateX(2px)}95%{transform:translateX(-2px)}96%{transform:translateX(0)}}.status{font-family:var(--mono);font-size:11px;display:flex;gap:24px;text-align:right;color:hsla(0,0%,100%,.55);letter-spacing:.12em}.status__row{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status__row .status__dot{width:8px;height:8px;border-radius:50%;background:var(--magenta);box-shadow:0 0 12px var(--magenta);animation:pulse 1.4s ease-in-out infinite}.status__row:first-child{flex-direction:row;align-items:center;gap:8px}.counter{font-size:22px;color:var(--cyan);text-shadow:0 0 10px rgba(0,240,255,.5);font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}main.pads{flex:1 1;display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(4,1fr);grid-gap:12px;gap:12px;padding:18px 28px;position:relative;z-index:10;min-height:0}.pad{background:linear-gradient(155deg,hsla(0,0%,8%,.9),rgba(8,8,8,.95));border:1px solid var(--line);border-radius:6px;cursor:pointer;font-family:var(--hangul);color:var(--fg);display:flex;flex-direction:column;justify-content:flex-end;padding:16px 18px 18px;text-align:left;transition:transform .07s ease-out,border-color .25s ease;outline:none}.pad,.pad__label{position:relative;overflow:hidden}.pad__label{font-size:clamp(48px,5.4vw,88px);line-height:1.05;letter-spacing:-.05em;z-index:2;white-space:nowrap;text-overflow:clip;width:100%;padding:.04em 0}.pad__label[data-len="3"]{font-size:clamp(36px,4.4vw,66px);letter-spacing:-.06em}.pad__label[data-len="4"]{font-size:clamp(28px,3.4vw,52px);letter-spacing:-.07em}.pad__label[data-len="5"]{font-size:clamp(22px,2.8vw,42px);letter-spacing:-.08em}.pad__sub{font-family:var(--mono);font-size:10px;color:hsla(0,0%,100%,.45);text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px;z-index:2;position:relative;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.pad__key{top:12px;right:14px;padding:3px 6px;border:1px solid hsla(0,0%,100%,.18);border-radius:2px;color:hsla(0,0%,100%,.55)}.pad__id,.pad__key{position:absolute;font-family:var(--mono);font-size:10px;z-index:2}.pad__id{top:14px;left:18px;color:hsla(0,0%,100%,.25);letter-spacing:.1em}.pad--magenta{--c:var(--magenta);--rgb:255,45,149}.pad--cyan{--c:var(--cyan);--rgb:0,240,255}.pad--yellow{--c:var(--yellow);--rgb:248,255,58}.pad--green{--c:var(--green);--rgb:45,255,149}.pad:before{inset:0;background:radial-gradient(circle at 50% 100%,var(--c) 0,transparent 65%);mix-blend-mode:screen;z-index:1}.pad:after,.pad:before{content:"";position:absolute;opacity:0;transition:opacity .3s ease;pointer-events:none}.pad:after{top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--c),transparent);z-index:2}.pad:hover{border-color:rgba(var(--rgb),.5);transform:translateY(-2px)}.pad:hover:before{opacity:.22}.pad:hover:after{opacity:1}.pad:hover .pad__label{color:var(--c);text-shadow:0 0 18px rgba(var(--rgb),.45)}.pad.hit{animation:pad-hit .45s cubic-bezier(.22,1,.36,1)}@keyframes pad-hit{0%{transform:scale(.96);border-color:var(--c);box-shadow:0 0 0 0 rgba(var(--rgb),.7),inset 0 0 60px rgba(var(--rgb),.6)}to{transform:scale(1);border-color:var(--line);box-shadow:0 0 0 30px rgba(var(--rgb),0),inset 0 0 0 rgba(var(--rgb),0)}}.pad.hit .pad__label{color:var(--c);text-shadow:0 0 24px var(--c)}.bgm-bar{justify-content:space-between;padding:18px 36px;border-top:1px solid var(--line);position:relative;z-index:10;background:linear-gradient(180deg,transparent,rgba(0,0,0,.5))}.bgm-bar,.bgm-info{display:flex;align-items:center}.bgm-info{gap:18px}.bgm-art{font-family:var(--hangul);font-size:42px;line-height:1;display:flex;gap:2px;letter-spacing:-.06em;position:relative}.bgm-art__zero{color:var(--fg);text-shadow:0 0 8px hsla(0,0%,100%,.2)}.bgm-art__plus{color:var(--magenta);text-shadow:0 0 12px var(--magenta)}.bgm-title{font-size:17px;font-weight:700;letter-spacing:-.01em}.bgm-sub{font-family:var(--mono);font-size:10px;color:hsla(0,0%,100%,.5);letter-spacing:.12em;margin-top:3px}.bgm-toggle{display:flex;align-items:center;gap:14px;background:transparent;border:2px solid hsla(0,0%,100%,.18);padding:12px 24px;border-radius:999px;font-family:var(--hangul);font-size:22px;letter-spacing:.05em;color:var(--fg);cursor:pointer;transition:all .3s ease}.bgm-toggle__dot{width:12px;height:12px;border-radius:50%;background:hsla(0,0%,100%,.2);transition:all .3s ease}.bgm-toggle:hover{border-color:hsla(0,0%,100%,.45)}.bgm-toggle.on{border-color:var(--magenta);color:var(--magenta);text-shadow:0 0 12px var(--magenta);box-shadow:0 0 30px rgba(255,45,149,.4),inset 0 0 30px rgba(255,45,149,.12);background:rgba(255,45,149,.04)}.bgm-toggle.on .bgm-toggle__dot{background:var(--magenta);box-shadow:0 0 18px var(--magenta);animation:dot-pulse .9s ease-in-out infinite}@keyframes dot-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.4);opacity:.7}}.hint{position:fixed;bottom:96px;right:36px;font-family:var(--mono);font-size:10px;color:hsla(0,0%,100%,.3);letter-spacing:.18em;z-index:5;pointer-events:none;display:flex;gap:8px;align-items:center}.hint .kbd{border:1px solid hsla(0,0%,100%,.2);padding:2px 5px;border-radius:2px;color:hsla(0,0%,100%,.5)}body.bgm-on:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 50% 110%,rgba(255,45,149,.18),transparent 60%);pointer-events:none;z-index:3;animation:bgm-glow 1.6s ease-in-out infinite alternate}@keyframes bgm-glow{0%{opacity:.6}to{opacity:1}}.boot{position:fixed;inset:0;background:var(--bg);z-index:1000;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .5s ease,visibility .5s ease}.boot.gone{opacity:0;visibility:hidden;pointer-events:none}.boot__inner{text-align:center}.boot__title{font-family:var(--hangul);font-size:clamp(64px,14vw,180px);letter-spacing:-.04em;color:var(--fg);text-shadow:-3px 0 var(--magenta),3px 0 var(--cyan);animation:boot-glitch 2.5s infinite}.boot__sub{margin-top:20px;font-family:var(--mono);font-size:13px;color:hsla(0,0%,100%,.5);letter-spacing:.4em;animation:blink 1s steps(2) infinite}@keyframes boot-glitch{0%,to{text-shadow:-3px 0 var(--magenta),3px 0 var(--cyan)}10%{text-shadow:3px 0 var(--magenta),-3px 0 var(--cyan)}20%{text-shadow:-2px 0 var(--magenta),2px 0 var(--cyan);transform:translateX(2px)}30%{transform:translateX(-1px)}60%{text-shadow:-3px 0 var(--magenta),3px 0 var(--cyan);transform:translateX(0)}}@keyframes blink{50%{opacity:.3}}@media (max-width:800px){.topbar{padding:8px 12px;gap:8px;flex-wrap:nowrap}.logo{font-size:clamp(18px,5.4vw,24px);gap:4px}.logo .symbol{font-size:.8em}main.pads{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(5,1fr);padding:8px;gap:6px}.pad{padding:6px 10px 8px;min-height:0}.pad__label{font-size:clamp(22px,5.6vw,32px);letter-spacing:-.06em;line-height:1.1;padding:.06em 0}.pad__label[data-len="3"]{font-size:clamp(18px,4.6vw,26px);letter-spacing:-.07em}.pad__label[data-len="4"]{font-size:clamp(14px,3.6vw,22px);letter-spacing:-.08em}.pad__label[data-len="5"]{font-size:clamp(12px,3vw,18px);letter-spacing:-.08em}.pad__id,.pad__key{display:none}.pad__sub{font-size:8px;letter-spacing:.05em;margin-bottom:2px}.bgm-bar{padding:12px 16px;flex-direction:column;align-items:stretch;gap:10px}.bgm-info{gap:12px}.bgm-art{font-size:32px}.bgm-title{font-size:14px}.bgm-sub{font-size:9px}.bgm-toggle{justify-content:center;padding:10px 18px;font-size:18px}.hint{display:none}.topbar__nav{gap:4px;flex-shrink:0}.topbar__nav .rhythm-link,.topbar__nav .rhythm-link--rank,.topbar__nav .rhythm-link--shout{font-size:8px;padding:4px 6px;letter-spacing:.1em}.status{gap:8px;font-size:8px;letter-spacing:.08em;align-items:center;flex-shrink:0}.status__row{gap:3px}.status__row:first-child{gap:4px}.status__row .counter{font-size:13px}.status__dot{width:6px;height:6px}.rhythm-link{font-size:9px;padding:6px 10px;letter-spacing:.18em}}@media (max-width:380px){main.pads{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(7,1fr)}.pad__label{font-size:clamp(24px,6.5vw,34px);letter-spacing:-.06em}.pad__label[data-len="3"]{font-size:clamp(18px,5vw,26px)}.pad__label[data-len="4"]{font-size:clamp(13px,4vw,20px)}.pad__label[data-len="5"]{font-size:clamp(11px,3.2vw,16px)}}body.rhythm{overflow:hidden}.back{font-family:var(--mono);font-size:12px;color:var(--cyan);text-decoration:none;letter-spacing:.18em;border:1px solid rgba(0,240,255,.3);padding:8px 14px;border-radius:2px;transition:all .2s}.back:hover{background:rgba(0,240,255,.1);box-shadow:0 0 16px rgba(0,240,255,.4)}main.stage{flex:1 1;position:relative;z-index:10;overflow:hidden;display:flex;flex-direction:column}.rhythm-bg-canvas{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;pointer-events:none}.rhythm-main-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:5;touch-action:none;transform-origin:center center;will-change:transform}.lanes{position:absolute;inset:0;display:grid;grid-template-columns:repeat(4,1fr);pointer-events:none;z-index:1}.lane{border-left:1px solid hsla(0,0%,100%,.04);border-right:1px solid hsla(0,0%,100%,.04);position:relative;background:linear-gradient(180deg,transparent,hsla(0,0%,100%,.015) 50%,transparent)}.lane:first-child{border-left:none}.lane:last-child{border-right:none}.lane__head{top:18px;transform:translateX(-50%);font-family:var(--mono);font-size:11px;letter-spacing:.25em;color:hsla(0,0%,100%,.3);padding:4px 10px;border:1px solid hsla(0,0%,100%,.1);border-radius:2px}.lane__head,.lane__key{position:absolute;left:50%}.lane__key{bottom:14%;transform:translateX(-50%) translateY(60px);font-family:var(--hangul);font-size:24px;letter-spacing:.04em;color:hsla(0,0%,100%,.35);padding:6px 18px;border:1.5px solid hsla(0,0%,100%,.18);border-radius:6px;background:rgba(0,0,0,.5);transition:all .06s ease-out;display:none}body.mode-manual .lane__key{display:block}.lane.pressed .lane__key{color:var(--fg);border-color:var(--fg);background:hsla(0,0%,100%,.12);transform:translateX(-50%) translateY(60px) scale(.92)}.judgment-line{position:absolute;left:0;right:0;bottom:12%;height:3px;background:linear-gradient(90deg,transparent,rgba(255,45,149,.8) 20%,rgba(0,240,255,.9) 50%,rgba(248,255,58,.8) 80%,transparent);z-index:4;box-shadow:0 0 24px hsla(0,0%,100%,.4)}.judgment-line__pulse{position:absolute;inset:-8px 0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.15),transparent);filter:blur(8px);animation:line-pulse .5s ease-in-out infinite alternate}@keyframes line-pulse{0%{opacity:.5}to{opacity:1}}.notes{inset:0;z-index:3;pointer-events:none}.note,.notes{position:absolute}.note{width:calc(100% / 4 - 24px);height:60px;margin-left:12px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--hangul);letter-spacing:-.03em;background:linear-gradient(155deg,hsla(0,0%,8%,.95),rgba(8,8,8,.95));border:2px solid var(--c);color:var(--fg);box-shadow:0 0 20px rgba(var(--rgb),.35),inset 0 0 12px rgba(var(--rgb),.18);will-change:transform}.note__sub{font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:hsla(0,0%,100%,.55);margin-bottom:2px}.note__label{font-size:28px;color:var(--c);text-shadow:0 0 12px rgba(var(--rgb),.6)}.note--magenta{--c:var(--magenta);--rgb:255,45,149}.note--cyan{--c:var(--cyan);--rgb:0,240,255}.note--yellow{--c:var(--yellow);--rgb:248,255,58}.note--green{--c:var(--green);--rgb:45,255,149}.note.dead{animation:note-die .45s cubic-bezier(.22,1,.36,1) forwards}.note.miss{animation:note-miss .5s ease-out forwards}@keyframes note-miss{0%{opacity:1;filter:grayscale(0)}to{opacity:0;filter:grayscale(1) blur(4px);transform:translateY(160px)}}@keyframes note-die{0%{opacity:1;transform:scale(1)}30%{opacity:1;transform:scale(1.15)}to{opacity:0;transform:scale(.6)}}.hit-fx{position:absolute;left:0;right:0;bottom:12%;height:0;pointer-events:none;z-index:5}.hit-ring{position:absolute;width:80px;height:80px;border-radius:50%;border:3px solid var(--c);transform:translate(-50%,-50%);opacity:1;animation:ring-expand .6s ease-out forwards}@keyframes ring-expand{0%{width:20px;height:20px;opacity:1}to{width:200px;height:200px;opacity:0}}.hit-flash{position:absolute;left:0;right:0;top:-200px;bottom:-8px;background:linear-gradient(180deg,transparent,rgba(var(--rgb),.22) 80%,rgba(var(--rgb),.4));pointer-events:none;animation:flash-fade .35s ease-out forwards}@keyframes flash-fade{0%{opacity:1}to{opacity:0}}.rhythm-bar{display:flex;justify-content:space-between;align-items:center;padding:18px 36px;border-top:1px solid var(--line);position:relative;z-index:10;background:linear-gradient(180deg,transparent,rgba(0,0,0,.5))}.rhythm-bar .bgm-info{display:flex;align-items:center;gap:18px}.mode-toggle{position:relative;display:inline-flex;background:rgba(0,0,0,.6);border:1px solid hsla(0,0%,100%,.15);border-radius:999px;padding:3px;font-family:var(--mono);font-size:11px;letter-spacing:.2em}.mode-toggle__btn{position:relative;z-index:2;background:transparent;border:none;padding:8px 18px;color:hsla(0,0%,100%,.5);cursor:pointer;font-family:inherit;font-size:inherit;letter-spacing:inherit;transition:color .2s}.mode-toggle__btn:hover{color:var(--fg)}.mode-toggle__slider{position:absolute;z-index:1;top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px);background:linear-gradient(90deg,var(--magenta),var(--cyan));border-radius:999px;transition:transform .25s ease}.mode-toggle[data-mode=manual] .mode-toggle__slider{transform:translateX(0)}.mode-toggle[data-mode=auto] .mode-toggle__slider{transform:translateX(100%)}.mode-toggle[data-mode=auto] [data-set=auto],.mode-toggle[data-mode=manual] [data-set=manual]{color:#000}.judge-text{position:absolute;left:50%;bottom:25%;transform:translateX(-50%);font-family:var(--hangul);font-size:56px;letter-spacing:.05em;pointer-events:none;z-index:6;opacity:0}.judge-text.show{animation:judge-pop .55s cubic-bezier(.22,1,.36,1) forwards}.judge-text.perfect{color:var(--cyan);text-shadow:0 0 24px var(--cyan)}.judge-text.good{color:var(--yellow);text-shadow:0 0 18px var(--yellow)}.judge-text.miss{color:var(--magenta);text-shadow:0 0 18px var(--magenta)}@keyframes judge-pop{0%{opacity:0;transform:translateX(-50%) translateY(20px) scale(.8)}20%{opacity:1;transform:translateX(-50%) translateY(0) scale(1.15)}60%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}to{opacity:0;transform:translateX(-50%) translateY(-20px) scale(1)}}.result{position:fixed;inset:0;background:rgba(5,5,5,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease}.result.show{opacity:1;visibility:visible}.result__inner{background:linear-gradient(155deg,hsla(0,0%,8%,.95),rgba(8,8,8,.95));border:1px solid var(--line);border-radius:12px;padding:40px 60px;min-width:480px;text-align:center;position:relative;box-shadow:0 0 80px rgba(255,45,149,.2)}.result__rank{font-family:var(--hangul);font-size:140px;line-height:.9;letter-spacing:-.05em;color:var(--yellow);text-shadow:0 0 30px var(--yellow),0 0 60px rgba(248,255,58,.5);margin-bottom:8px}.result__rank.s-plus{color:var(--magenta);text-shadow:0 0 30px var(--magenta),0 0 60px rgba(255,45,149,.6)}.result__rank.a{color:var(--cyan);text-shadow:0 0 30px var(--cyan),0 0 60px rgba(0,240,255,.5)}.result__rank.b{color:var(--green);text-shadow:0 0 24px var(--green)}.result__rank.c{color:hsla(0,0%,100%,.6);text-shadow:0 0 18px hsla(0,0%,100%,.4)}.result__rank.d{color:hsla(0,0%,100%,.4)}.result__title{font-family:var(--mono);font-size:13px;letter-spacing:.5em;color:hsla(0,0%,100%,.55);margin-bottom:28px}.result__score{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}.result__label{font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:hsla(0,0%,100%,.45)}.result__big{font-family:JetBrains Mono,monospace;font-size:56px;font-weight:700;color:var(--cyan);text-shadow:0 0 18px rgba(0,240,255,.5);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.result__row{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px;margin-bottom:28px}.result__cell{display:flex;flex-direction:column;gap:4px;align-items:center}.result__num{font-family:JetBrains Mono,monospace;font-size:28px;font-weight:700;color:var(--fg);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.result__breakdown{display:flex;justify-content:center;gap:24px;margin-bottom:28px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:hsla(0,0%,100%,.65)}.result__break{display:flex;align-items:center;gap:8px}.result__break em{font-style:normal;font-weight:700;color:var(--fg);margin-left:4px}.result__break .dot{width:8px;height:8px;border-radius:50%}.result__break .dot.perfect{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}.result__break .dot.good{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}.result__break .dot.miss{background:var(--magenta);box-shadow:0 0 8px var(--magenta)}.result__again{background:transparent;border:2px solid var(--magenta);color:var(--magenta);padding:14px 32px;border-radius:999px;font-family:var(--hangul);font-size:22px;letter-spacing:.05em;cursor:pointer;transition:all .25s;text-shadow:0 0 12px var(--magenta)}.result__again:hover{background:rgba(255,45,149,.1);box-shadow:0 0 30px rgba(255,45,149,.5)}.counter.bump{animation:counter-bump .25s ease-out}@keyframes counter-bump{0%{transform:scale(1)}50%{transform:scale(1.18)}to{transform:scale(1)}}@media (max-width:800px){body.rhythm .topbar{padding:12px 16px;gap:10px}.back{font-size:10px;padding:6px 10px;letter-spacing:.12em}.rhythm-bar{padding:12px 16px;flex-direction:column;gap:10px}.rhythm-bar>div{width:100%}.rhythm-bar>div:last-child{display:flex;gap:8px}.rhythm-bar>div:last-child .bgm-toggle{flex:1 1}.lane__head{font-size:9px;padding:3px 6px;letter-spacing:.15em;top:10px}.lane__key{bottom:13%;font-size:32px;padding:14px 0;width:80%;border-width:2px;background:rgba(0,0,0,.7)}body.mode-manual .lane__key.tap-active{background:hsla(0,0%,100%,.18);color:var(--fg);border-color:var(--fg)}.note{height:44px;margin-left:6px;width:calc(25% - 12px);border-radius:6px;padding:4px}.note__sub{font-size:8px;letter-spacing:.15em;margin-bottom:1px}.note__label{font-size:18px;line-height:1}.judge-text{font-size:36px;bottom:22%}.mode-toggle{font-size:9px}.mode-toggle__btn{padding:6px 12px}.status{gap:10px;font-size:9px}.status__row .counter{font-size:16px}.result__inner{min-width:0!important;width:calc(100vw - 32px);padding:28px 24px}.result__rank{font-size:90px}.result__big{font-size:36px}.result__row{gap:12px}.result__num{font-size:22px}.result__breakdown{gap:14px;font-size:10px;flex-wrap:wrap;justify-content:center}.result__again{font-size:18px;padding:12px 22px}.result__name-row{flex-direction:column}.result__name-row .result__again{width:100%}.rank-table{font-size:11px}.rank-table td,.rank-table th{padding:6px 8px}}.result__name-row{display:flex;gap:8px;margin-top:16px}.result__name{flex:1 1;background:rgba(0,0,0,.4);border:1.5px solid hsla(0,0%,100%,.15);border-radius:999px;padding:12px 18px;color:var(--fg);font-family:var(--sans);font-size:15px;outline:none;transition:border-color .2s}.result__name:focus{border-color:var(--cyan);box-shadow:0 0 16px rgba(0,240,255,.3)}.result__name::placeholder{color:hsla(0,0%,100%,.35)}.result__submitted{margin-top:16px;font-family:var(--mono);font-size:12px;letter-spacing:.3em;color:var(--green);text-shadow:0 0 8px var(--green)}.rank-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:13px}.rank-table th{text-align:left;padding:8px 12px;font-size:10px;letter-spacing:.25em;color:hsla(0,0%,100%,.4);border-bottom:1px solid var(--line)}.rank-table td{padding:10px 12px;border-bottom:1px solid hsla(0,0%,100%,.04);color:var(--fg)}.rank-table td.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--cyan)}.rank-table tr:first-child td:first-child{color:var(--yellow);font-weight:700}.rank-table tr:nth-child(2) td:first-child{color:hsla(0,0%,100%,.7);font-weight:700}.rank-table tr:nth-child(3) td:first-child{color:var(--magenta);font-weight:700}.credits{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:hsla(0,0%,100%,.35);text-transform:lowercase;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.credits:hover{color:hsla(0,0%,100%,.7)}.credits__name{font-weight:500;letter-spacing:.15em}.credits a{display:inline-flex;align-items:center;justify-content:center;color:inherit;width:22px;height:22px;border-radius:50%;border:1px solid hsla(0,0%,100%,.12);transition:all .2s ease}.credits a:hover{color:var(--magenta);border-color:var(--magenta);box-shadow:0 0 10px rgba(255,45,149,.4)}.credits svg{display:block}@media (max-width:800px){.credits{font-size:9px;gap:6px}.credits a{width:20px;height:20px}}.result-stage{flex:1 1;display:flex;align-items:center;justify-content:center;padding:32px 24px;position:relative;z-index:10;min-height:0;overflow:auto}.result__inner--page{position:static;max-width:600px;width:100%}.result-position{position:absolute;top:-12px;right:-12px;font-family:var(--mono);font-size:14px;letter-spacing:.15em;color:var(--magenta);background:rgba(255,45,149,.15);border:1.5px solid var(--magenta);padding:8px 14px;border-radius:999px;text-shadow:0 0 8px var(--magenta)}.result-name{font-family:var(--hangul);font-size:36px;letter-spacing:-.02em;color:var(--fg);margin-bottom:6px}.result-cta{display:flex;gap:10px;justify-content:center;margin-top:12px;flex-wrap:wrap}.share-btn{border-color:var(--cyan)!important;color:var(--cyan)!important;text-shadow:0 0 12px var(--cyan)!important}.share-btn:hover{background:rgba(0,240,255,.1)!important;box-shadow:0 0 20px rgba(0,240,255,.5)!important}.share-inline{background:transparent;border:1.5px solid var(--cyan);color:var(--cyan);font-family:var(--mono);font-size:11px;letter-spacing:.15em;padding:6px 12px;border-radius:999px;cursor:pointer;transition:all .2s}.share-inline:hover{background:rgba(0,240,255,.1);box-shadow:0 0 12px rgba(0,240,255,.4)}@media (max-width:800px){.result-position{top:-8px;right:-8px;font-size:12px;padding:6px 10px}.result-name{font-size:28px}.result-cta .result__again{font-size:16px;padding:10px 18px}.result__inner--page{padding:24px 18px!important}}.result__submitted-row{display:flex;flex-direction:column;gap:12px;align-items:center;margin-top:16px}.result__submitted-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.result__submitted-actions .result__again{font-size:16px;padding:10px 20px;text-decoration:none;display:inline-flex;align-items:center}.topbar__nav{display:flex;gap:10px;align-items:center}.rhythm-link--rank{background:transparent;font-family:var(--mono);font-size:11px;letter-spacing:.25em;color:var(--cyan);text-decoration:none;border:1px solid rgba(0,240,255,.4);padding:8px 14px;border-radius:2px;transition:all .2s;text-shadow:0 0 12px rgba(0,240,255,.5);cursor:pointer}.rhythm-link--rank:hover{background:rgba(0,240,255,.1);box-shadow:0 0 18px rgba(0,240,255,.5)}.bonus-overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,rgba(255,45,149,.18),rgba(0,240,255,.12) 60%,transparent);pointer-events:none;animation:bonus-bg 4s ease-out forwards}@keyframes bonus-bg{0%{opacity:0}10%{opacity:1}90%{opacity:1}to{opacity:0}}.bonus-overlay__phrase{font-family:var(--hangul);font-size:clamp(36px,7vw,96px);letter-spacing:-.04em;color:var(--fg);text-shadow:-3px 0 var(--magenta),3px 0 var(--cyan),0 0 30px hsla(0,0%,100%,.6);animation:bonus-pop 4s cubic-bezier(.22,1,.36,1) forwards;text-align:center;padding:0 20px}@keyframes bonus-pop{0%{transform:scale(.6) rotate(-3deg);opacity:0}10%{transform:scale(1.15) rotate(2deg);opacity:1}20%{transform:scale(1) rotate(-1deg)}30%{transform:scale(1.05) rotate(1deg)}40%,80%{transform:scale(1) rotate(0);opacity:1}to{transform:scale(.95);opacity:0}}.download-btn{border-color:var(--green)!important;color:var(--green)!important;text-shadow:0 0 12px var(--green)!important}.download-btn:hover{background:rgba(45,255,149,.1)!important;box-shadow:0 0 20px rgba(45,255,149,.5)!important}.rank-table__view{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,240,255,.3);color:var(--cyan);text-decoration:none;font-size:12px;transition:all .2s}.rank-table__view:hover{background:rgba(0,240,255,.12);box-shadow:0 0 12px rgba(0,240,255,.5)}@media (max-width:800px){.topbar__nav{gap:6px}.rhythm-link,.rhythm-link--rank{font-size:9px;padding:6px 10px;letter-spacing:.18em}}.rhythm-link--shout{background:transparent;font-family:var(--mono);font-size:11px;letter-spacing:.25em;color:var(--yellow);border:1px solid rgba(248,255,58,.45);padding:8px 14px;border-radius:2px;transition:all .2s;text-shadow:0 0 12px rgba(248,255,58,.5);cursor:pointer}.rhythm-link--shout:hover{background:rgba(248,255,58,.08);box-shadow:0 0 16px rgba(248,255,58,.4)}.fresh-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:800;display:flex;align-items:center;gap:14px;padding:14px 18px;background:rgba(8,8,8,.92);border:1.5px solid var(--green);border-radius:999px;box-shadow:0 0 28px rgba(45,255,149,.45);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fresh-in .45s cubic-bezier(.22,1,.36,1);max-width:calc(100% - 32px)}@keyframes fresh-in{0%{transform:translate(-50%,-28px);opacity:0}to{transform:translate(-50%);opacity:1}}.fresh-toast__check{width:30px;height:30px;border-radius:50%;background:var(--green);color:#050505;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0}.fresh-toast__text{display:flex;flex-direction:column}.fresh-toast__title{font-family:var(--hangul);font-size:17px;letter-spacing:-.01em;color:var(--fg)}.fresh-toast__sub{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:hsla(0,0%,100%,.5);margin-top:2px}.fresh-toast__btn{background:transparent;border:1px solid var(--cyan);color:var(--cyan);border-radius:999px;padding:8px 14px;font-family:var(--hangul);font-size:14px;cursor:pointer;transition:all .2s}.fresh-toast__btn:hover{background:rgba(0,240,255,.12);box-shadow:0 0 14px rgba(0,240,255,.5)}.fresh-toast__close{background:transparent;border:none;color:hsla(0,0%,100%,.45);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}.fresh-toast__close:hover{color:var(--fg)}@media (max-width:800px){.fresh-toast{top:auto;bottom:24px;flex-wrap:wrap;padding:12px 14px;gap:10px}.fresh-toast__btn{font-size:13px;padding:6px 12px}}.result__auto-notice{margin-top:16px;padding:14px 18px;border:1px dashed hsla(0,0%,100%,.18);border-radius:12px;background:hsla(0,0%,100%,.03);text-align:center}.result__auto-title{font-family:var(--hangul);font-size:18px;letter-spacing:-.01em;color:var(--magenta);text-shadow:0 0 10px rgba(255,45,149,.4)}.result__auto-sub{margin-top:6px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:hsla(0,0%,100%,.55)}.result__auto-sub strong{color:var(--cyan);font-weight:700}.bgm-toggle__kbd{margin-left:10px;font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:hsla(0,0%,100%,.4);border:1px solid hsla(0,0%,100%,.18);border-radius:3px;padding:2px 6px}@media (max-width:800px){.bgm-toggle__kbd{display:none}}.mode-toggle--locked{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.mode-toggle--locked .mode-toggle__btn{cursor:not-allowed;pointer-events:none}.mode-toggle--locked .mode-toggle__slider{background:hsla(0,0%,100%,.25)!important}body.beat{overflow:hidden}body.beat .topbar{padding:14px 28px}.beat-stage{flex:1 1;display:flex;flex-direction:column;gap:16px;padding:16px 28px 12px;position:relative;z-index:10;overflow-y:auto;overflow-x:hidden;min-height:0}.beat-title{display:flex;gap:10px;align-items:center}.beat-title__name,.beat-title__title{background:rgba(0,0,0,.4);border:1.5px solid hsla(0,0%,100%,.12);border-radius:999px;padding:10px 16px;color:var(--fg);font-family:var(--hangul);font-size:18px;letter-spacing:-.01em;outline:none;transition:border-color .2s,box-shadow .2s}.beat-title__name:focus,.beat-title__title:focus{border-color:var(--cyan);box-shadow:0 0 14px rgba(0,240,255,.25)}.beat-title__title{flex:2 1;min-width:0}.beat-title__name{flex:1 1;min-width:0;font-family:var(--mono);font-size:12px;letter-spacing:.1em}.beat-grid{display:flex;flex-direction:column;gap:6px;width:100%;min-width:0;overflow-x:auto;overflow-y:visible;overscroll-behavior-x:contain;scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.18) transparent}.beat-grid__row{display:grid;grid-template-columns:220px repeat(16,minmax(28px,1fr));grid-gap:4px;gap:4px;align-items:stretch}.beat-grid__head .beat-step-num{height:22px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:hsla(0,0%,100%,.3);border-bottom:1px solid hsla(0,0%,100%,.06)}.beat-step-num.is-strong{color:hsla(0,0%,100%,.55)}.beat-step-num.is-active{color:var(--cyan);text-shadow:0 0 6px var(--cyan)}.beat-track{display:flex;align-items:center;gap:8px;padding-right:6px;min-width:0}.beat-track__label{flex:1 1;min-width:0;background:rgba(8,8,8,.85);border:1px solid var(--line);border-radius:6px;padding:8px 10px;text-align:left;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:2px;color:var(--fg);transition:border-color .2s,box-shadow .2s}.beat-track__label:hover{border-color:hsla(0,0%,100%,.32);box-shadow:0 0 14px hsla(0,0%,100%,.08)}.beat-track__name{font-family:var(--hangul);font-size:18px;letter-spacing:-.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.beat-track__cat{font-family:var(--mono);font-size:8px;letter-spacing:.18em;color:hsla(0,0%,100%,.4);text-transform:uppercase}.beat-track__gain{width:64px;flex-shrink:0;accent-color:var(--cyan)}.beat-cell{background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.06);border-radius:4px;cursor:pointer;height:100%;min-height:36px;position:relative;transition:background .08s,transform .06s,box-shadow .12s;outline:none}.beat-cell.is-bar{border-left:2px solid hsla(0,0%,100%,.18)}.beat-cell:hover{background:hsla(0,0%,100%,.1)}.beat-row--magenta .beat-cell.is-on{background:var(--magenta);box-shadow:0 0 14px rgba(255,45,149,.5)}.beat-row--cyan .beat-cell.is-on{background:var(--cyan);box-shadow:0 0 14px rgba(0,240,255,.5)}.beat-row--yellow .beat-cell.is-on{background:var(--yellow);box-shadow:0 0 14px rgba(248,255,58,.5)}.beat-row--green .beat-cell.is-on{background:var(--green);box-shadow:0 0 14px rgba(45,255,149,.5)}.beat-row--bgm .beat-cell.is-on{background:hsla(0,0%,100%,.85);box-shadow:0 0 14px hsla(0,0%,100%,.45),inset 0 0 0 1px rgba(0,240,255,.4)}.beat-row--bgm .beat-cell{background:hsla(0,0%,100%,.04)}.beat-row--bgm .beat-cell:hover{background:hsla(0,0%,100%,.1)}.beat-track__label--bgm{background:linear-gradient(180deg,rgba(0,240,255,.1),hsla(0,0%,100%,.04))!important;border-color:rgba(0,240,255,.35)!important;cursor:default!important}.beat-track__label--bgm .beat-track__name{color:hsla(0,0%,100%,.95)!important}.beat-track__label--bgm .beat-track__cat{color:var(--cyan)!important;font-weight:700;letter-spacing:.12em}.beat-cell.is-current:after{content:"";position:absolute;inset:-3px;border-radius:5px;border:1.5px solid hsla(0,0%,100%,.55);pointer-events:none;animation:beat-step-pulse .18s ease-out}@keyframes beat-step-pulse{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.beat-bottom-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.beat-bottom-actions .rhythm-link{cursor:pointer}.beat-bar{justify-content:space-between;padding:14px 28px 16px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));position:relative;z-index:10}.beat-bar,.beat-transport{display:flex;align-items:center;gap:18px}.beat-transport{flex-wrap:wrap}.beat-transport__play{display:inline-flex;align-items:center;gap:10px;background:transparent;border:2px solid hsla(0,0%,100%,.18);padding:10px 20px;border-radius:999px;font-family:var(--hangul);font-size:18px;letter-spacing:.04em;color:var(--fg);cursor:pointer;transition:all .25s}.beat-transport__play.on{border-color:var(--magenta);color:var(--magenta);text-shadow:0 0 12px var(--magenta);box-shadow:0 0 22px rgba(255,45,149,.45),inset 0 0 22px rgba(255,45,149,.1)}.beat-transport__play .bgm-toggle__dot{width:10px;height:10px;border-radius:50%;background:hsla(0,0%,100%,.25);transition:all .25s}.beat-transport__play.on .bgm-toggle__dot{background:var(--magenta);box-shadow:0 0 14px var(--magenta);animation:dot-pulse .9s ease-in-out infinite}.beat-slider{display:flex;flex-direction:column;gap:4px;min-width:110px}.beat-slider__head{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:hsla(0,0%,100%,.55)}.beat-slider__value{color:var(--cyan)}.beat-slider input[type=range]{accent-color:var(--cyan);width:100%}.sample-picker{min-width:min(680px,92vw);max-height:80vh;overflow:auto}.sample-picker__tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;justify-content:center}.sample-picker__tab{background:transparent;border:1px solid hsla(0,0%,100%,.16);color:hsla(0,0%,100%,.6);padding:6px 12px;border-radius:999px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;cursor:pointer;transition:all .2s}.sample-picker__tab.is-active{background:var(--cyan);color:#000;border-color:var(--cyan);box-shadow:0 0 14px rgba(0,240,255,.5)}.sample-picker__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:10px;gap:10px}.sample-card{background:linear-gradient(155deg,hsla(0,0%,8%,.92),rgba(8,8,8,.95));border:1px solid var(--line);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px;transition:border-color .2s,box-shadow .2s}.sample-card.is-selected{border-color:var(--cyan);box-shadow:0 0 16px rgba(0,240,255,.35)}.sample-card--magenta.is-selected{border-color:var(--magenta);box-shadow:0 0 16px rgba(255,45,149,.35)}.sample-card--yellow.is-selected{border-color:var(--yellow);box-shadow:0 0 16px rgba(248,255,58,.35)}.sample-card--green.is-selected{border-color:var(--green);box-shadow:0 0 16px rgba(45,255,149,.35)}.sample-card__head{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;letter-spacing:.15em;color:hsla(0,0%,100%,.4)}.sample-card__check{color:var(--cyan);font-weight:700}.sample-card__label{font-family:var(--hangul);font-size:22px;letter-spacing:-.03em;color:var(--fg)}.sample-card--magenta .sample-card__label{color:var(--magenta);text-shadow:0 0 10px rgba(255,45,149,.5)}.sample-card--cyan .sample-card__label{color:var(--cyan);text-shadow:0 0 10px rgba(0,240,255,.5)}.sample-card--yellow .sample-card__label{color:var(--yellow);text-shadow:0 0 10px rgba(248,255,58,.5)}.sample-card--green .sample-card__label{color:var(--green);text-shadow:0 0 10px rgba(45,255,149,.5)}.sample-card__actions{display:flex;gap:6px}.sample-card__btn{flex:1 1;background:transparent;border:1px solid hsla(0,0%,100%,.18);color:hsla(0,0%,100%,.7);padding:6px;border-radius:999px;font-family:var(--mono);font-size:10px;letter-spacing:.15em;cursor:pointer;transition:all .2s}.sample-card__btn:hover{border-color:var(--fg);color:var(--fg)}.sample-card__btn--pick{background:var(--cyan);color:#000;border-color:var(--cyan);font-weight:700}.sample-card__btn--pick:hover{box-shadow:0 0 12px rgba(0,240,255,.5)}@media (max-width:800px){body.beat .topbar{padding:12px 16px;gap:10px}.beat-stage{padding:12px 14px 10px;gap:10px}.beat-grid__row{grid-template-columns:130px repeat(16,34px);min-width:max-content;align-items:stretch}.beat-grid__head>.beat-track__label,.beat-grid__row>.beat-track{position:-webkit-sticky;position:sticky;left:0;z-index:3;background:#050505;box-shadow:4px 0 6px rgba(0,0,0,.55)}.beat-track{gap:4px;padding-right:4px}.beat-track__label{flex:1 1;min-width:0;flex-direction:row!important;align-items:center;padding:7px 6px}.beat-track__name{flex:1 1;min-width:0;font-size:12px;letter-spacing:-.06em}.beat-track__cat{display:none}.beat-track__gain,.beat-track__pitch{display:none!important}.beat-row--bgm .beat-track__cat{display:inline}.beat-row--bgm .beat-track__settings{display:none}.beat-cell{min-height:32px}.beat-step-num{font-size:8px}.beat-title__name,.beat-title__title{font-size:14px;padding:8px 12px}.beat-title__name{font-size:11px}.beat-bar{flex-direction:column;align-items:stretch;padding:12px 14px}.beat-transport{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px 14px;gap:10px 14px;align-items:center}.beat-transport__play{grid-column:1/2;justify-self:start;font-size:14px;padding:8px 14px}.step-toggle{grid-column:2/3;justify-self:end}.beat-slider{min-width:0}.sample-picker{min-width:0;width:calc(100vw - 24px)}.sample-picker__grid{grid-template-columns:repeat(2,1fr)}.sample-card__label{font-size:18px}}.rhythm-link--beat{background:transparent;font-family:var(--mono);font-size:11px;letter-spacing:.25em;color:var(--green);text-decoration:none;border:1px solid rgba(45,255,149,.45);padding:8px 14px;border-radius:2px;transition:all .2s;text-shadow:0 0 12px rgba(45,255,149,.5);cursor:pointer}.rhythm-link--beat:hover{background:rgba(45,255,149,.08);box-shadow:0 0 18px rgba(45,255,149,.5)}.bgm-picker{display:flex;flex-direction:column;gap:8px;position:relative}.bgm-chip{display:none}.bgm-picker__panel{display:block}.bgm-picker__close{margin-left:auto;background:transparent;border:none;color:hsla(0,0%,100%,.55);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}.bgm-picker__close:hover{color:var(--fg)}.bgm-picker__head{display:flex;align-items:baseline;gap:12px;font-family:var(--mono)}.bgm-picker__label{font-size:11px;letter-spacing:.25em;color:hsla(0,0%,100%,.55)}.bgm-picker__hint{font-size:10px;letter-spacing:.12em;color:hsla(0,0%,100%,.35)}.bgm-picker__row{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:2px 2px 6px;scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.18) transparent}.bgm-picker__row::-webkit-scrollbar{height:6px}.bgm-picker__row::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.18);border-radius:3px}.bgm-card{flex:0 0 150px;background:linear-gradient(155deg,hsla(0,0%,8%,.92),rgba(8,8,8,.95));border:1.5px solid var(--line);border-radius:8px;padding:10px 12px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:border-color .2s,box-shadow .2s,transform .07s ease-out;color:var(--fg);outline:none}.bgm-card:hover{border-color:rgba(0,240,255,.45);transform:translateY(-1px)}.bgm-card.is-active{border-color:var(--cyan);box-shadow:0 0 18px rgba(0,240,255,.45),inset 0 0 22px rgba(0,240,255,.08)}.bgm-card__title{font-family:var(--hangul);font-size:18px;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bgm-card__artist{font-size:10px;letter-spacing:.1em;color:hsla(0,0%,100%,.55)}.bgm-card__artist,.bgm-card__range{font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bgm-card__range{font-size:9px;letter-spacing:.06em;color:hsla(0,0%,100%,.35)}.bgm-card.is-active .bgm-card__title{color:var(--cyan);text-shadow:0 0 10px rgba(0,240,255,.5)}.bgm-card--off{background:hsla(0,0%,100%,.02);border-style:dashed}.bgm-card--off .bgm-card__title{color:hsla(0,0%,100%,.7)}.bgm-card--off.is-active{border-color:var(--magenta);box-shadow:0 0 14px rgba(255,45,149,.35);border-style:solid}.bgm-card--off.is-active .bgm-card__title{color:var(--magenta);text-shadow:0 0 8px rgba(255,45,149,.5)}@media (max-width:800px){.bgm-card{flex-basis:160px;max-width:180px;padding:8px 12px}.bgm-card__title{font-size:16px}.bgm-card__artist{font-size:9px}.bgm-card__range{font-size:8px;letter-spacing:.04em}}.step-toggle{display:inline-flex;background:rgba(0,0,0,.5);border:1px solid hsla(0,0%,100%,.16);border-radius:999px;padding:3px;font-family:var(--mono);font-size:11px;letter-spacing:.18em}.step-toggle__btn{background:transparent;border:none;color:hsla(0,0%,100%,.55);padding:6px 12px;border-radius:999px;cursor:pointer;font:inherit;letter-spacing:inherit;transition:background .2s,color .2s}.step-toggle__btn.is-active{background:var(--cyan);color:#000;box-shadow:0 0 12px rgba(0,240,255,.45);font-weight:700}.beat-grid--32 .beat-grid__row{grid-template-columns:220px repeat(32,minmax(16px,1fr));gap:2px}.beat-grid--32 .beat-cell{min-height:32px}.beat-grid--32 .beat-step-num{font-size:8px}@media (max-width:800px){.beat-grid--32 .beat-grid__row{grid-template-columns:130px repeat(32,22px);min-width:max-content}.beat-grid--32 .beat-cell{min-height:26px}}.bgm-bar--with-picker{align-items:stretch;gap:16px}.bgm-bar__pickerwrap{flex:1 1;min-width:0}.bgm-bar__rightside{display:flex;align-items:center;gap:16px;flex-shrink:0}.bgm-toggle:disabled{opacity:.4;cursor:not-allowed}@media (max-width:800px){.bgm-bar--with-picker{flex-direction:column;align-items:stretch;gap:10px}.bgm-bar__rightside{justify-content:space-between}}.rank-modal{min-width:min(620px,92vw);max-height:85vh;overflow:auto}.rank-modal__title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;font-size:16px;color:var(--cyan);margin-bottom:14px}.rank-modal__track{font-family:var(--hangul);font-size:18px;color:var(--fg);letter-spacing:-.02em}.rank-modal__tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;padding:8px;background:rgba(0,0,0,.4);border-radius:10px;border:1px solid var(--line)}.rank-modal__tab{background:transparent;border:1px solid hsla(0,0%,100%,.14);color:hsla(0,0%,100%,.55);padding:6px 10px;border-radius:999px;font-family:var(--hangul);font-size:12px;letter-spacing:-.02em;cursor:pointer;transition:all .18s}.rank-modal__tab:hover{color:var(--fg);border-color:hsla(0,0%,100%,.3)}.rank-modal__tab.is-active{background:var(--cyan);color:#000;border-color:var(--cyan);box-shadow:0 0 12px rgba(0,240,255,.4);font-weight:700}.rhythm-bar--with-picker{align-items:stretch;gap:12px}.rhythm-bar__pickerwrap{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:6px}.rhythm-bar__progress{display:flex;align-items:baseline;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.1em}.rhythm-bar__title{font-family:var(--hangul);font-size:14px;letter-spacing:-.01em;color:var(--fg)}.rhythm-bar__sub{color:hsla(0,0%,100%,.5)}.rhythm-bar__rightside{display:flex;align-items:center;gap:12px;flex-shrink:0}@media (max-width:800px){.rhythm-bar--with-picker{flex-direction:column;align-items:stretch;gap:10px}.rhythm-bar__rightside{justify-content:space-between}.rank-modal__tab{font-size:11px;padding:5px 8px}}.bgm-picker.is-locked .bgm-card{cursor:not-allowed;opacity:.4;filter:grayscale(.5);pointer-events:none}.bgm-picker.is-locked .bgm-card.is-active{opacity:.85;filter:none}.bgm-card:disabled{cursor:not-allowed}.beat-track__pitch{display:inline-flex;align-items:center;gap:2px;background:rgba(0,0,0,.5);border:1px solid hsla(0,0%,100%,.12);border-radius:999px;padding:2px;font-family:var(--mono);flex-shrink:0}.beat-track__pitch-btn{background:transparent;border:none;width:22px;height:22px;border-radius:50%;color:hsla(0,0%,100%,.7);cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.beat-track__pitch-btn:hover{background:hsla(0,0%,100%,.08);color:var(--fg)}.beat-track__pitch-btn:active{transform:scale(.92)}.beat-track__pitch-val{min-width:28px;text-align:center;font-size:11px;color:var(--cyan);letter-spacing:.05em;font-weight:700}.beat-track__pitch-val[data-zero=true]{color:hsla(0,0%,100%,.4);font-weight:400}@media (max-width:800px){.beat-track__pitch-btn{width:20px;height:20px;font-size:12px}.beat-track__pitch-val{min-width:24px;font-size:10px}}.bgm-chip{align-items:center;gap:8px;width:100%;background:linear-gradient(180deg,hsla(0,0%,8%,.92),rgba(8,8,8,.95));border:1px solid var(--line);border-radius:999px;padding:8px 14px;color:var(--fg);cursor:pointer;text-align:left;font-family:var(--mono);font-size:11px;letter-spacing:.06em}.bgm-chip__icon{font-size:14px;flex-shrink:0}.bgm-chip__title{font-family:var(--hangul);font-size:14px;letter-spacing:-.02em;color:var(--cyan)}.bgm-chip__title--off{color:hsla(0,0%,100%,.55)}.bgm-chip__meta{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:hsla(0,0%,100%,.5);font-size:10px}.bgm-chip__chevron{color:hsla(0,0%,100%,.55);font-size:12px;flex-shrink:0}.bgm-chip.has-bgm{border-color:rgba(0,240,255,.45);box-shadow:0 0 12px rgba(0,240,255,.18)}.beat-track__settings{display:none;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--line);background:rgba(8,8,8,.85);color:hsla(0,0%,100%,.6);border-radius:6px;font-size:14px;cursor:pointer;flex-shrink:0}.beat-track__settings:hover{color:var(--fg);border-color:hsla(0,0%,100%,.32)}.track-control__pitch{display:flex;flex-direction:column;gap:8px}.track-control__pitch-label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:hsla(0,0%,100%,.55)}.track-control__pitch-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(8,8,8,.85);border:1px solid var(--line);border-radius:999px;padding:6px 12px}.track-control__pitch-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:hsla(0,0%,8%,.85);color:var(--fg);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center}.track-control__pitch-btn:active{transform:scale(.94)}.track-control__pitch-val{flex:1 1;text-align:center;font-family:var(--mono);font-size:22px;color:var(--cyan);font-weight:700;letter-spacing:.05em}.track-control__pitch-val[data-zero=true]{color:hsla(0,0%,100%,.45);font-weight:400}.beat-transport__settings{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line);background:rgba(8,8,8,.85);color:hsla(0,0%,100%,.7);border-radius:999px;font-size:18px;cursor:pointer}.beat-transport__settings:hover{color:var(--fg);border-color:hsla(0,0%,100%,.32)}.transport-settings{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-end;justify-content:center}.transport-settings__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.transport-settings__sheet{position:relative;width:100%;max-width:480px;background:linear-gradient(180deg,hsla(0,0%,6%,.98),rgba(5,5,5,.98));border:1px solid var(--line);border-bottom:none;border-top-left-radius:16px;border-top-right-radius:16px;padding:16px 20px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -8px 36px rgba(0,0,0,.55);animation:settings-up .22s ease-out}@keyframes settings-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.transport-settings__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.transport-settings__title{font-family:var(--mono);font-size:11px;letter-spacing:.3em;color:hsla(0,0%,100%,.6)}.transport-settings__close{background:transparent;border:none;color:hsla(0,0%,100%,.55);font-size:26px;line-height:1;cursor:pointer;padding:0 6px}.transport-settings__close:hover{color:var(--fg)}.transport-settings__body{display:flex;flex-direction:column;gap:14px}.transport-settings__body .beat-slider{min-width:0}.topbar__social{display:none}body.beat .topbar__social{align-items:center;justify-content:center;color:hsla(0,0%,100%,.55);transition:color .2s}body.beat .topbar__social:hover{color:var(--cyan)}@media (max-width:800px){body.beat main.beat-stage{flex:1 1;min-height:0;display:flex;flex-direction:column}body.beat main.beat-stage>.beat-grid{flex:1 1;min-height:0}.bgm-picker.is-collapsible .bgm-chip{display:inline-flex}.bgm-picker.is-collapsible.is-collapsed .bgm-picker__panel{display:none}.bgm-picker.is-collapsible.is-expanded .bgm-picker__panel{position:absolute;z-index:20;margin-top:8px;left:14px;right:14px;background:linear-gradient(180deg,hsla(0,0%,6%,.98),rgba(5,5,5,.98));border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:0 12px 32px rgba(0,0,0,.6)}.bgm-picker.is-collapsible.is-expanded .bgm-picker__row{overflow-x:auto}.beat-transport{display:grid!important;grid-template-columns:auto auto 1fr auto;grid-gap:8px;gap:8px;align-items:center}.beat-transport__play{font-size:13px!important;padding:7px 12px!important;justify-self:start}.step-toggle{font-size:10px;padding:2px 6px}.beat-slider{min-width:0}.beat-slider--hide-mobile{display:none!important}.beat-track__settings,.beat-transport__settings{display:inline-flex}body.beat .credits{display:none}body.beat .topbar__social--mobile{display:inline-flex}body.beat .beat-title{gap:6px;padding:4px 0}body.beat .beat-title__name,body.beat .beat-title__title{padding:6px 10px!important;font-size:12px!important}body.beat .topbar{padding:8px 14px!important}body.beat .beat-bottom-actions{gap:8px;margin-top:2px}body.beat .beat-bottom-actions .rhythm-link{padding:6px 12px;font-size:10px}body.beat .beat-bar{padding:8px 12px calc(10px + env(safe-area-inset-bottom))!important;gap:8px}}.pe-root{position:fixed;inset:0;display:grid;grid-template-rows:auto auto 1fr auto;background:#050010;color:#f0e9ff;font-family:JetBrains Mono,monospace;font-size:12px;z-index:1}.pe-top{display:flex;align-items:center;gap:16px;padding:8px 16px;border-bottom:1px solid rgba(255,45,149,.3);background:rgba(20,5,40,.9)}.pe-back{color:var(--cyan,#00f0ff);text-decoration:none;font-weight:700}.pe-title{font-weight:900;font-size:14px;color:var(--magenta,#ff2d95);letter-spacing:2px}.pe-bgm-pick{margin-left:auto;display:flex;align-items:center;gap:8px}.pe-bgm-pick select{background:rgba(40,10,80,.6);color:#fff;border:1px solid rgba(0,240,255,.4);padding:4px 8px;font-family:inherit;font-size:12px}.pe-loading{color:var(--yellow,#f8ff3a);font-size:11px}.pe-toolbar{display:flex;align-items:center;gap:14px;padding:8px 16px;background:rgba(15,5,30,.8);border-bottom:1px solid hsla(0,0%,100%,.06);flex-wrap:wrap}.pe-types{display:flex;gap:6px}.pe-type{border:2px solid;background:transparent;padding:6px 12px;font-family:inherit;font-weight:700;font-size:11px;cursor:pointer;letter-spacing:1px}.pe-type.on{font-weight:900}.pe-snap{display:flex;align-items:center;gap:8px;color:#b0a0d0}.pe-snap input,.pe-snap select{background:rgba(40,10,80,.6);color:#fff;border:1px solid rgba(0,240,255,.4);padding:3px 6px;font-family:inherit;font-size:11px}.pe-bpm{display:flex;align-items:center;gap:4px}.pe-actions{margin-left:auto;display:flex;gap:6px}.pe-actions button{background:rgba(40,10,80,.6);color:#d0c0ff;border:1px solid rgba(255,45,149,.4);padding:5px 10px;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer}.pe-actions button.primary{background:var(--magenta,#ff2d95);color:#000;border-color:var(--magenta,#ff2d95)}.pe-actions button:disabled{opacity:.4;cursor:not-allowed}.pe-main{display:grid;grid-template-columns:1fr 320px;grid-gap:0;gap:0;overflow:hidden}.pe-stage{position:relative;background:linear-gradient(180deg,rgba(60,10,100,.4),#050010),repeating-linear-gradient(0deg,hsla(0,0%,100%,.04) 0 1px,transparent 1px 40px),repeating-linear-gradient(90deg,hsla(0,0%,100%,.04) 0 1px,transparent 1px 40px);cursor:crosshair;touch-action:none;overflow:hidden}.pe-canvas{inset:0}.pe-canvas,.pe-hud{position:absolute;pointer-events:none}.pe-hud{top:8px;left:8px;gap:4px;font-size:11px;color:#b0a0d0;background:rgba(0,0,0,.5);padding:6px 10px;border-left:2px solid var(--magenta,#ff2d95)}.pe-hud,.pe-side{display:flex;flex-direction:column}.pe-side{border-left:1px solid hsla(0,0%,100%,.1);background:rgba(10,0,20,.92);overflow:hidden}.pe-defaults{padding:10px 12px;border-bottom:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;gap:6px}.pe-defaults__title{font-weight:900;color:var(--yellow,#f8ff3a);font-size:11px;letter-spacing:1px;margin-bottom:4px}.pe-defaults label,.pe-detail label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#c0b0e0;gap:8px}.pe-defaults input,.pe-defaults select,.pe-detail input,.pe-detail select{background:rgba(40,10,80,.6);color:#fff;border:1px solid rgba(0,240,255,.3);padding:3px 6px;font-family:inherit;font-size:11px;width:100px}.pe-notes{flex:1 1;overflow:hidden;display:flex;flex-direction:column}.pe-notes__head{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid hsla(0,0%,100%,.08);font-weight:700;color:#f0e9ff}.pe-notes__head button{background:rgba(255,45,149,.3);color:#fff;border:1px solid var(--magenta,#ff2d95);padding:3px 8px;font-family:inherit;font-size:10px;cursor:pointer}.pe-notes__list{flex:1 1;overflow-y:auto}.pe-note-row{display:flex;gap:8px;padding:5px 12px;border-left:3px solid;cursor:pointer;font-size:11px;border-bottom:1px solid hsla(0,0%,100%,.04)}.pe-note-row:hover{background:rgba(255,45,149,.1)}.pe-note-row.sel{background:rgba(0,240,255,.15)}.pe-note-row__t{color:var(--yellow,#f8ff3a);min-width:56px}.pe-note-row__type{font-weight:700;min-width:56px}.pe-note-row__pos{color:#b0a0d0}.pe-empty{padding:20px;text-align:center;color:#807090;font-size:11px}.pe-detail{padding:10px 12px;border-top:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;gap:6px;background:rgba(20,5,50,.5)}.pe-bottom{display:flex;align-items:center;gap:12px;padding:8px 16px;background:rgba(15,5,30,.95);border-top:1px solid rgba(255,45,149,.3)}.pe-play{background:var(--magenta,#ff2d95);color:#000;border:none;padding:8px 20px;font-family:inherit;font-weight:900;cursor:pointer;letter-spacing:1px}.pe-play:disabled{opacity:.4;cursor:not-allowed}.pe-bottom button{background:rgba(40,10,80,.6);color:#fff;border:1px solid rgba(0,240,255,.4);padding:8px 14px;font-family:inherit;font-weight:700;cursor:pointer}.pe-seek{flex:1 1;accent-color:var(--magenta,#ff2d95)}.pe-time{color:var(--yellow,#f8ff3a);min-width:160px;text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pe-toggle{gap:4px;font-size:11px;color:#c0b0e0}.pe-modal,.pe-toggle{display:flex;align-items:center}.pe-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);justify-content:center;z-index:100}.pe-modal__inner{background:#1a0530;border:1px solid var(--magenta,#ff2d95);padding:20px;width:600px;max-width:95vw;display:flex;flex-direction:column;gap:12px}.pe-modal__title{font-weight:900;color:var(--yellow,#f8ff3a)}.pe-modal textarea{background:#050010;color:#fff;border:1px solid rgba(0,240,255,.4);padding:10px;font-family:monospace;font-size:12px;resize:vertical}.pe-modal__actions{display:flex;justify-content:flex-end;gap:8px}.pe-modal__actions button{background:rgba(40,10,80,.6);color:#fff;border:1px solid rgba(0,240,255,.4);padding:6px 14px;font-family:inherit;cursor:pointer}.pe-modal__actions button.primary{background:var(--magenta,#ff2d95);color:#000;border-color:var(--magenta,#ff2d95)}@media (max-width:800px){.pe-main{grid-template-columns:1fr 240px}.pe-defaults input,.pe-detail input{width:70px}.pe-bottom{flex-wrap:wrap}}