:root{--cream-50: #faf9f5;--cream-100: #f5f4ed;--cream-200: #f0eee6;--cream-300: #e8e6dc;--cream-400: #e0ddd0;--ink-950: #141413;--ink-800: #30302e;--ink-700: #3d3d3a;--ink-600: #4d4c48;--olive-600: #5e5d59;--stone-400: #6b6a64;--stone-500: #87867f;--silver-500: #b0aea5;--cream-500: #d1cfc5;--cream-600: #c2c0b6;--white-pure: #ffffff;--focus-500: #3898ec;--terracotta-400: #d97757;--terracotta-500: #c96442;--terracotta-600: #b35837;--error-500: #b53333;--warning-500: #d9a030;--success-500: #3a7a4a;--chart-blue: #3b82f6;--chart-cyan: #38bdf8;--chart-violet: #8b5cf6;--chart-slate: #64748b;--surface-page: var(--cream-100);--surface-card: var(--cream-50);--surface-raised: var(--cream-50);--surface-sunken: var(--cream-200);--surface-hover: var(--cream-300);--text-primary: var(--ink-950);--text-secondary: var(--olive-600);--text-muted: var(--stone-500);--text-subtle: var(--stone-400);--text-inverse: var(--cream-50);--border-subtle: var(--cream-200);--border-warm: var(--cream-300);--border-strong: var(--ink-950);--border-dark: var(--ink-800);--ring-warm: var(--cream-500);--ring-deep: var(--cream-600);--focus-ring: var(--focus-500);--brand-default: var(--terracotta-500);--brand-hover: var(--terracotta-400);--brand-strong: var(--terracotta-600);--status-error: var(--error-500);--status-warning: var(--warning-500);--status-success: var(--success-500);--overlay-modal: color-mix(in srgb, var(--ink-950) 55%, transparent);--overlay-hover-soft: color-mix(in srgb, var(--ink-950) 6%, transparent);--overlay-hover-warm: color-mix(in srgb, var(--ink-950) 12%, transparent);--overlay-brand-soft: color-mix(in srgb, var(--brand-default) 10%, transparent);--overlay-brand-mid: color-mix(in srgb, var(--brand-default) 20%, transparent);--overlay-brand-strong: color-mix(in srgb, var(--brand-default) 35%, transparent);--shadow-card: 0 1px 3px color-mix(in srgb, var(--ink-950) 6%, transparent), 0 1px 2px color-mix(in srgb, var(--ink-950) 4%, transparent);--shadow-card-hover: 0 4px 12px color-mix(in srgb, var(--ink-950) 10%, transparent), 0 2px 4px color-mix(in srgb, var(--ink-950) 6%, transparent);--shadow-ring-warm: 0 0 0 1px var(--ring-warm);--shadow-ring-deep: 0 0 0 1px var(--ring-deep);--shadow-ring-brand: 0 0 0 1px var(--brand-default);--shadow-whisper: 0 4px 24px color-mix(in srgb, var(--ink-950) 5%, transparent);--shadow-inset-press: inset 0 0 0 1px color-mix(in srgb, var(--ink-950) 15%, transparent);--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-micro: .1s;--duration-short: .2s;--duration-medium: .35s;--duration-long: .5s;--font-serif: "Noto Serif KR", Georgia, "Times New Roman", serif;--font-sans: "Noto Sans KR", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Cascadia Code", Consolas, monospace;--font-display: "Oxanium", "Noto Sans KR", sans-serif;--text-display-1: 4rem;--text-display-2: 3.25rem;--text-h1: 2.3rem;--text-h2: 2rem;--text-h3: 1.6rem;--text-h4: 1.3rem;--text-body-lg: 1.25rem;--text-body: 1.0625rem;--text-body-md: 1rem;--text-body-sm: .9375rem;--text-caption: .875rem;--text-label: .75rem;--text-overline: .625rem;--text-micro: .6rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--leading-tight: 1.1;--leading-snug: 1.2;--leading-normal: 1.3;--leading-comfort: 1.43;--leading-relaxed: 1.6;--tracking-normal: 0;--tracking-label: .12px;--tracking-overline: .5px;--tracking-micro: .096px;--tracking-code: -.32px;--space-0: 0;--space-3xs: .125rem;--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-section-sm: 5rem;--space-section-lg: 7.5rem;--radius-sharp: .25rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--layout-max-content: 75rem;--layout-max-readable: 42rem;--layout-grid-gap: var(--space-lg);--waveform-playhead: var(--text-primary);--waveform-divider: var(--border-subtle);--waveform-bar-line: color-mix(in srgb, var(--ink-950) 6%, transparent);--waveform-beat-line: color-mix(in srgb, var(--ink-950) 3%, transparent);--waveform-loop-border: var(--brand-default);--waveform-loop-handle: var(--brand-default);--waveform-loop-select: color-mix(in srgb, var(--brand-default) 22%, transparent);--waveform-dim-outside: color-mix(in srgb, var(--ink-950) 45%, transparent);--waveform-loop-tint: color-mix(in srgb, var(--brand-default) 8%, transparent);--waveform-handle-pill: color-mix(in srgb, var(--ink-950) 85%, transparent);--waveform-recording-line: var(--status-error);--waveform-recording-fill: color-mix(in srgb, var(--status-error) 80%, transparent);--game-string-1: #ff3355;--game-string-2: #ffcc00;--game-string-3: #4488ff;--game-string-4: #ff8800;--game-string-5: #00dd66;--game-string-6: #cc44ff;--neon-purple: #7c5cfc;--neon-purple-deep: #6a4cf0;--neon-gold: #f5d76e;--neon-amber: #ffd700;--neon-orange: #ff8800;--neon-magenta: #ff00aa;--neon-pink: #ff3355;--neon-violet: #aa44ff;--neon-blue: #4488ff;--neon-blue-mid: #4d96ff;--neon-blue-deep: #4466ff;--neon-cyan: #00f0ff;--neon-green: #00ff88;--game-bg-deep: #1a1030;--game-bg-mid: #2a2240;--game-bg-lift: #3a2a6a;--game-bg-dawn: #1a1528;--game-bg-abyss: #08060e;--game-bg-night: #0d0a16;--game-bg-card: #13101f;--game-card-purple-end: #2a1540;--game-card-blue-start: #0a1828;--game-card-blue-end: #1a2838;--game-fog: #060410;--game-fretboard: #1a1210;--game-fret-nut: #dcdcdc;--game-fret-bar: #8c82aa;--game-inlay: #999999;--game-fret-dot-dim: #3c3255;--game-fret-dot: #b4a0dc;--game-fret-label: #c8b4ff;--game-glow-label: color-mix(in srgb, var(--game-fret-label) 60%, transparent);--game-glow-bright: color-mix(in srgb, var(--white-pure) 50%, transparent);--game-glow-mid: color-mix(in srgb, var(--white-pure) 12%, transparent);--game-glow-fade: color-mix(in srgb, var(--white-pure) 0%, transparent);--game-text-dim: #9ca3c2;--game-text-muted: #6b6894;--game-text-hint: #c0c4dc;--game-text-cool: #dfe3f0;--game-text-cold: #f0f2ff;--game-warmwood: #a97b65;--chart-section-intro: #3b82f6;--chart-section-verse: #10b981;--chart-section-pre-chorus: #f59e0b;--chart-section-chorus: #ef4444;--chart-section-bridge: #8b5cf6;--chart-section-outro: #6366f1;--chart-section-inst: #64748b;--chart-section-silence: #374151;--chart-section-default: #6b7280;--stem-vocals-bg: #f4e0da;--stem-vocals-fg: #b8553b;--stem-drums-bg: #f5eacd;--stem-drums-fg: #a67b1e;--stem-bass-bg: #dce8fa;--stem-bass-fg: #3670c9;--stem-piano-bg: #e8dff7;--stem-piano-fg: #7044b5;--stem-guitar-bg: #d9eddf;--stem-guitar-fg: #2d6b3d;--gp-art-terra-from: #b8553b;--gp-art-terra-to: #c96442;--gp-art-blue-from: #3670c9;--gp-art-blue-to: #5b8fd9;--gp-art-violet-from:#7044b5;--gp-art-violet-to: #9066cc;--gp-art-green-from: #3a7a4a;--gp-art-green-to: #4d9960;--stave-line: color-mix(in srgb, var(--ink-950) 25%, transparent);--stave-separator: color-mix(in srgb, var(--ink-950) 35%, transparent);--stave-glyph-primary: var(--text-primary);--stave-glyph-secondary: var(--text-secondary);--stave-glyph-meta: var(--text-muted);--stave-bar-number: var(--brand-default);--stave-cursor-bar: color-mix(in srgb, var(--brand-default) 10%, transparent);--stave-cursor-beat: color-mix(in srgb, var(--brand-default) 45%, transparent);--ios-label: #1c1c1e;--ios-secondary-label: #8e8e93;--ios-separator: #d1d1d6;--ios-fill-secondary: #f0ede8}/*! 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-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}}}@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-serif:ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--leading-snug:1.375;--leading-relaxed:1.625;--radius-xs:.125rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@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%;-moz-tab-size:4;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;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-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,)}}@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-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}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%;background-color:var(--surface-page);color:var(--text-primary);font-family:Noto Sans KR,system-ui,-apple-system,Segoe UI,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--brand-default);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}.route-shell{padding:2rem;max-width:1200px;margin:0 auto;width:100%}.route-shell h1{font-family:"Noto Serif KR",serif;font-weight:700;margin:0 0 1rem;color:var(--text-primary)}.route-shell p{color:var(--text-secondary)}.route-studio{padding:1rem;max-width:100%}.sep-page{display:flex;flex-direction:column;gap:1.25rem;max-width:1200px;margin:0 auto}.sep-page-head{display:flex;align-items:baseline;gap:1rem;justify-content:space-between}.sep-page-head h1{font-family:"Noto Serif KR",serif;font-weight:700;margin:0;color:var(--text-primary)}.sep-page-head-meta{color:var(--text-secondary);font-size:.875rem;margin:0}.sep-strip{border:2px dashed var(--border-warm);border-radius:12px;padding:1.5rem;display:flex;gap:.75rem;align-items:center;cursor:pointer;background:var(--surface-raised);color:var(--text-secondary);transition:all .15s ease}.sep-strip:hover,.sep-strip.is-drag{border-color:var(--brand-default);background:var(--surface-hover);color:var(--text-primary)}.sep-strip-text{flex:1;font-weight:500}.sep-strip-formats{font-size:.75rem;color:var(--text-muted)}.sep-active{display:flex;flex-direction:column;gap:.5rem}.sep-active-head{font-size:.875rem;color:var(--text-secondary);margin:0}.sep-active-row{display:grid;grid-template-columns:2fr 1fr auto 2fr;gap:.75rem;align-items:center;padding:.5rem .75rem;background:var(--surface-raised);border-radius:6px}.sep-active-name,.sep-active-step,.sep-active-pct{margin:0;font-size:.875rem}.sep-active-bar{background:var(--surface-sunken);height:6px;border-radius:3px;overflow:hidden}.sep-active-fill{background:var(--brand-default);height:100%;transition:width .2s ease}.sep-toolbar{display:flex;gap:.75rem;align-items:center}.sep-search{flex:1}.sep-search input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-warm);border-radius:8px;background:var(--surface-raised);color:var(--text-primary)}.sep-sort{padding:.5rem .75rem;border:1px solid var(--border-warm);border-radius:8px;background:var(--surface-raised);color:var(--text-primary)}.sep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.sep-card{position:relative;background:var(--surface-raised);border:1px solid var(--border-warm);border-radius:10px;padding:1rem;cursor:pointer;display:flex;flex-direction:column;gap:.75rem;transition:all .15s ease}.sep-card:hover{border-color:var(--brand-default);background:var(--surface-hover)}.sep-card.is-running{cursor:default;opacity:.7}.sep-card.is-failed{border-color:var(--status-error)}.sep-card-title{margin:0;font-weight:600;color:var(--text-primary)}.sep-card-subtitle{margin:0;color:var(--text-secondary);font-size:.875rem}.sep-card-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.75rem}.sep-card-meta-item{color:var(--text-muted)}.sep-card-progress{background:var(--surface-sunken);height:4px;border-radius:2px;overflow:hidden}.sep-card-progress-fill{background:var(--brand-default);height:100%;transition:width .2s ease}.sep-card-step{margin:.25rem 0 0;font-size:.75rem;color:var(--text-muted)}.sep-card-error{font-size:.75rem;color:var(--status-error)}.sep-card-menu{position:absolute;top:.5rem;right:.5rem;background:transparent;border:none;padding:.25rem;color:var(--text-muted);border-radius:4px}.sep-card-menu:hover{background:var(--surface-hover);color:var(--status-error)}.sep-empty{text-align:center;padding:2rem;color:var(--text-muted)}.sep-empty-title{margin:0;font-weight:600}.sep-empty-hint{margin:.25rem 0 0;font-size:.875rem}.sep-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--ink-950) 45%,transparent);display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.sep-overlay-inner{background:var(--surface-raised);padding:2rem;border-radius:12px;border:2px dashed var(--brand-default);text-align:center}.sep-stem-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--ink-950) 50%,transparent);display:flex;align-items:center;justify-content:center;z-index:1100}.sep-stem-modal-card{background:var(--surface-page);border-radius:12px;padding:1.5rem;width:min(460px,90vw);max-height:90vh;overflow:auto;box-shadow:0 10px 40px color-mix(in srgb,var(--ink-950) 25%,transparent)}.sep-stem-modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.sep-stem-modal-head h3{margin:0;font-family:"Noto Serif KR",serif}.sep-stem-modal-head p{margin:.25rem 0 0;color:var(--text-secondary);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.sep-stem-modal-close{background:transparent;border:none;font-size:1.25rem;color:var(--text-muted);padding:.25rem .5rem}.sep-stem-modal-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.sep-stem-modal-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.sep-stem-modal-item:hover{background:var(--surface-hover)}.sep-stem-modal-label{flex:1;font-weight:500}.sep-stem-modal-toggle{width:36px;height:20px;border-radius:10px;background:var(--surface-sunken);position:relative;transition:background .15s ease}.sep-stem-modal-toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--surface-page);transition:transform .15s ease}.sep-stem-modal-toggle.is-on{background:var(--brand-default)}.sep-stem-modal-toggle.is-on:after{transform:translate(16px)}.sep-stem-guitar-seg{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.sep-stem-guitar-seg.is-disabled{opacity:.4;pointer-events:none}.sep-stem-guitar-seg-btn{border:1px solid var(--border-warm);border-radius:8px;padding:.5rem;cursor:pointer;display:flex;flex-direction:column;gap:.125rem;text-align:center;background:var(--surface-raised)}.sep-stem-guitar-seg-btn.is-active{border-color:var(--brand-default);background:var(--surface-hover)}.sep-stem-guitar-seg-title{font-size:.75rem;font-weight:600}.sep-stem-guitar-seg-sub{font-size:.675rem;color:var(--text-muted)}.sep-stem-modal-foot{display:flex;justify-content:flex-end;gap:.5rem}.sep-stem-modal-cancel{background:transparent;border:1px solid var(--border-warm);padding:.5rem 1rem;border-radius:8px;cursor:pointer}.btn-brand{background:var(--brand-default);color:var(--white-pure);border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-weight:600}.btn-brand:disabled{opacity:.5;cursor:not-allowed}.sep-stem-modal-pill{background:color-mix(in srgb,var(--white-pure) 20%,transparent);border-radius:10px;padding:.125rem .5rem;margin-left:.5rem;font-size:.75rem}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.studio-layout{display:flex;flex-direction:column;gap:.75rem;max-width:1600px;margin:0 auto}.studio-loading,.studio-error{padding:2rem;text-align:center;color:var(--text-secondary)}.studio-cockpit{display:flex;flex-direction:column;gap:.75rem;background:var(--surface-raised);border:1px solid var(--border-warm);border-radius:12px;padding:1rem}.studio-header{display:flex;align-items:center;gap:1rem;justify-content:space-between}.studio-header-left{display:flex;align-items:center;gap:.5rem}.studio-back-btn{background:transparent;border:1px solid var(--border-subtle);width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background var(--duration-micro) var(--ease-default),color var(--duration-micro) var(--ease-default),border-color var(--duration-micro) var(--ease-default)}.studio-back-btn:hover{background:var(--surface-sunken);color:var(--text-primary);border-color:var(--ring-warm)}.studio-header-left .studio-filename{margin:0;font-family:var(--font-serif);font-size:var(--text-h4);font-weight:var(--weight-medium);line-height:var(--leading-snug);color:var(--text-primary);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.studio-header-controls{display:flex;gap:.75rem;align-items:center}.studio-header-right{display:flex;align-items:center;gap:.5rem}.studio-header-btn{background:transparent;border:1px solid var(--border-warm);color:var(--text-primary);border-radius:6px;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;line-height:1;transition:background .12s ease}.studio-header-btn:hover{background:var(--surface-hover)}.studio-header-btn-primary{background:var(--brand-default);border-color:var(--brand-default);color:var(--white-pure)}.studio-header-btn-primary:hover{background:var(--brand-strong);border-color:var(--brand-strong)}.studio-bpm-control,.studio-key-control{display:inline-flex;align-items:center;gap:var(--space-3xs);background:var(--surface-sunken);border:1px solid transparent;border-radius:var(--radius-md);padding:2px;transition:box-shadow var(--duration-micro) var(--ease-default),border-color var(--duration-micro) var(--ease-default)}.studio-bpm-control:hover,.studio-key-control:hover{box-shadow:var(--shadow-ring-warm)}.studio-ctrl-btn{background:transparent;border:none;width:24px;height:24px;cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background var(--duration-micro) var(--ease-default),color var(--duration-micro) var(--ease-default)}.studio-ctrl-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.studio-ctrl-value{min-width:80px;text-align:center;font-size:var(--text-body-sm);font-weight:var(--weight-medium);color:var(--text-primary);display:inline-flex;align-items:baseline;justify-content:center;gap:var(--space-3xs);padding:0 var(--space-2xs)}.studio-ctrl-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:var(--text-body-sm);letter-spacing:var(--tracking-code);color:var(--text-primary)}.studio-ctrl-num-input{width:3ch;padding:0;margin:0;border:none;outline:none;background:transparent;text-align:center;cursor:text;border-radius:var(--radius-xs);transition:background var(--duration-micro) var(--ease-default),box-shadow var(--duration-micro) var(--ease-default)}.studio-ctrl-num-input:hover{background:var(--surface-hover)}.studio-ctrl-num-input:focus-visible{background:color-mix(in srgb,var(--brand-default) 10%,transparent);box-shadow:0 0 0 1px var(--brand-default)}.studio-ctrl-num-input::-webkit-outer-spin-button,.studio-ctrl-num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.studio-ctrl-unit{font-family:var(--font-sans);font-size:var(--text-caption);font-weight:var(--weight-regular);color:var(--text-muted);letter-spacing:var(--tracking-label)}.studio-meta-tag{font-size:.8rem;color:var(--text-muted)}.studio-main{display:grid;grid-template-columns:360px 1fr 220px;gap:.75rem;align-items:start}.studio-sections-rail{display:flex;flex-direction:column;gap:var(--space-2xs);padding:0 0 0 var(--space-sm);min-height:0}.studio-sections-rail-title{margin:0 0 var(--space-2xs) var(--space-xs);font-family:var(--font-sans);font-size:var(--text-caption);font-weight:500;letter-spacing:0;text-transform:none;color:var(--text-muted)}.studio-sections-rail-list{display:flex;flex-direction:column;gap:0;overflow-y:auto;min-height:0;flex:1}.studio-sections-rail-list .section-chip{background:transparent;border:0;border-left:0;border-radius:var(--radius-sm);padding:var(--space-2xs) var(--space-xs);width:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-xs);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-body-md);color:var(--text-primary);text-align:left;transition:background var(--duration-micro) var(--ease-default)}.studio-sections-rail-list .section-chip:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background:var(--section-color, var(--brand-default))}.studio-sections-rail-list .section-chip:hover{background:var(--surface-sunken)}.studio-sections-rail-list .section-chip.is-looping{background:var(--surface-sunken);font-weight:500}.studio-sections-rail-list .section-chip.is-looping:before{width:8px;height:8px}.studio-sections-rail-list .section-chip-label{text-transform:capitalize}.studio-sections-rail-list .section-chip-time{font-variant-numeric:tabular-nums;font-size:var(--text-caption);color:var(--text-muted)}.studio-sections-rail-list .section-chip.is-looping .section-chip-time{color:var(--text-secondary)}.studio-tracks{display:flex;flex-direction:column;gap:0;background:var(--surface-sunken);border-radius:6px;overflow:hidden}.studio-track-row{display:grid;grid-template-columns:1fr 28px 28px 100px 36px;align-items:center;gap:.5rem;padding:0 .75rem;background:var(--surface-sunken);border-bottom:1px solid var(--border-warm)}.studio-track-row:last-child{border-bottom:none}.studio-track-row.is-take{background:color-mix(in srgb,var(--brand-default) 6%,var(--surface-sunken))}.studio-track-name{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary);min-width:0}.studio-track-name-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.studio-track-name .take-start{color:var(--text-muted);font-size:.8125rem;font-weight:400;white-space:nowrap}.studio-track-end{display:flex;align-items:center;justify-content:center;position:relative}.studio-track-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--c, currentColor)}.track-chip{width:26px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:var(--text-label);font-weight:var(--weight-medium);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--duration-micro) var(--ease-default),color var(--duration-micro) var(--ease-default),box-shadow var(--duration-micro) var(--ease-default)}.track-chip:hover{color:var(--text-primary);background:var(--surface-hover)}.track-chip-m.active{background:color-mix(in srgb,var(--brand-default) 12%,transparent);color:var(--brand-strong);border-color:var(--brand-default)}.track-chip-s.active{background:var(--brand-default);color:var(--surface-card);border-color:var(--brand-default)}.studio-track-row:has(.track-chip-m.active){opacity:.6}.track-vol{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;--track-fill-pct: 100%;background:linear-gradient(to right,var(--brand-default) 0%,var(--brand-default) var(--track-fill-pct),color-mix(in srgb,var(--ink-950) 8%,var(--surface-sunken)) var(--track-fill-pct),color-mix(in srgb,var(--ink-950) 8%,var(--surface-sunken)) 100%);background-repeat:no-repeat;background-position:center;background-size:100% 6px;border-radius:var(--radius-full);cursor:pointer;height:18px;accent-color:var(--brand-default)}.track-vol::-webkit-slider-runnable-track{height:6px;background:transparent;border-radius:var(--radius-full)}.track-vol::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:var(--radius-full);background:var(--brand-default);border:2px solid var(--surface-card);margin-top:-5px;box-shadow:0 0 0 1px color-mix(in srgb,var(--brand-strong) 35%,transparent),0 1px 4px color-mix(in srgb,var(--ink-950) 14%,transparent);transition:box-shadow var(--duration-micro) var(--ease-default),background var(--duration-micro) var(--ease-default),transform var(--duration-micro) var(--ease-default)}.track-vol:hover::-webkit-slider-thumb,.track-vol:focus::-webkit-slider-thumb{background:var(--brand-hover);box-shadow:var(--shadow-ring-warm),0 2px 8px color-mix(in srgb,var(--ink-950) 16%,transparent);transform:scale(1.04)}.track-vol::-moz-range-track{height:6px;background:transparent;border-radius:var(--radius-full);border:none}.track-vol::-moz-range-progress{height:6px;background:var(--brand-default);border-radius:var(--radius-full);border:none}.track-vol::-moz-range-thumb{width:16px;height:16px;border-radius:var(--radius-full);background:var(--brand-default);border:2px solid var(--surface-card);box-shadow:0 0 0 1px color-mix(in srgb,var(--brand-strong) 35%,transparent),0 1px 4px color-mix(in srgb,var(--ink-950) 14%,transparent);transition:box-shadow var(--duration-micro) var(--ease-default),background var(--duration-micro) var(--ease-default),transform var(--duration-micro) var(--ease-default)}.track-vol:hover::-moz-range-thumb,.track-vol:focus::-moz-range-thumb{background:var(--brand-hover);box-shadow:var(--shadow-ring-warm),0 2px 8px color-mix(in srgb,var(--ink-950) 16%,transparent);transform:scale(1.04)}.track-vol:focus-visible{outline:none}.track-vol:focus-visible::-webkit-slider-thumb{outline:2px solid var(--focus-ring);outline-offset:2px}.track-vol:focus-visible::-moz-range-thumb{outline:2px solid var(--focus-ring);outline-offset:2px}.track-tab-slot{position:relative;width:36px;display:flex;align-items:center;justify-content:center}.track-tab-badge{width:28px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:var(--text-label);font-weight:var(--weight-medium);font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;justify-content:center;transition:background var(--duration-micro) var(--ease-default),color var(--duration-micro) var(--ease-default)}.track-tab-badge:hover{background:var(--surface-hover);color:var(--text-primary)}.track-tab-badge.completed{background:transparent;color:var(--brand-default);border-color:var(--brand-default)}.track-tab-badge.completed:hover{background:color-mix(in srgb,var(--brand-default) 8%,transparent);color:var(--brand-strong)}.track-tab-badge.generating{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-warm)}.studio-waveform-wrap{background-color:var(--surface-sunken);background-image:url(/img/studio-empty-knowsound.svg);background-repeat:no-repeat;background-position:center;background-size:contain;border-radius:6px;position:relative;overflow:hidden}.studio-waveform-wrap canvas{display:block;width:100%;height:100%;background:transparent}.studio-transport{display:flex;gap:var(--space-xs);align-items:center;flex-wrap:wrap}.transport-play{width:44px;height:44px;border-radius:var(--radius-full);background:var(--brand-default);color:var(--text-inverse);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:background var(--duration-micro) var(--ease-default),box-shadow var(--duration-micro) var(--ease-default)}.transport-play:hover{background:var(--brand-hover)}.transport-play:active{box-shadow:var(--shadow-inset-press)}.transport-btn{background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:0 var(--space-sm);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-caption);font-weight:var(--weight-medium);color:var(--text-secondary);display:inline-flex;align-items:center;gap:var(--space-2xs);transition:background var(--duration-micro) var(--ease-default),color var(--duration-micro) var(--ease-default),box-shadow var(--duration-micro) var(--ease-default),border-color var(--duration-micro) var(--ease-default)}.transport-btn-secondary{height:32px;border-color:var(--border-subtle)}.transport-btn-secondary:hover{background:var(--surface-sunken);color:var(--text-primary)}.transport-btn-secondary.is-active{background:color-mix(in srgb,var(--brand-default) 12%,transparent);color:var(--brand-strong);border-color:var(--brand-default)}.transport-rec{height:32px;color:var(--status-error);border:1px solid var(--status-error);background:transparent}.transport-rec:hover{background:color-mix(in srgb,var(--status-error) 8%,transparent)}.transport-rec.is-recording{background:var(--status-error);color:var(--text-inverse);border-color:var(--status-error);animation:studio-rec-pulse 1s ease-in-out infinite}@keyframes studio-rec-pulse{0%,to{opacity:1}50%{opacity:.7}}.transport-time{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:var(--text-body-sm);letter-spacing:var(--tracking-code);color:var(--text-primary);padding:0 var(--space-xs)}.studio-analysis-panel{background:var(--surface-raised);border:1px solid var(--border-warm);border-radius:12px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;min-height:200px;overflow:hidden}.analysis-tabs-nav{display:flex;gap:var(--space-md);border-bottom:1px solid var(--border-subtle);padding:0 var(--space-2xs)}.analysis-tab-btn{background:transparent;border:none;padding:var(--space-xs) var(--space-2xs);margin-bottom:-1px;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;font-family:var(--font-sans);font-size:var(--text-caption);font-weight:var(--weight-regular);color:var(--text-muted);transition:color var(--duration-micro) var(--ease-default),border-color var(--duration-micro) var(--ease-default)}.analysis-tab-btn:hover{color:var(--text-secondary)}.analysis-tab-btn.is-active{background:transparent;color:var(--text-primary);font-weight:var(--weight-medium);border-bottom-color:var(--brand-default)}.analysis-tab-content{flex:1;min-height:0;overflow:hidden}.analysis-empty{color:var(--text-muted);font-size:.875rem;padding:.5rem}.analysis-chords,.analysis-sections{display:flex;flex-wrap:wrap;gap:.375rem}.chord-chip{background:var(--surface-sunken);border:1px solid var(--border-warm);border-radius:6px;padding:.25rem .625rem;font-size:.8rem;cursor:pointer}.analysis-lyrics{display:flex;flex-direction:column;gap:var(--space-3xs);padding:var(--space-2xs) 0;height:100%;overflow:auto}.lyric-line{margin:0;padding:var(--space-2xs) 0;cursor:pointer;font-family:var(--font-serif);font-size:var(--text-body);font-weight:var(--weight-regular);line-height:var(--leading-relaxed);color:var(--text-muted);transition:color var(--duration-micro) var(--ease-default)}.lyric-line:hover{color:var(--text-secondary)}.lyric-line.is-active{color:var(--brand-default)}.analysis-tab-view{overflow:auto;max-height:100%}.tab-select{margin-bottom:.5rem;padding:.25rem .5rem}.track-take-delete{background:transparent;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:.25rem .375rem;border-radius:4px;color:var(--text-muted)}.track-take-delete:hover{color:var(--status-danger, var(--terracotta-600));background:var(--surface-hover)}.alphatab-container{max-height:100%;overflow:auto}@media (min-width: 769px){.studio-mobile-only{display:none!important}}@media (max-width: 768px){.studio-desktop-only{display:none!important}.studio-main{grid-template-columns:1fr}.studio-sections-rail{max-height:180px}}.landing-page{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;background:var(--surface-page)}.landing-hero{max-width:640px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.landing-hero-logo{display:flex;align-items:baseline;justify-content:center;gap:.75rem}.landing-hero-logo-ko{font-family:"Noto Serif KR",serif;font-size:3rem;font-weight:800;letter-spacing:.04em;color:var(--brand-default)}.landing-hero-logo-han{font-size:1.25rem;color:var(--text-muted);font-weight:400}.landing-hero-tagline{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.4;margin:0}.landing-hero-desc{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin:0;max-width:520px}.landing-hero-cta{display:inline-block;padding:.875rem 2rem;background:var(--brand-default);color:var(--text-inverse);border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s var(--ease-default)}.landing-hero-cta:hover{background:var(--brand-hover);text-decoration:none}.landing-hero-cta:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.login-page{flex:1;display:flex;align-items:center;justify-content:center;background:var(--surface-page);padding:1.5rem}.login-card{background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:380px;display:flex;flex-direction:column;gap:1.5rem;box-shadow:var(--shadow-card-hover)}.login-logo{display:flex;align-items:baseline;gap:.625rem}.login-logo-ko{font-size:2rem;font-weight:800;letter-spacing:.04em;color:var(--brand-default)}.login-logo-han{font-size:1rem;color:var(--text-muted);font-weight:400}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.25rem}.login-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);letter-spacing:.03em}.login-input{padding:.625rem .875rem;border:1px solid var(--border-warm);border-radius:8px;background:var(--surface-raised);color:var(--text-primary);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s var(--ease-default)}.login-input:focus{border-color:var(--brand-default);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-default) 18%,transparent)}.login-input::placeholder{color:var(--text-muted)}.login-error{font-size:.8rem;color:var(--status-error);background:color-mix(in srgb,var(--status-error) 8%,transparent);border:1px solid color-mix(in srgb,var(--status-error) 20%,transparent);border-radius:6px;padding:.5rem .75rem;margin:0}.login-submit-btn{padding:.75rem;background:var(--brand-default);color:var(--text-inverse);border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s var(--ease-default)}.login-submit-btn:hover:not(:disabled){background:var(--brand-hover)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{font-size:.8rem;color:var(--text-muted);text-align:center}.login-footer a{color:var(--brand-default)}.guitar-play-page,.game-screen{--bg-deep: var(--game-bg-abyss);--bg-rg: var(--game-bg-night);--bg-card-rg: var(--game-bg-card);--bg-surface: var(--game-bg-dawn);--border-rg: var(--game-bg-mid);--border-glow: var(--game-bg-lift);--text-rg: var(--game-text-cool);--text-dim: var(--game-text-muted);--text-bright: var(--game-text-cold);--neon-gold: var(--neon-amber);--neon-blue: var(--neon-blue-deep);--neon-red: var(--neon-pink);--neon-purple: var(--neon-violet);font-family:Noto Sans KR,sans-serif;color:var(--text-rg)}.guitar-play-page .atmosphere{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 50% 60% at 10% 50%,color-mix(in srgb,var(--neon-magenta) 3%,transparent) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 90% 60%,color-mix(in srgb,var(--neon-blue-deep) 4%,transparent) 0%,transparent 70%)}.guitar-play-page .select-screen{max-width:580px;margin:0 auto;padding:32px 24px;position:relative;z-index:5;color:var(--text-primary)}.guitar-play-page .select-screen,.guitar-play-page .select-screen *{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,system-ui,sans-serif}.guitar-play-page:has(.select-screen:not([style*="display: none"])) .atmosphere{display:none}.gp-header{margin-bottom:20px}.gp-header h2{font-size:26px;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);margin:0 0 12px}.gp-header-row{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.gp-mic-pill{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-muted);padding:5px 12px 5px 8px;background:var(--surface-sunken);border-radius:20px;border:none;cursor:pointer;transition:background .12s,color .12s}.gp-mic-pill:hover{background:var(--overlay-hover-warm)}.gp-mic-pill.is-on{color:var(--text-secondary)}.gp-mic-dot{width:7px;height:7px;border-radius:50%;background:var(--ring-warm);transition:background .2s}.gp-mic-pill.is-on .gp-mic-dot{background:var(--status-success)}.gp-header-actions{display:flex;gap:4px}.gp-add-btn{font-size:13px;font-weight:500;color:var(--brand-default);background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:8px;transition:background .12s}.gp-add-btn:hover{background:var(--overlay-hover-soft)}.gp-adding-bar{padding:12px 16px;background:var(--surface-sunken);border-radius:10px;margin-bottom:12px}.gp-adding-text{font-size:12px;color:var(--text-secondary);margin-bottom:6px}.gp-adding-track{height:4px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.gp-adding-fill{height:100%;background:var(--brand-default);border-radius:2px;transition:width .3s}.gp-song-list{list-style:none;margin:0;padding:8px 0}.gp-song-item{display:flex;align-items:center;gap:14px;padding:14px 12px;border-radius:14px;cursor:pointer;transition:background .15s var(--ease-default);position:relative}.gp-song-item+.gp-song-item{border-top:1px solid color-mix(in srgb,var(--ink-950) 4%,transparent)}.gp-song-item:hover{background:var(--overlay-hover-soft)}.gp-song-item:hover+.gp-song-item{border-top-color:transparent}.gp-song-item.is-selected{background:var(--overlay-brand-soft)}.gp-song-item.is-selected+.gp-song-item{border-top-color:transparent}.gp-song-info{flex:1;min-width:0}.gp-song-title{font-size:15px;font-weight:550;color:var(--text-primary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gp-song-artist{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.gp-song-meta{display:flex;gap:6px;align-items:center}.gp-tag{font-size:11px;font-weight:550;padding:1px 7px;border-radius:5px}.gp-tag-bpm{background:color-mix(in srgb,var(--chart-blue) 10%,var(--surface-sunken));color:var(--chart-blue)}.gp-tag-easy{background:color-mix(in srgb,var(--status-success) 10%,var(--surface-sunken));color:var(--status-success)}.gp-tag-medium{background:color-mix(in srgb,var(--status-warning) 10%,var(--surface-sunken));color:var(--status-warning)}.gp-tag-hard{background:color-mix(in srgb,var(--status-error) 10%,var(--surface-sunken));color:var(--status-error)}.gp-tag-dur{color:var(--text-muted);font-weight:400}.gp-play-btn{width:40px;height:40px;border-radius:50%;background:var(--brand-default);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px color-mix(in srgb,var(--brand-default) 25%,transparent);transition:transform .15s,box-shadow .15s}.gp-play-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px color-mix(in srgb,var(--brand-default) 35%,transparent)}.gp-play-btn svg{width:16px;height:16px;margin-left:2px}.gp-chevron{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface-hover);color:var(--text-secondary);flex-shrink:0}.gp-delete-btn{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .12s,color .12s;position:absolute;right:4px;top:4px}.gp-delete-btn:hover{background:var(--overlay-hover-soft);color:var(--status-error)}.guitar-play-page .section-title{font-family:Oxanium,sans-serif;font-size:14px;font-weight:700;color:var(--text-dim);letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;display:flex;align-items:center;gap:12px}.guitar-play-page .section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border-rg),transparent)}.guitar-play-page .mic-bar{display:flex;align-items:center;gap:16px;padding:14px 20px;background:var(--bg-card-rg);border:1px solid var(--border-rg);border-radius:10px;margin-bottom:28px}.guitar-play-page .mic-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.guitar-play-page .mic-dot.active{background:var(--neon-green);box-shadow:0 0 8px var(--neon-green);animation:guitar-pulse 2s ease infinite}.guitar-play-page .mic-dot.inactive{background:var(--text-dim)}@keyframes guitar-pulse{0%,to{opacity:1}50%{opacity:.5}}.guitar-play-page .mic-label{font-size:13px;color:var(--text-dim);flex:1}.guitar-play-page .mic-level{width:120px;height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}.guitar-play-page .mic-level-fill{height:100%;background:linear-gradient(90deg,var(--neon-green),var(--neon-cyan));border-radius:3px;transition:width .08s}.guitar-play-page .btn-mic{font-family:Oxanium,sans-serif;font-size:12px;font-weight:600;padding:6px 14px;border-radius:5px;border:1px solid color-mix(in srgb,var(--neon-green) 30%,transparent);background:color-mix(in srgb,var(--neon-green) 8%,transparent);color:var(--neon-green);cursor:pointer}.guitar-play-page .song-grid{display:grid;gap:12px}.guitar-play-page .song-card{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:18px;padding:16px 20px;background:var(--bg-card-rg);border:1px solid var(--border-rg);border-radius:10px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}.guitar-play-page .song-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .3s;background:linear-gradient(135deg,color-mix(in srgb,var(--neon-cyan) 4%,transparent),color-mix(in srgb,var(--neon-magenta) 3%,transparent));pointer-events:none}.guitar-play-page .song-card:hover{border-color:var(--border-glow);transform:translateY(-1px)}.guitar-play-page .song-card:hover:before{opacity:1}.guitar-play-page .song-card.selected{border-color:var(--neon-cyan);box-shadow:0 0 20px color-mix(in srgb,var(--neon-cyan) 8%,transparent)}.guitar-play-page .song-art{width:56px;height:56px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;position:relative;z-index:1}.guitar-play-page .song-info{position:relative;z-index:1}.guitar-play-page .song-title{font-family:Oxanium,sans-serif;font-size:15px;font-weight:700;color:var(--text-bright);margin-bottom:4px}.guitar-play-page .song-artist{font-size:12px;color:var(--text-dim);margin-bottom:6px}.guitar-play-page .song-meta{display:flex;gap:12px}.guitar-play-page .song-tag{font-family:Oxanium,sans-serif;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.guitar-play-page .tag-bpm{background:color-mix(in srgb,var(--neon-blue-deep) 12%,transparent);color:var(--neon-blue)}.guitar-play-page .tag-easy{background:color-mix(in srgb,var(--neon-green) 10%,transparent);color:var(--neon-green)}.guitar-play-page .tag-medium{background:color-mix(in srgb,var(--neon-orange) 10%,transparent);color:var(--neon-orange)}.guitar-play-page .tag-hard{background:color-mix(in srgb,var(--neon-pink) 10%,transparent);color:var(--neon-red)}.guitar-play-page .tag-duration{background:color-mix(in srgb,var(--game-text-muted) 15%,transparent);color:var(--text-dim)}.guitar-play-page .btn-play{font-family:Oxanium,sans-serif;font-size:13px;font-weight:700;padding:10px 24px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--neon-cyan),var(--neon-blue));color:var(--bg-deep);cursor:pointer;transition:all .2s;letter-spacing:1px;text-transform:uppercase}.guitar-play-page .btn-play:hover{box-shadow:0 0 24px color-mix(in srgb,var(--neon-cyan) 35%,transparent);transform:scale(1.03)}.game-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:var(--ink-950);display:flex;flex-direction:column}.game-screen .game-hud{display:flex;align-items:center;justify-content:space-between;padding:10px 28px;background:color-mix(in srgb,var(--ink-950) 85%,transparent);border-bottom:1px solid color-mix(in srgb,var(--game-bg-mid) 40%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.game-screen .hud-left{display:flex;align-items:center;gap:16px}.game-screen .hud-song{font-family:Oxanium,sans-serif;font-size:14px;font-weight:600;color:var(--text-rg)}.game-screen .hud-progress{width:180px;height:3px;background:color-mix(in srgb,var(--text-inverse) 10%,transparent);border-radius:2px;overflow:hidden}.game-screen .hud-progress-fill{height:100%;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-magenta));border-radius:2px;transition:width .3s linear}.game-screen .hud-center{display:flex;align-items:baseline;gap:8px}.game-screen .hud-score{font-family:Oxanium,sans-serif;font-size:32px;font-weight:800;color:var(--text-bright);letter-spacing:2px;min-width:160px;text-align:center}.game-screen .hud-combo{font-family:Oxanium,sans-serif;font-size:16px;font-weight:700;color:var(--neon-gold);text-shadow:0 0 10px color-mix(in srgb,var(--neon-amber) 50%,transparent);opacity:0;transform:scale(.8);transition:all .2s}.game-screen .hud-combo.visible{opacity:1;transform:scale(1)}.game-screen .btn-pause{font-family:Oxanium,sans-serif;font-size:12px;padding:6px 14px;border-radius:5px;border:1px solid color-mix(in srgb,var(--text-inverse) 15%,transparent);background:color-mix(in srgb,var(--text-inverse) 5%,transparent);color:color-mix(in srgb,var(--text-inverse) 50%,transparent);cursor:pointer}.game-screen .game-canvas-wrap{flex:1;position:relative;overflow:hidden}.game-screen .game-canvas-wrap canvas{display:block;width:100%;height:100%}.game-screen .judgment-display{position:absolute;left:50%;top:35%;transform:translate(-50%,-50%);pointer-events:none;z-index:20}.game-screen .judgment-text{font-family:Oxanium,sans-serif;font-size:44px;font-weight:800;letter-spacing:6px;text-transform:uppercase;opacity:0}.game-screen .judgment-text.show{animation:guitar-judgment-pop .55s cubic-bezier(.16,1,.3,1) forwards}.game-screen .judgment-text.perfect{color:var(--neon-gold);text-shadow:0 0 40px color-mix(in srgb,var(--neon-amber) 80%,transparent),0 2px 20px color-mix(in srgb,var(--ink-950) 50%,transparent)}.game-screen .judgment-text.great{color:var(--neon-green);text-shadow:0 0 30px color-mix(in srgb,var(--neon-green) 70%,transparent),0 2px 20px color-mix(in srgb,var(--ink-950) 50%,transparent)}.game-screen .judgment-text.good{color:var(--neon-blue);text-shadow:0 0 24px color-mix(in srgb,var(--neon-blue-deep) 60%,transparent),0 2px 20px color-mix(in srgb,var(--ink-950) 50%,transparent)}.game-screen .judgment-text.miss{color:var(--neon-red);text-shadow:0 0 24px color-mix(in srgb,var(--neon-pink) 60%,transparent),0 2px 20px color-mix(in srgb,var(--ink-950) 50%,transparent)}@keyframes guitar-judgment-pop{0%{opacity:0;transform:translateY(30px) scale(.6)}15%{opacity:1;transform:translateY(-10px) scale(1.15)}30%{transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-40px) scale(.85)}}.game-screen .countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:50;background:color-mix(in srgb,var(--ink-950) 75%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.game-screen .countdown-number{font-family:Oxanium,sans-serif;font-size:140px;font-weight:800;color:var(--neon-cyan);text-shadow:0 0 80px color-mix(in srgb,var(--neon-cyan) 60%,transparent);animation:guitar-countdown-pop .9s ease-out forwards}@keyframes guitar-countdown-pop{0%{opacity:0;transform:scale(2.5)}25%{opacity:1;transform:scale(.9)}50%{transform:scale(1)}to{opacity:0;transform:scale(.7)}}.guitar-play-page .results-screen{max-width:640px;margin:0 auto;padding:48px 24px;position:relative;z-index:5}.guitar-play-page .results-grade{text-align:center;margin-bottom:40px}.guitar-play-page .grade-letter{font-family:Oxanium,sans-serif;font-size:96px;font-weight:800;line-height:1;margin-bottom:8px}.guitar-play-page .grade-S{color:var(--neon-gold);text-shadow:0 0 40px color-mix(in srgb,var(--neon-amber) 50%,transparent)}.guitar-play-page .grade-A{color:var(--neon-green);text-shadow:0 0 40px color-mix(in srgb,var(--neon-green) 40%,transparent)}.guitar-play-page .grade-B{color:var(--neon-cyan);text-shadow:0 0 30px color-mix(in srgb,var(--neon-cyan) 40%,transparent)}.guitar-play-page .grade-C{color:var(--neon-orange);text-shadow:0 0 30px color-mix(in srgb,var(--neon-orange) 40%,transparent)}.guitar-play-page .grade-score{font-family:Oxanium,sans-serif;font-size:42px;font-weight:700;color:var(--text-bright);letter-spacing:3px}.guitar-play-page .grade-pct{font-size:16px;color:var(--text-dim);margin-top:6px}.guitar-play-page .judgment-bars{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}.guitar-play-page .jbar-row{display:grid;grid-template-columns:80px 1fr 48px;align-items:center;gap:14px}.guitar-play-page .jbar-label{font-family:Oxanium,sans-serif;font-size:13px;font-weight:700;letter-spacing:1px;text-align:right}.guitar-play-page .jbar-track{height:22px;background:var(--bg-surface);border-radius:4px;overflow:hidden}.guitar-play-page .jbar-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.16,1,.3,1)}.guitar-play-page .jbar-count{font-family:Oxanium,sans-serif;font-size:14px;font-weight:600;color:var(--text-rg);text-align:right}.guitar-play-page .stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:32px}.guitar-play-page .stat-box{background:var(--bg-card-rg);border:1px solid var(--border-rg);border-radius:10px;padding:18px 14px;text-align:center}.guitar-play-page .stat-value{font-family:Oxanium,sans-serif;font-size:26px;font-weight:700;color:var(--text-bright);margin-bottom:4px}.guitar-play-page .stat-label{font-size:11px;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase}.guitar-play-page .results-actions{display:flex;gap:12px;justify-content:center}.guitar-play-page .btn-result{font-family:Oxanium,sans-serif;font-size:14px;font-weight:700;padding:12px 32px;border-radius:8px;cursor:pointer;transition:all .2s;letter-spacing:1px}.guitar-play-page .btn-retry{border:none;background:linear-gradient(135deg,var(--neon-cyan),var(--neon-blue));color:var(--bg-deep)}.guitar-play-page .btn-retry:hover{box-shadow:0 0 24px color-mix(in srgb,var(--neon-cyan) 35%,transparent)}.guitar-play-page .btn-back{border:1px solid var(--border-rg);background:transparent;color:var(--text-dim)}.guitar-play-page .btn-back:hover{border-color:var(--text-dim);color:var(--text-rg)}.guitar-play-page .calibrate-screen{max-width:640px;margin:0 auto;padding:48px 24px;position:relative;z-index:5}.guitar-play-page .cal-beats{display:flex;gap:10px;justify-content:center;margin:24px 0}.guitar-play-page .cal-beat{width:32px;height:32px;border-radius:50%;background:var(--bg-surface);border:2px solid var(--border-rg);transition:all .2s}.guitar-play-page .cal-beat.hit{background:var(--neon-cyan);border-color:var(--neon-cyan);box-shadow:0 0 12px color-mix(in srgb,var(--neon-cyan) 50%,transparent)}.guitar-play-page .cal-beat.current{border-color:var(--neon-gold);box-shadow:0 0 12px color-mix(in srgb,var(--neon-amber) 40%,transparent)}.guitar-play-page .btn-calibrate{font-family:Oxanium,sans-serif;font-size:13px;font-weight:700;padding:10px 24px;border-radius:8px;border:1px solid color-mix(in srgb,var(--neon-cyan) 30%,transparent);background:color-mix(in srgb,var(--neon-cyan) 8%,transparent);color:var(--neon-cyan);cursor:pointer;transition:all .2s;letter-spacing:1px}.guitar-play-page .btn-calibrate:hover{background:color-mix(in srgb,var(--neon-cyan) 15%,transparent);box-shadow:0 0 16px color-mix(in srgb,var(--neon-cyan) 20%,transparent)}.guitar-play-page .fade-in{animation:guitar-fade-in .5s ease forwards}@keyframes guitar-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.guitar-play-page .stagger-1{animation-delay:.05s}.guitar-play-page .stagger-2{animation-delay:.1s}.guitar-play-page .stagger-3{animation-delay:.15s}.guitar-play-page .stagger-4{animation-delay:.2s}.guitar-play-page .stagger-5{animation-delay:.25s}.guitar-play-page [x-cloak]{display:none!important}@media (max-width: 768px){.guitar-play-page .select-screen{padding:20px 12px}.guitar-play-page .mic-bar{flex-wrap:wrap;gap:10px;padding:12px 14px}.guitar-play-page .mic-level{width:100%}.guitar-play-page .song-card{grid-template-columns:44px 1fr;gap:12px;padding:14px}.guitar-play-page .song-card .song-actions{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:8px}.guitar-play-page .song-art{width:44px;height:44px;font-size:20px}.guitar-play-page .song-meta{flex-wrap:wrap;gap:6px}.guitar-play-page .results-screen{padding:28px 16px}.guitar-play-page .stats-grid{grid-template-columns:1fr 1fr}.guitar-play-page .grade-letter{font-size:72px}.guitar-play-page .grade-score{font-size:32px}.song-header{flex-wrap:wrap;gap:8px}}.tuner-page{min-height:calc(100vh - 77px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px 48px}.tuner-surface{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:0}.tuner-picker{position:relative;margin-bottom:28px}.tuner-trigger{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:4px 2px;font-size:15px;font-weight:500;color:var(--brand-default);cursor:pointer;font-family:inherit;line-height:1}.tuner-trigger:hover{color:var(--brand-strong)}.tuner-trigger-chevron{transition:transform .2s ease}.tuner-trigger-chevron.open{transform:rotate(180deg)}.tuner-popover{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:260px;background:var(--surface-primary);border-radius:14px;box-shadow:0 4px 24px #0000001f;padding:6px;z-index:50;transform-origin:top center}.tuner-popover-enter{transition:opacity .15s ease-out,transform .15s ease-out}.tuner-popover-enter-start{opacity:0;transform:translate(-50%) scale(.95)}.tuner-popover-enter-end{opacity:1;transform:translate(-50%) scale(1)}.tuner-popover-leave{transition:opacity .1s ease-in,transform .1s ease-in}.tuner-popover-leave-start{opacity:1;transform:translate(-50%) scale(1)}.tuner-popover-leave-end{opacity:0;transform:translate(-50%) scale(.95)}.tuner-option{display:flex;align-items:center;width:100%;padding:10px 14px;border:none;border-radius:10px;background:none;cursor:pointer;font-family:inherit;font-size:15px;color:var(--text-primary);gap:8px;text-align:left}.tuner-option:hover{background:var(--surface-hover)}.tuner-option.selected{background:var(--surface-hover);font-weight:500}.tuner-option-label{flex:1}.tuner-option-notes{font-family:SF Mono,Menlo,ui-monospace,monospace;font-size:12px;color:var(--text-muted);flex-shrink:0}.tuner-option-check{color:var(--brand-default);flex-shrink:0;width:14px;height:14px}.tuner-popover-divider{height:1px;background:var(--border-subtle);margin:4px 8px}.tuner-strings{display:flex;gap:8px;justify-content:center;margin-bottom:32px}.tuner-string-dot{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;font-size:14px;font-weight:600;border:none;cursor:default;padding:0;transition:background .3s,color .3s,box-shadow .3s}.tuner-string-dot.inactive{background:var(--surface-hover);color:var(--text-muted)}.tuner-string-dot.active{background:var(--overlay-brand-mid);color:var(--brand-strong);box-shadow:0 0 0 2px var(--brand-default)}.tuner-string-dot.completed{background:color-mix(in srgb,var(--status-success) 12%,transparent);color:var(--status-success)}.tuner-string-label{line-height:1}.tuner-check{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:var(--status-success);color:var(--text-inverse);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;animation:tuner-check-pop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes tuner-check-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.tuner-gauge{position:relative;width:240px;height:240px;margin-bottom:32px}@media (min-height: 700px){.tuner-gauge{width:280px;height:280px}}.tuner-gauge-svg{width:100%;height:100%;overflow:visible}.tuner-gauge-bg{stroke:var(--cream-300)}.tuner-gauge-arc{transition:stroke-dashoffset .25s cubic-bezier(.4,0,.2,1),stroke .25s}.tuner-gauge-inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;pointer-events:none}.tuner-gauge-note{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,system-ui,sans-serif;font-size:56px;font-weight:300;line-height:1;color:var(--cream-400);transition:color .25s,font-weight .25s,transform .25s;letter-spacing:-1px}.tuner-gauge-note.has-note{font-weight:500;transform:scale(1)}.tuner-gauge-sub{font-family:SF Mono,Menlo,ui-monospace,monospace;font-size:12px;font-weight:400;color:var(--text-muted);font-variant-numeric:tabular-nums;margin-top:4px}.tuner-gauge-cents{font-family:SF Mono,Menlo,ui-monospace,monospace;font-size:13px;font-weight:500;font-variant-numeric:tabular-nums;margin-top:2px}.tuner-gauge-hint{font-size:14px;font-weight:400;color:var(--text-muted)}.tuner-gauge.in-tune-glow .tuner-gauge-arc{filter:drop-shadow(0 0 6px currentColor);transition:filter .4s}.tuner-all-done{text-align:center;font-size:17px;font-weight:600;color:var(--status-success);letter-spacing:.5px;margin-bottom:24px;animation:tuner-done-in .5s cubic-bezier(.34,1.56,.64,1)}@keyframes tuner-done-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.tuner-controls{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}.tuner-level-wrap{width:240px}.tuner-level-track{width:100%;height:3px;background:var(--surface-hover);border-radius:2px;overflow:hidden}.tuner-level-fill{height:100%;background:var(--brand-default);border-radius:2px;transition:width .08s linear}.tuner-actions{display:flex;align-items:center;gap:12px}.tuner-mic-btn{display:flex;align-items:center;gap:8px;padding:10px 24px;border-radius:24px;border:none;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s;background:var(--surface-hover);color:var(--text-primary)}.tuner-mic-btn:hover{background:var(--cream-400)}.tuner-mic-btn.active{background:var(--brand-default);color:var(--text-inverse)}.tuner-mic-btn.active:hover{background:var(--brand-strong)}.tuner-mic-icon{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .2s,box-shadow .2s}.tuner-mic-icon.off{background:var(--text-muted)}.tuner-mic-icon.on{background:var(--text-inverse);box-shadow:0 0 0 3px color-mix(in srgb,var(--text-inverse) 30%,transparent)}.tuner-reset-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--surface-hover);color:var(--text-muted);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.tuner-reset-btn:hover{background:var(--cream-400);color:var(--text-primary)}.song-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.btn-add-song{background:var(--neon-purple, var(--neon-purple));color:var(--text-inverse);border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.btn-add-song:hover{background:var(--neon-purple-deep)}.adding-song-bar{background:color-mix(in srgb,var(--neon-purple) 10%,transparent);border:1px solid var(--neon-purple, var(--neon-purple));border-radius:8px;padding:12px 16px;margin-bottom:16px}.adding-song-text{color:var(--text-dim, var(--silver-500));font-size:.85rem;margin-bottom:6px}.adding-song-progress{height:4px;background:color-mix(in srgb,var(--text-inverse) 10%,transparent);border-radius:2px;overflow:hidden}.adding-song-fill{height:100%;background:var(--neon-purple, var(--neon-purple));transition:width .3s}.song-source{color:var(--text-dim, var(--stone-500));font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.btn-delete-song{background:none;border:none;color:var(--neon-red, var(--neon-pink));cursor:pointer;font-size:1rem;padding:4px 8px;opacity:.5;transition:opacity .2s}.btn-delete-song:hover{opacity:1}.file-browser-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--ink-950) 70%,transparent);display:flex;align-items:center;justify-content:center;z-index:1000}.file-browser-content{background:var(--game-bg-deep);border:1px solid color-mix(in srgb,var(--neon-purple) 30%,transparent);border-radius:12px;width:90%;max-width:500px;max-height:70vh;display:flex;flex-direction:column}.file-browser-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid color-mix(in srgb,var(--text-inverse) 10%,transparent)}.file-browser-header h3{margin:0;color:var(--text-inverse);font-size:1rem}.btn-close{background:none;border:none;color:var(--text-dim, var(--stone-500));cursor:pointer;font-size:1.2rem}.file-browser-path{padding:8px 20px;color:var(--text-dim, var(--stone-500));font-size:.8rem;font-family:monospace;border-bottom:1px solid color-mix(in srgb,var(--text-inverse) 5%,transparent)}.file-browser-list{overflow-y:auto;flex:1;padding:8px}.file-entry{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;cursor:pointer;color:var(--cream-500);font-size:.9rem;transition:background .15s}.file-entry:hover{background:color-mix(in srgb,var(--neon-purple) 15%,transparent)}.file-entry.dir{color:var(--neon-blue, var(--neon-blue-mid))}.file-icon{font-size:1.1rem}.hud-volume{display:flex;align-items:center;gap:6px;margin-right:12px}.hud-volume-label{color:var(--text-dim, var(--stone-500));font-size:.7rem;white-space:nowrap}.hud-volume-slider{width:60px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:color-mix(in srgb,var(--text-inverse) 20%,transparent);border-radius:2px;outline:none}.hud-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--neon-purple, var(--neon-purple));cursor:pointer}body.page-dark{background:var(--color-ink, var(--text-primary))}body.page-dark .container{color:var(--color-silver, var(--silver-500));font-family:var(--font-sans, "Noto Sans KR", sans-serif)}body.page-dark .guitar-play-page .atmosphere{background:radial-gradient(ellipse 60% 70% at 15% 40%,color-mix(in srgb,var(--brand-default) 4%,transparent) 0%,transparent 70%),radial-gradient(ellipse 50% 50% at 85% 70%,color-mix(in srgb,var(--brand-hover) 2%,transparent) 0%,transparent 70%)}body.page-dark .guitar-play-page:not(:has(.tuner-screen)) .atmosphere,body.page-dark .select-screen~.atmosphere{background:radial-gradient(ellipse 60% 70% at 15% 30%,color-mix(in srgb,var(--brand-default) 4%,transparent) 0%,transparent 70%),radial-gradient(ellipse 55% 55% at 85% 75%,color-mix(in srgb,var(--brand-hover) 3%,transparent) 0%,transparent 70%)}.guitar-play-page .select-screen{max-width:1080px;padding:72px 24px 96px}.guitar-play-page .select-screen .section-title{font-family:var(--font-sans, "Noto Sans KR", sans-serif);font-size:.63rem;font-weight:500;color:var(--color-stone, var(--text-muted));letter-spacing:.5px;text-transform:uppercase}.guitar-play-page .select-screen .section-title:after{background:linear-gradient(90deg,var(--ink-700),transparent)}.song-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.song-header .section-title{margin-bottom:0;flex:1}.btn-add-song{font-family:var(--font-sans, sans-serif);font-size:.82rem;font-weight:500;padding:8px 14px;border-radius:var(--radius-sm, 8px);background:var(--color-dark, var(--ink-800));color:var(--color-silver, var(--silver-500));border:1px solid var(--ink-700);cursor:pointer;transition:all .15s}.btn-add-song:hover{color:var(--color-brand-coral, var(--brand-hover));border-color:var(--color-brand-coral, var(--brand-hover))}.adding-song-bar{background:var(--color-dark, var(--ink-800));border:1px solid var(--ink-700);border-radius:var(--radius-md, 12px);padding:14px 18px;margin-bottom:20px}.adding-song-text{font-size:.88rem;color:var(--color-silver, var(--silver-500));margin-bottom:10px}.adding-song-progress{height:4px;background:var(--ink-700);border-radius:999px;overflow:hidden}.adding-song-fill{height:100%;background:var(--color-brand, var(--brand-default));transition:width .3s ease-out}.select-screen .mic-bar{background:var(--color-dark, var(--ink-800));border:1px solid var(--ink-700);border-radius:var(--radius-md, 12px);padding:14px 18px;margin-bottom:28px}.select-screen .mic-bar .mic-dot.active{background:var(--color-brand-coral, var(--brand-hover));box-shadow:0 0 0 4px color-mix(in srgb,var(--brand-hover) 25%,transparent)}.select-screen .mic-bar .mic-dot.inactive{background:var(--ink-700)}.select-screen .mic-bar .mic-label{color:var(--color-silver, var(--silver-500));font-size:.82rem;font-weight:500}.select-screen .mic-bar .mic-level{background:var(--ink-700)}.select-screen .mic-bar .mic-level-fill{background:var(--color-brand, var(--brand-default))}.select-screen .mic-bar .btn-mic{background:var(--color-brand, var(--brand-default));color:var(--color-ivory, var(--surface-card));border:none;font-size:.82rem;font-weight:500;padding:8px 14px;border-radius:var(--radius-sm, 8px);cursor:pointer;transition:background .15s}.select-screen .mic-bar .btn-mic:hover{background:var(--brand-strong)}.guitar-play-page .song-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.guitar-play-page .song-card{background:var(--color-dark, var(--ink-800));border:1px solid var(--ink-700);border-radius:var(--radius-lg, 16px);padding:20px;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex;gap:16px;align-items:flex-start}.guitar-play-page .song-card:before{display:none}.guitar-play-page .song-card:hover{transform:translateY(-2px);border-color:var(--color-brand-coral, var(--brand-hover));box-shadow:0 4px 24px color-mix(in srgb,var(--ink-950) 30%,transparent)}.guitar-play-page .song-card.selected{border-color:var(--color-brand, var(--brand-default));box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-default) 25%,transparent)}.guitar-play-page .song-art{width:64px;height:64px;border-radius:var(--radius-sm, 8px);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.8rem}.guitar-play-page .song-info{flex:1;min-width:0}.guitar-play-page .song-title{font-family:var(--font-serif, "Noto Serif KR", Georgia, serif);font-size:1.15rem;font-weight:500;color:var(--color-ivory, var(--surface-card));line-height:1.25;margin-bottom:4px;letter-spacing:-.01em}.guitar-play-page .song-artist{font-family:var(--font-sans, sans-serif);font-size:.82rem;color:var(--color-silver, var(--silver-500));margin-bottom:12px}.guitar-play-page .song-meta{display:flex;gap:6px;flex-wrap:wrap}.guitar-play-page .song-tag{font-family:var(--font-sans, sans-serif);font-size:.7rem;font-weight:500;padding:2px 8px;border-radius:999px;letter-spacing:.02em}.guitar-play-page .tag-bpm{background:color-mix(in srgb,var(--silver-500) 12%,transparent);color:var(--color-silver, var(--silver-500))}.guitar-play-page .tag-easy{background:color-mix(in srgb,var(--brand-hover) 15%,transparent);color:var(--color-brand-coral, var(--brand-hover))}.guitar-play-page .tag-medium{background:color-mix(in srgb,var(--brand-default) 18%,transparent);color:var(--color-brand, var(--brand-default))}.guitar-play-page .tag-hard{background:color-mix(in srgb,var(--status-error) 18%,transparent);color:var(--color-error, var(--status-error))}.guitar-play-page .tag-duration{background:color-mix(in srgb,var(--text-muted) 15%,transparent);color:var(--color-stone, var(--text-muted))}.guitar-play-page .song-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.guitar-play-page .song-source{font-size:.63rem;color:var(--color-stone, var(--text-muted));text-transform:uppercase;letter-spacing:.5px}.guitar-play-page .btn-play{font-family:var(--font-sans, sans-serif);font-size:.82rem;font-weight:600;padding:8px 16px;background:var(--color-brand, var(--brand-default));color:var(--color-ivory, var(--surface-card));border:none;border-radius:var(--radius-sm, 8px);cursor:pointer;letter-spacing:.05em;transition:background .15s}.guitar-play-page .btn-play:hover:not(:disabled){background:var(--brand-strong)}.guitar-play-page .btn-play:disabled{background:var(--ink-700);color:var(--color-stone, var(--text-muted));cursor:not-allowed}.btn-delete-song{background:transparent;border:1px solid var(--ink-700);color:var(--color-stone, var(--text-muted));width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:.75rem}.btn-delete-song:hover{color:var(--color-error, var(--status-error));border-color:var(--color-error, var(--status-error))}.guitar-play-page .calibrate-screen{max-width:560px;margin:0 auto;padding:72px 24px;text-align:center}.guitar-play-page .calibrate-screen .section-title{justify-content:center;margin-bottom:16px}.guitar-play-page .calibrate-screen p{color:var(--color-silver, var(--silver-500))!important;font-family:var(--font-sans, sans-serif);line-height:1.6}.guitar-play-page .cal-beats{display:flex;gap:10px;justify-content:center;margin:32px 0}.guitar-play-page .cal-beat{width:42px;height:42px;border-radius:50%;background:var(--color-dark, var(--ink-800));border:1px solid var(--ink-700);transition:all .15s}.guitar-play-page .cal-beat.current{border-color:var(--color-brand, var(--brand-default));box-shadow:0 0 0 4px color-mix(in srgb,var(--brand-default) 20%,transparent)}.guitar-play-page .cal-beat.hit{background:var(--color-brand-coral, var(--brand-hover));border-color:var(--color-brand-coral, var(--brand-hover))}.btn-calibrate{font-family:var(--font-sans, sans-serif);font-size:.94rem;font-weight:500;padding:12px 28px;background:var(--color-brand, var(--brand-default));color:var(--color-ivory, var(--surface-card));border:none;border-radius:var(--radius-md, 12px);cursor:pointer;transition:background .15s}.btn-calibrate:hover:not(:disabled){background:var(--brand-strong)}.btn-calibrate:disabled{background:var(--ink-700);color:var(--color-stone, var(--text-muted));cursor:not-allowed}.guitar-play-page .results-screen{max-width:680px;margin:0 auto;padding:72px 24px 96px}.guitar-play-page .results-grade{text-align:center;margin-bottom:56px}.guitar-play-page .grade-letter{font-family:var(--font-serif, "Noto Serif KR", Georgia, serif);font-size:8rem;font-weight:500;line-height:1;letter-spacing:-.04em;text-shadow:none!important;display:block;margin-bottom:8px}.guitar-play-page .grade-S{color:var(--neon-gold)}.guitar-play-page .grade-A{color:var(--color-brand-coral, var(--brand-hover))}.guitar-play-page .grade-B{color:var(--color-brand, var(--brand-default))}.guitar-play-page .grade-C{color:var(--game-warmwood)}.guitar-play-page .grade-score{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:1.75rem;color:var(--color-ivory, var(--surface-card));letter-spacing:.08em}.guitar-play-page .grade-pct{font-family:var(--font-sans, sans-serif);font-size:.94rem;color:var(--color-silver, var(--silver-500));margin-top:4px}.guitar-play-page .results-screen .section-title{margin:24px 0 16px}.guitar-play-page .judgment-bars{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.guitar-play-page .jbar-row{display:flex;align-items:center;gap:14px}.guitar-play-page .jbar-label{font-family:var(--font-sans, sans-serif);font-size:.75rem;font-weight:600;width:70px;letter-spacing:.08em}.guitar-play-page .jbar-track{flex:1;height:8px;background:var(--color-dark, var(--ink-800));border-radius:999px;overflow:hidden}.guitar-play-page .jbar-fill{height:100%;transition:width .6s ease-out;border-radius:999px}.guitar-play-page .jbar-count{font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--color-silver, var(--silver-500));width:40px;text-align:right}.guitar-play-page .stats-grid{grid-template-columns:repeat(3,1fr);gap:12px}.guitar-play-page .stat-box{background:var(--color-dark, var(--ink-800));border:1px solid var(--ink-700);border-radius:var(--radius-md, 12px);padding:20px 16px;text-align:center}.guitar-play-page .stat-value{font-family:var(--font-serif, "Noto Serif KR", Georgia, serif);font-size:1.75rem;font-weight:500;color:var(--color-ivory, var(--surface-card));line-height:1;margin-bottom:6px}.guitar-play-page .stat-label{font-family:var(--font-sans, sans-serif);font-size:.63rem;color:var(--color-stone, var(--text-muted));text-transform:uppercase;letter-spacing:.5px}.guitar-play-page .results-actions{display:flex;justify-content:center;gap:12px;margin-top:32px}.guitar-play-page .btn-result{font-family:var(--font-sans, sans-serif);font-size:.94rem;font-weight:500;padding:10px 24px;border-radius:var(--radius-md, 12px);border:1px solid transparent;cursor:pointer;transition:all .15s}.guitar-play-page .btn-retry{background:var(--color-brand, var(--brand-default));color:var(--color-ivory, var(--surface-card))}.guitar-play-page .btn-retry:hover{background:var(--brand-strong)}.guitar-play-page .btn-back{background:var(--color-dark, var(--ink-800));color:var(--color-silver, var(--silver-500));border-color:var(--ink-700)}.guitar-play-page .btn-back:hover{color:var(--color-ivory, var(--surface-card));border-color:var(--color-silver, var(--silver-500))}.guitar-play-page,.game-screen{--neon-gold: var(--neon-gold);--neon-green: var(--brand-hover);--neon-blue: var(--brand-default);--neon-red: var(--status-error);--neon-cyan: var(--silver-500);--neon-magenta: var(--brand-hover);--neon-orange: var(--brand-default);--neon-purple: var(--game-warmwood)}.admin-layout{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 2rem 3rem}.admin-header{display:flex;flex-direction:column;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.admin-title{font-family:"Noto Serif KR",serif;font-size:1.75rem;font-weight:700;margin:0;color:var(--text-primary)}.admin-nav{display:flex;gap:1.25rem;flex-wrap:wrap}.admin-nav-link{font-size:.95rem;padding:.375rem .75rem;border-radius:6px;color:var(--text-secondary);text-decoration:none;transition:background-color .12s var(--ease-default),color .12s var(--ease-default)}.admin-nav-link:hover{background-color:var(--overlay-hover-soft);color:var(--text-primary)}.admin-nav-link-active{background-color:var(--overlay-brand-soft);color:var(--brand-default);font-weight:600}.admin-content{display:flex;flex-direction:column;gap:1.5rem}.admin-dashboard{display:flex;flex-direction:column;gap:1.25rem}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.admin-stat-card{display:flex;flex-direction:column;gap:.375rem;padding:1.25rem;border-radius:12px;background-color:var(--surface-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);color:var(--text-primary);text-decoration:none;transition:box-shadow .16s var(--ease-default),transform .16s var(--ease-default)}.admin-stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px);text-decoration:none}.admin-stat-label{margin:0;font-size:.85rem;color:var(--text-muted)}.admin-stat-value{margin:0;font-size:2rem;font-weight:700;color:var(--text-primary)}.admin-stat-meta{margin:0;font-size:.8rem;color:var(--text-subtle)}.admin-dashboard-hint{margin:0;color:var(--text-muted);font-size:.9rem}.admin-panel{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background-color:var(--surface-card);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow-card)}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.admin-panel-title{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.admin-panel-meta{margin:0;font-size:.85rem;color:var(--text-muted)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table thead th{text-align:left;padding:.6rem .75rem;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);background-color:var(--surface-sunken)}.admin-table tbody tr{border-bottom:1px solid var(--border-subtle)}.admin-table tbody tr:hover{background-color:var(--overlay-hover-soft)}.admin-table-row[data-used=true]{opacity:.7}.admin-table-cell{padding:.625rem .75rem;color:var(--text-primary);vertical-align:middle}.admin-table-cell-id{color:var(--text-muted);font-variant-numeric:tabular-nums}.admin-table-cell-code code{font-family:JetBrains Mono,SF Mono,Consolas,monospace;font-size:.85rem;background-color:var(--surface-sunken);padding:.125rem .375rem;border-radius:4px;color:var(--text-primary)}.admin-table-cell-actions{text-align:right;white-space:nowrap;display:flex;gap:.5rem;justify-content:flex-end}.admin-empty{padding:1.5rem;text-align:center;color:var(--text-muted);background-color:var(--surface-sunken);border-radius:8px;font-size:.9rem}.admin-badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;line-height:1.4}.admin-badge[data-variant=active]{background-color:color-mix(in srgb,var(--status-success) 15%,transparent);color:var(--status-success)}.admin-badge[data-variant=used]{background-color:var(--surface-sunken);color:var(--text-muted)}.admin-badge[data-variant=admin]{background-color:var(--overlay-brand-soft);color:var(--brand-strong)}.admin-badge[data-variant=member]{background-color:var(--surface-sunken);color:var(--text-secondary)}.admin-btn{border:1px solid transparent;border-radius:6px;padding:.4rem .85rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color .12s var(--ease-default),color .12s var(--ease-default),border-color .12s var(--ease-default)}.admin-btn:disabled{opacity:.55;cursor:not-allowed}.admin-btn-primary{background-color:var(--brand-default);color:var(--text-inverse)}.admin-btn-primary:hover:not(:disabled){background-color:var(--brand-hover)}.admin-btn-ghost{background-color:transparent;color:var(--text-secondary);border-color:var(--border-subtle)}.admin-btn-ghost:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary)}.admin-btn-danger{background-color:transparent;color:var(--status-error);border-color:color-mix(in srgb,var(--status-error) 40%,transparent)}.admin-btn-danger:hover:not(:disabled){background-color:color-mix(in srgb,var(--status-error) 10%,transparent)}.admin-notice{padding:.75rem 1rem;background-color:var(--overlay-brand-soft);border:1px solid color-mix(in srgb,var(--brand-default) 30%,transparent);border-radius:8px;color:var(--text-primary);font-size:.9rem}.admin-notice code{font-family:JetBrains Mono,SF Mono,Consolas,monospace;background-color:var(--surface-sunken);padding:.125rem .375rem;border-radius:4px}
