@layer theme,base,components,utilities;@layer theme{@theme default{ --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; --color-red-50: oklch(.971 .013 17.38); --color-red-100: oklch(.936 .032 17.717); --color-red-200: oklch(.885 .062 18.334); --color-red-300: oklch(.808 .114 19.571); --color-red-400: oklch(.704 .191 22.216); --color-red-500: oklch(.637 .237 25.331); --color-red-600: oklch(.577 .245 27.325); --color-red-700: oklch(.505 .213 27.518); --color-red-800: oklch(.444 .177 26.899); --color-red-900: oklch(.396 .141 25.723); --color-red-950: oklch(.258 .092 26.042); --color-orange-50: oklch(.98 .016 73.684); --color-orange-100: oklch(.954 .038 75.164); --color-orange-200: oklch(.901 .076 70.697); --color-orange-300: oklch(.837 .128 66.29); --color-orange-400: oklch(.75 .183 55.934); --color-orange-500: oklch(.705 .213 47.604); --color-orange-600: oklch(.646 .222 41.116); --color-orange-700: oklch(.553 .195 38.402); --color-orange-800: oklch(.47 .157 37.304); --color-orange-900: oklch(.408 .123 38.172); --color-orange-950: oklch(.266 .079 36.259); --color-amber-50: oklch(.987 .022 95.277); --color-amber-100: oklch(.962 .059 95.617); --color-amber-200: oklch(.924 .12 95.746); --color-amber-300: oklch(.879 .169 91.605); --color-amber-400: oklch(.828 .189 84.429); --color-amber-500: oklch(.769 .188 70.08); --color-amber-600: oklch(.666 .179 58.318); --color-amber-700: oklch(.555 .163 48.998); --color-amber-800: oklch(.473 .137 46.201); --color-amber-900: oklch(.414 .112 45.904); --color-amber-950: oklch(.279 .077 45.635); --color-yellow-50: oklch(.987 .026 102.212); --color-yellow-100: oklch(.973 .071 103.193); --color-yellow-200: oklch(.945 .129 101.54); --color-yellow-300: oklch(.905 .182 98.111); --color-yellow-400: oklch(.852 .199 91.936); --color-yellow-500: oklch(.795 .184 86.047); --color-yellow-600: oklch(.681 .162 75.834); --color-yellow-700: oklch(.554 .135 66.442); --color-yellow-800: oklch(.476 .114 61.907); --color-yellow-900: oklch(.421 .095 57.708); --color-yellow-950: oklch(.286 .066 53.813); --color-lime-50: oklch(.986 .031 120.757); --color-lime-100: oklch(.967 .067 122.328); --color-lime-200: oklch(.938 .127 124.321); --color-lime-300: oklch(.897 .196 126.665); --color-lime-400: oklch(.841 .238 128.85); --color-lime-500: oklch(.768 .233 130.85); --color-lime-600: oklch(.648 .2 131.684); --color-lime-700: oklch(.532 .157 131.589); --color-lime-800: oklch(.453 .124 130.933); --color-lime-900: oklch(.405 .101 131.063); --color-lime-950: oklch(.274 .072 132.109); --color-green-50: oklch(.982 .018 155.826); --color-green-100: oklch(.962 .044 156.743); --color-green-200: oklch(.925 .084 155.995); --color-green-300: oklch(.871 .15 154.449); --color-green-400: oklch(.792 .209 151.711); --color-green-500: oklch(.723 .219 149.579); --color-green-600: oklch(.627 .194 149.214); --color-green-700: oklch(.527 .154 150.069); --color-green-800: oklch(.448 .119 151.328); --color-green-900: oklch(.393 .095 152.535); --color-green-950: oklch(.266 .065 152.934); --color-emerald-50: oklch(.979 .021 166.113); --color-emerald-100: oklch(.95 .052 163.051); --color-emerald-200: oklch(.905 .093 164.15); --color-emerald-300: oklch(.845 .143 164.978); --color-emerald-400: oklch(.765 .177 163.223); --color-emerald-500: oklch(.696 .17 162.48); --color-emerald-600: oklch(.596 .145 163.225); --color-emerald-700: oklch(.508 .118 165.612); --color-emerald-800: oklch(.432 .095 166.913); --color-emerald-900: oklch(.378 .077 168.94); --color-emerald-950: oklch(.262 .051 172.552); --color-teal-50: oklch(.984 .014 180.72); --color-teal-100: oklch(.953 .051 180.801); --color-teal-200: oklch(.91 .096 180.426); --color-teal-300: oklch(.855 .138 181.071); --color-teal-400: oklch(.777 .152 181.912); --color-teal-500: oklch(.704 .14 182.503); --color-teal-600: oklch(.6 .118 184.704); --color-teal-700: oklch(.511 .096 186.391); --color-teal-800: oklch(.437 .078 188.216); --color-teal-900: oklch(.386 .063 188.416); --color-teal-950: oklch(.277 .046 192.524); --color-cyan-50: oklch(.984 .019 200.873); --color-cyan-100: oklch(.956 .045 203.388); --color-cyan-200: oklch(.917 .08 205.041); --color-cyan-300: oklch(.865 .127 207.078); --color-cyan-400: oklch(.789 .154 211.53); --color-cyan-500: oklch(.715 .143 215.221); --color-cyan-600: oklch(.609 .126 221.723); --color-cyan-700: oklch(.52 .105 223.128); --color-cyan-800: oklch(.45 .085 224.283); --color-cyan-900: oklch(.398 .07 227.392); --color-cyan-950: oklch(.302 .056 229.695); --color-sky-50: oklch(.977 .013 236.62); --color-sky-100: oklch(.951 .026 236.824); --color-sky-200: oklch(.901 .058 230.902); --color-sky-300: oklch(.828 .111 230.318); --color-sky-400: oklch(.746 .16 232.661); --color-sky-500: oklch(.685 .169 237.323); --color-sky-600: oklch(.588 .158 241.966); --color-sky-700: oklch(.5 .134 242.749); --color-sky-800: oklch(.443 .11 240.79); --color-sky-900: oklch(.391 .09 240.876); --color-sky-950: oklch(.293 .066 243.157); --color-blue-50: oklch(.97 .014 254.604); --color-blue-100: oklch(.932 .032 255.585); --color-blue-200: oklch(.882 .059 254.128); --color-blue-300: oklch(.809 .105 251.813); --color-blue-400: oklch(.707 .165 254.624); --color-blue-500: oklch(.623 .214 259.815); --color-blue-600: oklch(.546 .245 262.881); --color-blue-700: oklch(.488 .243 264.376); --color-blue-800: oklch(.424 .199 265.638); --color-blue-900: oklch(.379 .146 265.522); --color-blue-950: oklch(.282 .091 267.935); --color-indigo-50: oklch(.962 .018 272.314); --color-indigo-100: oklch(.93 .034 272.788); --color-indigo-200: oklch(.87 .065 274.039); --color-indigo-300: oklch(.785 .115 274.713); --color-indigo-400: oklch(.673 .182 276.935); --color-indigo-500: oklch(.585 .233 277.117); --color-indigo-600: oklch(.511 .262 276.966); --color-indigo-700: oklch(.457 .24 277.023); --color-indigo-800: oklch(.398 .195 277.366); --color-indigo-900: oklch(.359 .144 278.697); --color-indigo-950: oklch(.257 .09 281.288); --color-violet-50: oklch(.969 .016 293.756); --color-violet-100: oklch(.943 .029 294.588); --color-violet-200: oklch(.894 .057 293.283); --color-violet-300: oklch(.811 .111 293.571); --color-violet-400: oklch(.702 .183 293.541); --color-violet-500: oklch(.606 .25 292.717); --color-violet-600: oklch(.541 .281 293.009); --color-violet-700: oklch(.491 .27 292.581); --color-violet-800: oklch(.432 .232 292.759); --color-violet-900: oklch(.38 .189 293.745); --color-violet-950: oklch(.283 .141 291.089); --color-purple-50: oklch(.977 .014 308.299); --color-purple-100: oklch(.946 .033 307.174); --color-purple-200: oklch(.902 .063 306.703); --color-purple-300: oklch(.827 .119 306.383); --color-purple-400: oklch(.714 .203 305.504); --color-purple-500: oklch(.627 .265 303.9); --color-purple-600: oklch(.558 .288 302.321); --color-purple-700: oklch(.496 .265 301.924); --color-purple-800: oklch(.438 .218 303.724); --color-purple-900: oklch(.381 .176 304.987); --color-purple-950: oklch(.291 .149 302.717); --color-fuchsia-50: oklch(.977 .017 320.058); --color-fuchsia-100: oklch(.952 .037 318.852); --color-fuchsia-200: oklch(.903 .076 319.62); --color-fuchsia-300: oklch(.833 .145 321.434); --color-fuchsia-400: oklch(.74 .238 322.16); --color-fuchsia-500: oklch(.667 .295 322.15); --color-fuchsia-600: oklch(.591 .293 322.896); --color-fuchsia-700: oklch(.518 .253 323.949); --color-fuchsia-800: oklch(.452 .211 324.591); --color-fuchsia-900: oklch(.401 .17 325.612); --color-fuchsia-950: oklch(.293 .136 325.661); --color-pink-50: oklch(.971 .014 343.198); --color-pink-100: oklch(.948 .028 342.258); --color-pink-200: oklch(.899 .061 343.231); --color-pink-300: oklch(.823 .12 346.018); --color-pink-400: oklch(.718 .202 349.761); --color-pink-500: oklch(.656 .241 354.308); --color-pink-600: oklch(.592 .249 .584); --color-pink-700: oklch(.525 .223 3.958); --color-pink-800: oklch(.459 .187 3.815); --color-pink-900: oklch(.408 .153 2.432); --color-pink-950: oklch(.284 .109 3.907); --color-rose-50: oklch(.969 .015 12.422); --color-rose-100: oklch(.941 .03 12.58); --color-rose-200: oklch(.892 .058 10.001); --color-rose-300: oklch(.81 .117 11.638); --color-rose-400: oklch(.712 .194 13.428); --color-rose-500: oklch(.645 .246 16.439); --color-rose-600: oklch(.586 .253 17.585); --color-rose-700: oklch(.514 .222 16.935); --color-rose-800: oklch(.455 .188 13.697); --color-rose-900: oklch(.41 .159 10.272); --color-rose-950: oklch(.271 .105 12.094); --color-slate-50: oklch(.984 .003 247.858); --color-slate-100: oklch(.968 .007 247.896); --color-slate-200: oklch(.929 .013 255.508); --color-slate-300: oklch(.869 .022 252.894); --color-slate-400: oklch(.704 .04 256.788); --color-slate-500: oklch(.554 .046 257.417); --color-slate-600: oklch(.446 .043 257.281); --color-slate-700: oklch(.372 .044 257.287); --color-slate-800: oklch(.279 .041 260.031); --color-slate-900: oklch(.208 .042 265.755); --color-slate-950: oklch(.129 .042 264.695); --color-gray-50: oklch(.985 .002 247.839); --color-gray-100: oklch(.967 .003 264.542); --color-gray-200: oklch(.928 .006 264.531); --color-gray-300: oklch(.872 .01 258.338); --color-gray-400: oklch(.707 .022 261.325); --color-gray-500: oklch(.551 .027 264.364); --color-gray-600: oklch(.446 .03 256.802); --color-gray-700: oklch(.373 .034 259.733); --color-gray-800: oklch(.278 .033 256.848); --color-gray-900: oklch(.21 .034 264.665); --color-gray-950: oklch(.13 .028 261.692); --color-zinc-50: oklch(.985 0 0); --color-zinc-100: oklch(.967 .001 286.375); --color-zinc-200: oklch(.92 .004 286.32); --color-zinc-300: oklch(.871 .006 286.286); --color-zinc-400: oklch(.705 .015 286.067); --color-zinc-500: oklch(.552 .016 285.938); --color-zinc-600: oklch(.442 .017 285.786); --color-zinc-700: oklch(.37 .013 285.805); --color-zinc-800: oklch(.274 .006 286.033); --color-zinc-900: oklch(.21 .006 285.885); --color-zinc-950: oklch(.141 .005 285.823); --color-neutral-50: oklch(.985 0 0); --color-neutral-100: oklch(.97 0 0); --color-neutral-200: oklch(.922 0 0); --color-neutral-300: oklch(.87 0 0); --color-neutral-400: oklch(.708 0 0); --color-neutral-500: oklch(.556 0 0); --color-neutral-600: oklch(.439 0 0); --color-neutral-700: oklch(.371 0 0); --color-neutral-800: oklch(.269 0 0); --color-neutral-900: oklch(.205 0 0); --color-neutral-950: oklch(.145 0 0); --color-stone-50: oklch(.985 .001 106.423); --color-stone-100: oklch(.97 .001 106.424); --color-stone-200: oklch(.923 .003 48.717); --color-stone-300: oklch(.869 .005 56.366); --color-stone-400: oklch(.709 .01 56.259); --color-stone-500: oklch(.553 .013 58.071); --color-stone-600: oklch(.444 .011 73.639); --color-stone-700: oklch(.374 .01 67.558); --color-stone-800: oklch(.268 .007 34.298); --color-stone-900: oklch(.216 .006 56.043); --color-stone-950: oklch(.147 .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: var(--font-sans); --default-font-feature-settings: var(--font-sans--font-feature-settings); --default-font-variation-settings: var( --font-sans--font-variation-settings ); --default-mono-font-family: var(--font-mono); --default-mono-font-feature-settings: var( --font-mono--font-feature-settings ); --default-mono-font-variation-settings: var( --font-mono--font-variation-settings ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;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}body{line-height:inherit}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{font-size:75%;line-height:0;position:relative;vertical-align:baseline}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{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}: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;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,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}@theme{ --color-bg-primary: #0a0e1a; --color-bg-secondary: #121827; --color-bg-tertiary: #1a2332; --color-accent-cyan: #00d9ff; --color-accent-purple: #6366f1; --color-accent-green: #00ff88; --color-accent-danger: #ff0055; --color-accent-warning: #ffaa00; --color-text-primary: #e8eef5; --color-text-secondary: #8b92a8; --color-text-tertiary: #4a5264; --color-glass-bg: rgba(26, 35, 50, .6); --color-glass-border: rgba(0, 217, 255, .2); --color-glass-border-strong: rgba(0, 217, 255, .4); }:root{--shadow-glow-cyan: 0 0 20px rgba(0, 217, 255, .4);--shadow-glow-cyan-strong: 0 0 30px rgba(0, 217, 255, .6);--shadow-glow-purple: 0 0 20px rgba(99, 102, 241, .4);--shadow-glow-green: 0 0 20px rgba(0, 255, 136, .4)}@layer base{html,body{min-width:320px}body{background:radial-gradient(ellipse at top,#121827,#0a0e1a,#050710);background-attachment:fixed;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif}}@layer utilities{.glass{background:var(--color-glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-glass-border);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff1a}.glass-strong{background:#1a2332cc;border-color:var(--color-glass-border-strong)}.glow-cyan{box-shadow:var(--shadow-glow-cyan)}.glow-cyan-strong{box-shadow:var(--shadow-glow-cyan-strong)}.glow-purple{box-shadow:var(--shadow-glow-purple)}.glow-green{box-shadow:var(--shadow-glow-green)}.text-glow-cyan{text-shadow:0 0 10px rgba(0,217,255,.6)}.beat-pulse{animation:beat-pulse .6s ease-in-out}@keyframes beat-pulse{0%,to{box-shadow:var(--shadow-glow-cyan);transform:scale(1)}50%{box-shadow:var(--shadow-glow-cyan-strong);transform:scale(1.02)}}.slide-up{animation:slide-up .3s ease-out}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-in .3s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}}*{margin:0;padding:0;box-sizing:border-box}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:root{--bg-primary: #0a0e1a;--bg-secondary: #121827;--bg-tertiary: #1a2332;--accent-cyan: #00d9ff;--accent-cyan-soft: rgba(0, 217, 255, .18);--accent-cyan-bold: rgba(0, 217, 255, .65);--accent-cyan-bright: #00f0ff;--accent-purple: #6366f1;--accent-purple-bright: #818cf8;--accent-green: #00ff88;--accent-danger: #ff0055;--accent-warning: #ffaa00;--action-primary: linear-gradient(135deg, #00d9ff 0%, #0099ff 100%);--action-primary-hover: linear-gradient(135deg, #00f0ff 0%, #00b3ff 100%);--action-secondary: rgba(0, 217, 255, .15);--action-secondary-hover: rgba(0, 217, 255, .25);--text-primary: #e8eef5;--text-secondary: #8b92a8;--text-tertiary: #4a5264;--glass-bg: rgba(26, 35, 50, .6);--glass-border: rgba(0, 217, 255, .2);--glass-border-strong: rgba(0, 217, 255, .4);--glow-cyan: 0 0 20px rgba(0, 217, 255, .4);--glow-cyan-strong: 0 0 30px rgba(0, 217, 255, .6);--glow-cyan-intense: 0 0 40px rgba(0, 217, 255, .8), 0 0 80px rgba(0, 217, 255, .4);--glow-purple: 0 0 20px rgba(99, 102, 241, .4);--glow-green: 0 0 20px rgba(0, 255, 136, .4);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--touch-min: 44px;--primary-color: var(--accent-cyan);--background: var(--bg-primary);--surface: var(--bg-secondary);--surface-light: var(--bg-tertiary);--text: var(--text-primary);--text-secondary: var(--text-secondary);--accent: var(--accent-cyan);--success: var(--accent-green);--danger: var(--accent-danger);--border: var(--glass-border)}*{box-sizing:border-box}html{overflow-x:hidden;max-width:100vw}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:radial-gradient(ellipse at top,#121827,#0a0e1a,#050710);background-attachment:fixed;color:var(--text-primary);min-height:100vh;padding:0;margin:0;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;font-weight:400;min-width:320px;max-width:100vw;overflow-x:hidden;position:relative}.app-container{max-width:1200px;width:100%;max-width:100vw;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:0;overflow-x:hidden;position:relative}.app-shell{min-height:100vh;display:flex;flex-direction:column;color:var(--text-primary);text-rendering:optimizeLegibility;padding-top:0}.app-shell-main{flex:1;width:100%;max-width:1120px;margin:0 auto;padding:0 clamp(1rem,3vw,2.5rem) 6rem;display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2.5rem)}.app-shell-main.has-user{padding-top:0}@media(max-width:1024px){.app-shell-main,.app-shell-main.has-user{padding:1.6rem clamp(.9rem,4vw,2rem) 7rem}}@media(max-width:768px){.app-shell-main,.app-shell-main.has-user{padding:1.4rem clamp(.8rem,5vw,1.6rem) 7.2rem}}@media(max-width:520px){.app-shell-main,.app-shell-main.has-user{padding:1.2rem clamp(.65rem,6vw,1.3rem) 6.2rem}}@media(max-width:400px){.app-shell-main,.app-shell-main.has-user{padding:1.1rem clamp(.55rem,7vw,1.1rem) 6rem}}@media(max-width:360px){.app-shell-main,.app-shell-main.has-user{padding:1rem .5rem 6rem}}@media(max-width:320px){.app-shell-main,.app-shell-main.has-user{padding:.75rem .25rem 6rem}}.hidden{display:none!important}@media(min-width:768px){.md\:block{display:block!important}.md\:hidden{display:none!important}}@media(min-width:768px){.app-header.md\:ml-\[240px\],main.md\:ml-\[240px\]{margin-left:240px;transition:margin-left .3s ease}body.sidebar-collapsed .app-header.md\:ml-\[240px\],body.sidebar-collapsed main.md\:ml-\[240px\]{margin-left:64px}}header{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;width:100%;max-width:100vw;padding:0 clamp(.5rem,2vw,1rem);box-sizing:border-box}h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}h2,h3{color:var(--text)}.performance-mode-selector{display:flex;gap:10px;margin:0 auto 20px;background:var(--surface);padding:5px;border-radius:12px;width:100%;max-width:min(360px,calc(100vw - 2rem));justify-content:center;box-sizing:border-box}.mode-btn{flex:1;padding:12px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s ease}.mode-btn.active{background:var(--primary-color);color:var(--text)}.performance-mode{display:none}.performance-mode.active{display:block;width:100%;max-width:100%}.current-setlist-section{display:flex;gap:10px;margin:0 auto 20px;width:100%;max-width:min(900px,calc(100vw - 2rem));flex-wrap:wrap;padding:0 clamp(.5rem,2vw,1rem);box-sizing:border-box}.setlist-select{flex:1;min-width:200px;padding:12px;border-radius:12px;background:var(--surface);border:none;color:var(--text);font-size:1rem;font-family:inherit}.current-setlist-section .btn{flex-shrink:0;white-space:nowrap}.song-list-container{width:100%;max-width:900px;margin:0 auto 20px}.song-list{background:var(--surface);border-radius:16px;padding:15px;margin-bottom:20px;max-height:200px;overflow-y:auto;width:100%}.song-item{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:8px 12px;padding:14px;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-bottom:10px;align-items:center;background:var(--surface-light);border:1px solid transparent}.performance-song-item{grid-template-columns:auto 1fr auto}.song-item:hover{background:var(--surface);border-color:#6366f14d;transform:translateY(-1px)}.song-item.active{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--text);border-color:var(--primary-color);box-shadow:0 4px 12px #6366f166}.drag-handle-small{grid-row:1 / 3;grid-column:1;align-self:center;cursor:grab;font-size:1.2rem;color:var(--text-secondary);padding:4px 8px;border-radius:4px;transition:all .2s ease;-webkit-user-select:none;user-select:none;touch-action:none}.song-item.active .drag-handle-small{color:var(--text)}.drag-handle-small:active{cursor:grabbing}.song-number{grid-row:1;grid-column:2;font-weight:700;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.song-item.active .song-number{color:var(--text);opacity:.9}.song-name{grid-row:2;grid-column:2;font-weight:600;font-size:1rem;line-height:1.4;color:var(--text);word-wrap:break-word;overflow-wrap:break-word}.song-item.active .song-name{color:var(--text)}.song-artist-small{display:block;font-weight:400;font-size:.85rem;color:var(--text-secondary);margin-top:4px;font-style:italic}.song-item.active .song-artist-small{color:#ffffffe6}.song-bpm{grid-row:1 / 3;grid-column:3;align-self:center;color:var(--text-secondary);font-size:.9rem;font-weight:600;background:var(--surface);padding:6px 12px;border-radius:8px;white-space:nowrap;min-width:70px;text-align:center}.song-item.active .song-bpm{background:#fff3;color:var(--text)}.live-song-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin:0 auto 30px;padding:20px;background:var(--surface);border-radius:16px;max-height:850px;overflow-y:auto;width:100%;max-width:1000px;position:relative}.live-song-grid:after{content:"";position:sticky;bottom:0;left:0;right:0;height:30px;background:linear-gradient(to top,var(--surface) 0%,transparent 100%);pointer-events:none;opacity:0;transition:opacity .3s ease;margin-top:-30px}.live-song-grid.has-more:after{opacity:1}.live-more-indicator{grid-column:1 / -1;text-align:center;padding:10px;color:var(--text-secondary);font-size:.85rem;font-style:italic;margin-top:10px}.live-song-button{background:var(--surface-light);border:2px solid transparent;border-radius:12px;padding:12px 15px;cursor:pointer;transition:all .2s ease;text-align:center;height:140px;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:4px;min-height:140px;max-height:140px;overflow:hidden}.live-song-button:hover{background:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.live-song-button.active{background:var(--primary-color);border-color:var(--accent);box-shadow:0 0 20px #6366f180}.live-song-number{font-size:1.2rem;font-weight:700;color:var(--text-secondary);line-height:1.2;flex-shrink:0;margin-bottom:2px}.live-song-button.active .live-song-number{color:var(--text)}.live-song-name{font-size:1.1rem;font-weight:600;color:var(--text);line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;width:100%;flex:1;display:block;text-align:center;overflow:hidden;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;min-height:0}.live-song-artist{font-size:.85rem;color:var(--text-secondary);font-style:italic;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;width:100%;flex-shrink:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;text-align:center;margin-top:2px}.live-song-bpm{font-size:.8rem;color:var(--text-secondary);line-height:1.2;flex-shrink:0;font-weight:600}.live-no-songs{grid-column:1 / -1;text-align:center;padding:40px;color:var(--text-secondary)}.live-quick-tempo{background:var(--surface);border-radius:16px;padding:20px;margin:0 auto 20px;width:100%;max-width:600px}.quick-tempo-label{text-align:center;font-size:.9rem;color:var(--text-secondary);margin-bottom:15px;text-transform:uppercase;letter-spacing:1px}.quick-tempo-controls{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.tempo-btn{min-width:60px;padding:12px 16px;font-size:1rem;font-weight:700}.quick-tempo-value{font-size:2.5rem;font-weight:700;color:var(--primary-color);min-width:100px;text-align:center;padding:0 20px}.performance-controls{background:var(--surface);border-radius:16px;padding:20px;box-shadow:0 10px 30px #0003;margin:0 auto 20px;width:100%;max-width:900px}.current-song-display{text-align:center;margin-bottom:20px}.current-song-display h2{font-size:1.4rem;margin-bottom:12px;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.bpm-display{display:flex;align-items:baseline;justify-content:center;gap:10px;flex-wrap:wrap}#bpm-value{font-size:3rem;font-weight:700;color:var(--primary-color)}.bpm-label{font-size:1rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px}.time-signature-display{font-size:1.5rem;font-weight:600;color:var(--secondary-color);margin-left:15px}.bpm-input{font-size:inherit;font-weight:inherit;width:80px;text-align:center;background:var(--surface-light);border:2px solid var(--primary-color);border-radius:8px;padding:4px 8px;color:var(--text);outline:none;font-family:inherit}.bpm-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f133}#bpm-value:hover{color:var(--primary-color);text-decoration:underline}.tempo-wheel-container{display:flex;flex-direction:column;align-items:center;margin:20px auto;width:100%;max-width:100%;padding:0 15px;box-sizing:border-box}.tempo-wheel{width:240px;height:240px;position:relative;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.tempo-wheel:active{cursor:grabbing}.wheel-background{position:absolute;width:100%;height:100%;border-radius:50%;background:var(--surface);border:4px solid var(--primary-color);box-shadow:0 10px 40px #6366f14d;transition:transform .2s ease,box-shadow .2s ease;pointer-events:none;transform-origin:center center}.wheel-mark{position:absolute;top:5px;left:50%;transform:translate(-50%);width:3px;height:15px;background:var(--primary-color);border-radius:2px}.wheel-mark-1{top:5px}.wheel-mark-2{top:50%;right:5px;transform:translateY(-50%) rotate(90deg);left:auto}.wheel-mark-3{bottom:5px;transform:translate(-50%) rotate(180deg)}.wheel-mark-4{top:50%;left:5px;transform:translateY(-50%) rotate(-90deg);right:auto}.tempo-wheel.active .wheel-background{box-shadow:0 15px 50px #6366f166}.wheel-inner{position:absolute;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;pointer-events:none}.wheel-play-btn{background:var(--surface);border:3px solid var(--primary-color);border-radius:50%;width:80%;height:80%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;pointer-events:auto;padding:0;box-shadow:0 4px 15px #0003}.wheel-play-btn:hover{background:var(--surface-light);transform:scale(1.05);box-shadow:0 6px 20px #6366f14d}.wheel-play-btn.playing{background:var(--primary-color);border-color:var(--accent);box-shadow:0 0 25px #6366f199}.wheel-play-btn.playing .wheel-bpm-value,.wheel-play-btn.playing .wheel-label{color:var(--text)}.wheel-play-icon,.wheel-pause-icon{font-size:2rem;color:var(--primary-color);margin-bottom:5px;line-height:1}.wheel-play-btn.playing .wheel-play-icon,.wheel-play-btn.playing .wheel-pause-icon{color:var(--text)}.wheel-bpm-value{font-size:2rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:3px;pointer-events:none}.wheel-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;pointer-events:none}.wheel-value{font-size:3rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:5px}.wheel-handle{position:absolute;top:10px;left:50%;transform:translate(-50%);width:4px;height:20px;background:var(--primary-color);border-radius:2px;pointer-events:none;z-index:3}.wheel-handle:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:12px solid var(--primary-color)}.tempo-wheel-controls{margin-top:16px;width:100%;max-width:100%;display:flex;flex-direction:column;gap:12px;align-items:stretch;box-sizing:border-box}.song-navigation-container{order:1;margin-bottom:0}.tap-tempo-container{order:2}.song-navigation-container{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:100%;margin-bottom:0;box-sizing:border-box;padding:0}.song-navigation-container .current-song-title{display:none}.current-song-title{font-size:.9rem;color:var(--text-secondary);min-width:100px;max-width:220px;flex:1 1 auto;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tap-tempo-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}.tap-tempo-btn{width:100%;min-width:120px;min-height:44px;touch-action:manipulation}.tap-tempo-message{font-size:.85rem;color:var(--primary-color);font-weight:500;text-align:center;min-height:22px;height:22px;display:flex;align-items:center;justify-content:center;line-height:1.2;animation:fadeIn .2s ease-in;visibility:visible}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tempo-wheel-controls .btn{min-width:120px;min-height:44px;touch-action:manipulation}.tempo-wheel-controls .btn.active{background:var(--primary-color);transform:scale(.95)}@media(max-width:768px){.tempo-wheel{width:240px;height:240px}.wheel-value{font-size:2.5rem}}.beat-pattern-selector{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:15px 0;padding:15px;background:var(--surface-light);border-radius:12px;max-width:100%;box-sizing:border-box}.beat-btn{width:50px;height:50px;min-width:50px;max-width:100%;border-radius:12px;border:2px solid var(--surface);background:var(--surface);color:var(--text-secondary);font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex-shrink:0;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.beat-btn:hover{border-color:var(--primary-color);background:var(--surface-light);transform:scale(1.05)}.beat-btn.accented{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:var(--text);border-color:var(--primary-color);box-shadow:0 4px 12px #6366f166;transform:scale(1.1)}.beat-btn.accented:hover{transform:scale(1.15);box-shadow:0 6px 16px #6366f180}.accent-controls{display:flex;gap:10px;margin-top:10px;justify-content:center;flex-wrap:wrap;width:100%}.accent-controls .btn{flex:0 1 auto;padding:10px 20px;font-size:.9rem;min-width:140px}.save-changes-section{margin-top:20px;padding:15px;background:var(--surface-light);border-radius:12px;border:2px solid var(--primary-color);display:flex;flex-direction:column;gap:12px;align-items:center}.unsaved-indicator{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9rem}.unsaved-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}.save-changes-section .save-btn{width:100%}.overwrite-btn{width:100%;font-size:.9rem;position:relative}.overwrite-btn:active{background:var(--danger);transform:scale(.98)}.overwrite-btn.holding{background:var(--danger);animation:pulse .5s infinite}.lyrics-container{background:var(--surface-light);border-radius:16px;padding:20px;margin:0 auto 30px;min-height:200px;max-height:300px;overflow-y:auto;width:100%;max-width:900px}.lyrics-display{text-align:center}.lyric-line{font-size:1.2rem;line-height:2;color:var(--text-secondary);transition:all .3s ease;padding:5px 0}.lyric-line.current{color:var(--text);font-size:1.5rem;font-weight:600}.lyrics-placeholder{color:var(--text-secondary);font-style:italic}.metronome-section{margin:0 auto 20px;width:100%;max-width:900px}.visual-beat{height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;padding:15px;background:var(--surface-light);border-radius:12px;border:1px solid rgba(99,102,241,.2)}.beat-indicator{width:80px;height:80px;border-radius:50%;background:var(--surface);border:3px solid var(--primary-color);box-shadow:0 0 20px #6366f14d,inset 0 0 20px #6366f11a;transition:all .15s cubic-bezier(.4,0,.2,1);opacity:.7;display:flex;align-items:center;justify-content:center;position:relative;color:var(--text);font-weight:700;font-size:2rem;-webkit-user-select:none;user-select:none}@media(min-width:375px){.visual-beat{height:130px;padding:18px}.beat-indicator{width:90px;height:90px;font-size:2.2rem}}@media(min-width:640px){.visual-beat{height:140px;padding:20px;margin-bottom:25px}.beat-indicator{width:100px;height:100px;font-size:2.5rem}}.beat-indicator.active{transform:scale(1.25);opacity:1;border-width:4px;box-shadow:0 0 40px #4caf50cc,0 0 60px #4caf5066,inset 0 0 30px #4caf5033;border-color:#4caf50;background:linear-gradient(135deg,#4caf5033,#4caf500d)}.beat-indicator.active.accent{transform:scale(1.35);border-color:#f44;box-shadow:0 0 50px #ff4444e6,0 0 80px #ff444480,inset 0 0 40px #ff44444d;background:linear-gradient(135deg,#ff444440,#ff44441a)}.metronome-settings{margin:0 auto 20px;padding:12px;background:var(--surface-light);border-radius:12px;border:1px solid rgba(99,102,241,.15);width:100%;max-width:900px}.settings-grid{display:grid;grid-template-columns:1fr;gap:10px;align-items:stretch}@media(min-width:640px){.settings-grid{grid-template-columns:repeat(3,1fr);gap:12px}}.settings-checkbox{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border-radius:8px;border:1px solid rgba(99,102,241,.1);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;min-width:0;justify-content:flex-start}.settings-checkbox:hover{background:#6366f11a;border-color:#6366f14d;transform:translateY(-1px)}.settings-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color);margin:0;flex-shrink:0;min-width:18px}.settings-checkbox input[type=checkbox]:checked+.settings-icon{filter:brightness(1.2)}.settings-icon{font-size:1.2rem;line-height:1;flex-shrink:0;transition:filter .2s ease;min-width:24px;width:24px;text-align:center}.settings-label{font-size:.9rem;color:var(--text);font-weight:500;flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.settings-checkbox:has(input:checked){background:#6366f126;border-color:var(--primary-color)}.settings-checkbox:has(input:checked) .settings-label{color:var(--text);font-weight:600}@media(min-width:320px){.view{padding:12px}header{margin-bottom:16px}h1{font-size:1.4rem}.performance-controls{padding:16px;border-radius:12px}.current-song-display h2{font-size:1.2rem}.bpm-display{font-size:1.8rem;gap:8px}#bpm-value{font-size:2.2rem}#bpm-slider{height:12px}#bpm-slider::-webkit-slider-thumb{width:32px;height:32px;margin-top:-10px}#bpm-slider::-moz-range-thumb{width:32px;height:32px}.range-labels{font-size:.65rem;margin-top:6px}.tempo-wheel{width:220px;height:220px}.tempo-wheel-controls{margin-top:12px;width:100%;gap:12px;align-items:center}.song-navigation-container{grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:100%;padding:0}.song-navigation-container button{width:100%;min-width:auto;padding:12px 16px;font-size:.9rem;min-height:44px}.current-song-title{display:none}.tap-tempo-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}.tap-tempo-btn{width:100%;min-width:auto;max-width:100%;padding:12px 16px;font-size:.9rem;min-height:44px}.tempo-wheel-controls .btn{min-width:auto;width:100%;padding:12px 16px;font-size:.9rem;min-height:44px}.btn{padding:11px 18px;font-size:.9rem}.song-list{max-height:180px;padding:12px}.lyrics-container,.metronome-section{margin-bottom:16px}.settings-label{font-size:.8rem}.settings-checkbox{padding:12px 14px;gap:10px;min-height:48px}.settings-icon{font-size:1.1rem;min-width:24px;width:24px}.metronome-settings{padding:15px}.live-song-button{height:110px;min-height:110px;max-height:110px;padding:10px;gap:4px}.live-song-number{font-size:1rem}.live-song-name{font-size:.85rem}.live-song-artist{font-size:.7rem}.live-song-bpm{font-size:.65rem}.live-song-grid{max-height:790px}}@media(min-width:375px){.view{padding:16px}header{margin-bottom:20px}h1{font-size:1.5rem}.performance-controls{padding:18px}.current-song-display h2{font-size:1.3rem}.tempo-wheel{width:240px;height:240px}.tempo-wheel-controls{margin-top:12px;gap:12px}.song-navigation-container{grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:100%}.song-navigation-container button{width:100%;min-width:auto;padding:12px 18px;font-size:.9rem}.current-song-title{display:none}.tap-tempo-container{width:100%;max-width:300px;margin:0 auto}.tap-tempo-btn{width:100%;min-width:110px;max-width:300px;padding:12px 20px;font-size:.95rem}.tempo-wheel-controls .btn{min-width:110px;width:auto;padding:12px 18px}.range-labels{font-size:.72rem}.metronome-settings{padding:15px}.live-song-button{height:130px;min-height:130px;max-height:130px;padding:12px;gap:5px}.live-song-name{font-size:.95rem}.live-song-artist{font-size:.75rem}.live-song-bpm{font-size:.7rem}.live-song-grid{max-height:765px}.settings-checkbox{gap:10px;padding:12px;min-height:50px}.settings-icon{font-size:1.2rem;min-width:26px;width:26px}.settings-label{font-size:.85rem}.btn{padding:12px 20px}}@media(min-width:425px){.view{padding:20px}header{margin-bottom:24px}h1{font-size:1.75rem}.performance-controls{padding:24px;border-radius:18px}.current-song-display{margin-bottom:24px}.current-song-display h2{font-size:1.5rem}.bpm-display{font-size:2rem;gap:10px}#bpm-value{font-size:2.8rem}.bpm-label{font-size:1.1rem}.time-signature-display{font-size:1.6rem}.tempo-wheel-container{margin:24px 0}.tempo-wheel{width:260px;height:260px}.tempo-wheel-controls{margin-top:14px;gap:12px}.song-navigation-container{grid-template-columns:1fr 1fr;gap:12px}.song-navigation-container button{width:100%;min-width:auto;padding:12px 20px;font-size:.95rem}.current-song-title{display:none}.tap-tempo-container{max-width:320px}.tap-tempo-btn{max-width:320px;padding:12px 24px;font-size:1rem}.tempo-wheel-controls .btn{min-width:120px;padding:12px 20px;font-size:.95rem}.song-list{max-height:220px;padding:15px}.song-item{padding:16px;gap:10px 16px}.song-name{font-size:1.05rem}.song-bpm{font-size:1rem;padding:8px 14px;min-width:80px}.lyrics-container,.metronome-section{margin-bottom:20px}.control-group{margin-bottom:24px}.button-group{gap:12px}.btn{padding:14px 24px;font-size:1rem}}@media(min-width:640px){.live-song-grid{grid-template-columns:repeat(3,1fr);max-height:660px}.settings-grid{grid-template-columns:repeat(3,1fr)}.performance-mode-selector{max-width:400px;margin:0 auto 24px}.tempo-wheel{width:300px;height:300px}.tempo-wheel-controls{margin-top:16px;gap:14px}.song-navigation-container{grid-template-columns:1fr 1fr;gap:12px}.song-navigation-container button{width:100%;min-width:auto;padding:13px 22px;font-size:1rem}.current-song-title{display:none}.tap-tempo-container{max-width:340px}.tap-tempo-btn{max-width:340px;padding:13px 26px;font-size:1rem}.current-song-display h2{font-size:1.7rem}#bpm-value{font-size:3rem}.performance-controls{padding:28px}}@media(min-width:768px){.view{padding:24px}h1{font-size:2rem}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.tempo-wheel{width:320px;height:320px}.tempo-wheel-controls{margin-top:18px;gap:16px}.song-navigation-container{grid-template-columns:1fr 1fr;gap:14px}.song-navigation-container button{width:100%;min-width:auto;padding:14px 24px;font-size:1rem}.current-song-title{display:none}.tap-tempo-container{max-width:360px}.tap-tempo-btn{max-width:360px;padding:14px 28px;font-size:1.05rem}.performance-controls{padding:30px;border-radius:24px}.current-song-display h2{font-size:1.8rem}.song-list{max-height:280px}.performance-mode-selector{max-width:500px}}@media(min-width:1024px){.view{padding:30px}.performance-controls{max-width:900px;margin:0 auto 30px}.tempo-wheel-container{margin:30px auto}.tempo-wheel{width:340px;height:340px}.live-song-grid,.songs-container,.setlists-container{max-width:1100px}}.controls{margin-top:20px;width:100%;max-width:100%}.control-group{margin-bottom:25px}label{display:block;font-size:.9rem;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.slider-container{position:relative;padding:8px 0 24px}#bpm-slider{width:100%;height:10px;border-radius:5px;background:linear-gradient(to right,var(--surface-light) 0%,var(--surface-light) 100%);outline:none;-webkit-appearance:none;appearance:none;margin:0;position:relative;z-index:1}#bpm-slider::-webkit-slider-runnable-track{width:100%;height:10px;border-radius:5px;background:var(--surface-light)}#bpm-slider::-moz-range-track{width:100%;height:10px;border-radius:5px;background:var(--surface-light);border:none}#bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:var(--primary-color);cursor:pointer;box-shadow:0 2px 8px #6366f180,0 0 0 3px var(--surface);transition:all .2s ease;margin-top:-9px;position:relative;z-index:2}#bpm-slider::-webkit-slider-thumb:hover,#bpm-slider::-webkit-slider-thumb:active{transform:scale(1.15);box-shadow:0 4px 12px #6366f1b3,0 0 0 4px var(--surface)}#bpm-slider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:3px solid var(--surface);box-shadow:0 2px 8px #6366f180;transition:all .2s ease}#bpm-slider::-moz-range-thumb:hover,#bpm-slider::-moz-range-thumb:active{transform:scale(1.15);box-shadow:0 4px 12px #6366f1b3}.range-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-secondary);margin-top:8px;position:relative;padding:0 2px}.range-labels span{font-weight:500;opacity:.7;transition:opacity .2s ease}.range-labels span:first-child,.range-labels span:last-child{opacity:1;font-weight:600}.range-labels:before{content:"";position:absolute;top:-18px;left:0;right:0;height:10px;background-image:repeating-linear-gradient(to right,transparent,transparent calc((100% / 6) - 1px),rgba(99,102,241,.3) calc((100% / 6) - 1px),rgba(99,102,241,.3) calc(100% / 6));pointer-events:none}.button-group{display:flex;gap:15px}.btn{flex:1;padding:12px 20px;border:none;border-radius:12px;min-height:44px;font-size:.95rem;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;color:var(--text);font-family:inherit}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));box-shadow:0 4px 15px #6366f166}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.btn-primary.playing{background:linear-gradient(135deg,#ef4444,#f87171)}.btn-secondary{background:var(--surface-light)}.btn-secondary:hover{background:var(--surface);transform:translateY(-2px)}.helix-info{background:var(--surface-light);border-radius:12px;padding:15px;text-align:center;margin-top:20px}.helix-info p{color:var(--text-secondary)}#helix-preset-name{color:var(--primary-color);font-weight:600}.song-card,.setlist-card{background:var(--surface);border-radius:16px;padding:20px;margin-bottom:15px;box-shadow:0 4px 12px #0003}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.card-header h3{font-size:1.3rem}.song-artist{font-size:.9rem;font-weight:400;color:var(--text-secondary);font-style:italic}.card-actions{display:flex;gap:10px}.btn-icon{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:5px 10px;border-radius:8px;transition:all .2s ease}.btn-icon:hover{background:var(--surface-light)}.card-body p{color:var(--text-secondary);margin-bottom:8px}.song-list-inline{list-style:none;margin-top:10px}.song-list-inline li{padding:5px 0;color:var(--text-secondary)}.empty-state{text-align:center;color:var(--text-secondary);padding:40px;font-style:italic}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#000000b3;overflow-y:auto}.modal-content{background:var(--surface);margin:50px auto;padding:30px;border-radius:24px;max-width:600px;width:90%;position:relative;box-shadow:0 20px 60px #00000080}.close{position:absolute;right:20px;top:20px;font-size:28px;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:color .2s ease}.close:hover{color:var(--text)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text);font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px;border-radius:12px;background:var(--surface-light);border:none;color:var(--text);font-size:1rem;font-family:inherit}.form-group textarea{resize:vertical;min-height:150px}.form-group small{display:block;margin-top:5px;color:var(--text-secondary);font-size:.85rem}.form-actions{display:flex;gap:15px;margin-top:30px}.song-checkbox-list{background:var(--surface-light);border-radius:12px;padding:15px;max-height:400px;overflow-y:auto}.setlist-controls-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.btn-small{padding:8px 16px;font-size:.85rem}.btn-danger{background:var(--danger, #dc3545);color:#fff}.btn-danger:hover{background:var(--danger-hover, #c82333)}.song-count{color:var(--text-secondary);font-size:.9rem}.sortable-song-item{display:flex;align-items:center;gap:10px;padding:12px;margin-bottom:8px;border-radius:8px;background:var(--surface);border:2px solid transparent;cursor:move;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sortable-song-item:hover{background:var(--surface-light);border-color:var(--primary-color)}.sortable-song-item.selected{border-color:var(--primary-color);background:var(--surface-light)}.sortable-song-item.dragging{opacity:.5;cursor:grabbing}.sortable-song-item.drag-over{border-top:3px solid var(--primary-color)}.selected-songs-list{display:flex;flex-direction:column;gap:8px}.selected-songs-list .sortable-song-item{cursor:default;-webkit-user-select:none;user-select:none}.selected-songs-list .sortable-song-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.selected-songs-list .btn-icon{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.85rem;padding:6px 10px;border-radius:6px;transition:all .2s ease;min-width:36px;display:flex;align-items:center;justify-content:center}.selected-songs-list .btn-icon:hover:not(:disabled){background:var(--primary-color);color:var(--text);border-color:var(--primary-color);transform:scale(1.1)}.selected-songs-list .btn-icon:disabled{opacity:.3;cursor:not-allowed}.selected-songs-list .song-number-modal{transition:all .2s ease}.selected-songs-list .song-number-modal:hover{transform:scale(1.1);box-shadow:0 2px 4px #0003}.drag-handle{cursor:grab;color:var(--primary-color);font-size:1.3rem;font-weight:700;-webkit-user-select:none;user-select:none;padding:5px 8px;border-radius:4px;transition:all .2s ease}.drag-handle:hover{background:var(--surface-light);transform:scale(1.1)}.drag-handle:active,.sortable-song-item.dragging .drag-handle{cursor:grabbing}.drag-handle-small{cursor:grab;color:var(--primary-color);font-size:1.1rem;font-weight:700;-webkit-user-select:none;user-select:none;margin-right:10px;padding:5px;border-radius:4px;transition:all .2s ease}.drag-handle-small:hover{background:var(--surface-light);transform:scale(1.2)}.song-item.dragging .drag-handle-small{cursor:grabbing}.song-number-modal{min-width:25px;font-weight:600;color:var(--primary-color);text-align:center;font-size:.9rem}.sortable-song-item input[type=checkbox]{width:auto;margin:0}.song-checkbox-label{flex:1;cursor:pointer;margin:0}.song-artist-small{font-size:.85rem;color:var(--text-secondary);font-style:italic}.checkbox-label{display:flex;align-items:center;gap:10px;padding:10px;border-radius:8px;cursor:pointer;transition:background .2s ease}.checkbox-label:hover{background:var(--surface)}.checkbox-label input[type=checkbox]{width:auto}.song-item{cursor:move;position:relative}.song-item.dragging{opacity:.5}.song-item.drag-over{border-top:3px solid var(--primary-color)}.midi-controls{background:var(--surface);border-radius:24px;padding:30px;margin:0 auto;width:100%;max-width:1000px}.light-programming{margin-top:30px}.light-timeline{background:var(--surface-light);border-radius:12px;padding:20px;min-height:100px;margin-bottom:20px}.light-controls{display:flex;gap:15px}.note-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;margin-top:20px}.midi-note-btn{padding:12px;border-radius:8px;background:var(--surface-light);border:none;color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.midi-note-btn:hover{background:var(--primary-color);transform:translateY(-2px)}.midi-note-btn:active{transform:translateY(0)}footer{margin-top:auto;padding:20px;text-align:center}.install-prompt{color:var(--text-secondary);font-size:.85rem;padding:10px;background:var(--surface);border-radius:8px;cursor:pointer;transition:all .2s ease;display:inline-block}.install-prompt:hover{background:var(--surface-light);color:var(--text)}.setlist-detail-info{margin-bottom:30px}.setlist-summary{background:var(--surface);border-radius:16px;padding:20px;display:flex;gap:30px;flex-wrap:wrap;margin-bottom:20px}.summary-item{display:flex;flex-direction:column;gap:5px}.summary-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.summary-value{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.setlist-detail-songs{background:var(--surface);border-radius:16px;padding:20px}.detail-song-item{display:flex;gap:20px;padding:15px;border-bottom:1px solid var(--surface-light);page-break-inside:avoid}.detail-song-item:last-child{border-bottom:none}.detail-song-number{min-width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:var(--text);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.detail-song-info{flex:1}.detail-song-name{font-size:1.2rem;font-weight:600;margin-bottom:8px;color:var(--text)}.detail-song-meta{display:flex;gap:15px;flex-wrap:wrap;font-size:.9rem;color:var(--text-secondary)}.detail-song-meta span{padding:4px 8px;background:var(--surface-light);border-radius:6px}@media print{body{background:#fff;color:#000}.app-container{max-width:none}.nav-tabs,footer,.btn,#close-detail-btn,#print-setlist-btn{display:none!important}.view{padding:0;display:block!important}.setlist-detail-info,.setlist-detail-songs{background:#fff;box-shadow:none}.detail-song-item{border-bottom:1px solid #ccc;padding:10px 0}.detail-song-number{background:#000;color:#fff}.detail-song-name{color:#000}.detail-song-meta{color:#666}@page{margin:2cm}h1{color:#000!important;background:none!important;-webkit-text-fill-color:#000!important}}@media(max-width:1024px){.view{padding:15px}header{flex-direction:column;align-items:flex-start;gap:15px;margin-bottom:20px}header>div{width:100%;flex-wrap:wrap;gap:8px}.btn{font-size:.9rem;padding:10px 16px}.btn-small{padding:6px 12px;font-size:.85rem}}@media(max-width:768px){.nav-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-tab{font-size:.85rem;padding:14px 12px;white-space:nowrap;min-width:fit-content}h1{font-size:1.5rem}.view{padding:12px}.button-group{flex-direction:column;width:100%}.button-group .btn{width:100%}.form-actions{flex-direction:column;gap:10px}.form-actions .btn{width:100%}.modal-content{margin:10px;padding:20px;max-width:calc(100% - 20px);max-height:calc(100vh - 20px);overflow-y:auto}.modal-content h2{font-size:1.3rem}.song-card,.setlist-card{padding:15px}.tempo-wheel-controls{margin-top:12px}.performance-controls{gap:20px}.current-song-display{text-align:center}.bpm-display{font-size:1.5rem}.controls{flex-direction:column;gap:15px}.control-group{width:100%}.beat-pattern-selector{flex-wrap:wrap;gap:8px}.beat-btn{min-width:50px;padding:12px;font-size:1rem}.song-list,.song-checkbox-list{gap:10px}.song-item,.sortable-song-item{padding:12px;font-size:.9rem}.setlist-controls-bar{flex-direction:column;align-items:flex-start;gap:10px}header>div{flex-direction:column;align-items:stretch}header .btn{width:100%;margin:0}select{width:100%}.note-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:8px}.note-btn{padding:12px 8px;font-size:.85rem}.lyrics-display{font-size:1rem;padding:15px;max-height:40vh}.save-changes-section{flex-direction:column;align-items:stretch}.save-changes-section .btn{width:100%}.setlist-detail-info{padding:15px}.detail-song-item{flex-direction:column;align-items:flex-start;gap:10px}.midi-controls{flex-direction:column}#export-data-textarea,#import-data-textarea{min-height:150px;font-size:.75rem}}@media(max-width:480px){.nav-tab{padding:12px 10px;font-size:.8rem}h1{font-size:1.2rem}.view{padding:10px clamp(.5rem,2vw,1rem)}}@media(max-width:360px){.view{padding:.75rem .5rem 3.5rem;gap:1rem}header{padding:0 .5rem;margin-bottom:1rem}h1{font-size:1.1rem}.performance-mode-selector{max-width:calc(100vw - 1rem);padding:4px;gap:6px}.mode-btn{padding:10px 12px;font-size:.85rem}.current-setlist-section{padding:0 .5rem;gap:8px}.setlist-select{min-width:0;font-size:.9rem;padding:10px}.setlist-button{padding:10px 14px;font-size:.85rem}}@media(max-width:320px){.view{padding:.625rem .5rem 3rem;gap:.875rem}header{padding:0 .5rem;gap:8px}h1{font-size:1rem}.performance-mode-selector{max-width:calc(100vw - 1rem);margin-bottom:1rem}.mode-btn{padding:8px 10px;font-size:.8rem}.current-setlist-section{margin-bottom:1rem;gap:6px}.setlist-select{font-size:.85rem;padding:8px}.setlist-button{padding:8px 12px;font-size:.8rem}.bpm-display{font-size:1.2rem}.modal-content{padding:15px;margin:5px;max-width:calc(100% - 10px)}.song-card,.setlist-card{padding:12px}.btn{padding:10px 14px;font-size:.85rem}.beat-btn{min-width:45px;padding:10px;font-size:.9rem}.note-grid{grid-template-columns:repeat(auto-fill,minmax(45px,1fr))}}@media(max-width:360px){.beat-pattern-selector{gap:6px;padding:12px;margin:12px 0}.beat-btn{width:44px;height:44px;min-width:44px;font-size:1rem}.accent-controls{gap:8px;flex-wrap:wrap}.accent-controls .btn{flex:1 1 calc(50% - 4px);min-width:0}}@media(max-width:320px){.beat-pattern-selector{gap:4px;padding:10px;margin:10px 0}.beat-btn{width:calc((100% - 12px)/4);height:44px;min-width:0;max-width:50px;font-size:.95rem;padding:0}.accent-controls{gap:6px;flex-direction:column;align-items:stretch}.accent-controls .btn{flex:1 1 auto;font-size:.85rem;padding:.5rem .75rem;min-width:0;width:100%}.tempo-wheel{width:180px!important;height:180px!important}.tempo-wheel-container{margin:12px auto}.performance-controls{padding:.75rem!important;border-radius:.875rem}.setup-mode-container{max-width:100%;padding:.875rem .625rem 1rem}.modal-content{margin:10px!important;padding:1rem!important;max-width:calc(100vw - 20px)!important}.settings-input,.settings-select,.setlist-select{max-width:100%;box-sizing:border-box}}button{-webkit-user-select:none;-moz-user-select:none;user-select:none}.skip-link{position:absolute;top:-40px;left:0;background:var(--primary-color);color:#fff;padding:8px 16px;text-decoration:none;z-index:10000;border-radius:0 0 4px}.skip-link:focus{top:0;outline:3px solid var(--accent-cyan)}.view{width:100%;max-width:100vw;display:flex;flex-direction:column;align-items:center;padding:1.5rem clamp(.75rem,2vw,1rem) 4rem;gap:1.5rem;box-sizing:border-box;overflow-x:hidden;position:relative}@media(min-width:640px){.view{padding:2rem 2rem 4rem;gap:2rem}}@media(min-width:1024px){.view{padding:2.5rem 2.5rem 5rem;gap:2.25rem}}.pwa-update-button{position:fixed;bottom:20px;right:20px;padding:8px 12px;background:var(--surface-light);border:1px solid var(--border);border-radius:8px;font-size:.75rem;cursor:pointer;z-index:35;box-shadow:0 2px 8px #0003}@media(max-width:480px){.pwa-update-button{bottom:calc(88px + env(safe-area-inset-bottom));right:12px;z-index:30}}.auth-banner{position:fixed;top:0;left:0;right:0;z-index:50;background:linear-gradient(135deg,#6366f1e6,#0ea5e9e6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:.875rem clamp(.75rem,2vw,1rem);display:flex;align-items:center;justify-content:space-between;color:#fff;font-weight:700;box-shadow:0 4px 24px #00000080;border-bottom:2px solid rgba(255,255,255,.3);width:100%;max-width:100vw;overflow-x:hidden;box-sizing:border-box}.auth-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(99,102,241,.35),transparent 60%);pointer-events:none}.auth-banner>*{position:relative;z-index:1}@media(min-width:640px){.auth-banner{padding:.875rem 1.5rem}}.auth-banner-content{display:flex;align-items:center;gap:clamp(.5rem,1.5vw,.75rem);flex:1;min-width:0;flex-wrap:wrap;overflow:hidden}@media(max-width:480px){.auth-banner{padding:.75rem clamp(.5rem,2vw,.875rem);flex-direction:column;align-items:stretch;gap:.75rem}.auth-banner-content{width:100%;justify-content:space-between;gap:.5rem}.auth-button-group{width:100%;justify-content:flex-end;gap:.5rem}.auth-user-box{flex:1 1 auto;min-width:0;overflow:hidden}.auth-button{flex:0 0 auto;min-width:fit-content}}@media(max-width:360px){.auth-banner{padding:.625rem .5rem}.auth-user-name{font-size:.7rem;max-width:100px}.auth-button{padding:.5rem .75rem;font-size:.7rem}}.auth-user-box{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background-color:#ffffff26;border-radius:.75rem;border:1px solid rgba(255,255,255,.25);box-shadow:inset 0 2px 4px #0000001a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.auth-user-box .check-icon{font-size:1rem}@media(min-width:640px){.auth-user-box .check-icon{font-size:1.125rem}}.auth-user-name{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}@media(min-width:640px){.auth-user-name{font-size:.875rem;max-width:none}}.auth-separator{color:#fff6;font-size:1.125rem;display:none}@media(min-width:640px){.auth-separator{display:inline}}.auth-button{padding:.55rem 1.2rem;background:linear-gradient(135deg,#f4f4f5e6,#fff9);border-radius:999px;font-size:.8rem;font-weight:700;transition:all .25s ease;border:1px solid rgba(255,255,255,.45);box-shadow:0 6px 18px #0e749040;color:#1f2937;display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap;cursor:pointer}@media(min-width:640px){.auth-button{font-size:.875rem}}.auth-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0e74904d}.auth-button:active{transform:scale(.97)}.auth-button-group{display:flex;align-items:center;gap:.5rem;flex-shrink:0;justify-content:flex-end}.auth-button-icon{font-size:1.05rem}.auth-button-text{display:none}@media(min-width:640px){.auth-button-text{display:inline}}@media(max-width:480px){.auth-button{width:100%;justify-content:center;padding:.65rem 1.1rem;font-size:.85rem}.auth-button-group{width:100%;gap:.75rem}.auth-button-icon{font-size:1.15rem}}.login-modal-overlay{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-lg);animation:fadeIn .2s ease-out}.login-modal-content{position:relative;width:100%;max-width:480px;background:linear-gradient(160deg,#0a0e1afa,#121827fa,#1a2332fa);border:2px solid var(--accent-cyan-bold);border-radius:1.5rem;padding:var(--space-2xl);box-shadow:0 25px 80px #000000e6,0 0 0 1px #ffffff0d inset,var(--glow-cyan-intense);animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.login-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid rgba(0,217,255,.15)}.login-modal-title{font-size:2rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#00d9ff,#00f0ff,#09f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:var(--space-sm)}.login-modal-close{min-width:var(--touch-min);min-height:var(--touch-min);display:inline-flex;align-items:center;justify-content:center;border-radius:.75rem;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:var(--color-text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s ease}.login-modal-close:hover{background:#ff005526;border-color:var(--accent-danger);color:var(--accent-danger);transform:rotate(90deg)}.login-modal-form{display:flex;flex-direction:column;gap:var(--space-lg)}.login-modal-field{display:flex;flex-direction:column;gap:var(--space-sm)}.login-modal-label{font-size:.875rem;font-weight:600;letter-spacing:.02em;color:var(--accent-cyan);text-transform:uppercase}.login-modal-input{width:100%;min-height:var(--touch-min);padding:var(--space-md) var(--space-lg);border-radius:.75rem;background:#1a233299;border:2px solid rgba(0,217,255,.2);color:var(--color-text-primary);font-size:1rem;font-weight:500;transition:all .2s ease}.login-modal-input::placeholder{color:var(--color-text-secondary);opacity:.5}.login-modal-input:focus{outline:none;border-color:var(--accent-cyan-bold);background:#1a2332cc;box-shadow:0 0 0 3px #00d9ff1a,var(--glow-cyan)}.login-modal-input:hover:not(:focus){border-color:#00d9ff66}.login-modal-alert{padding:var(--space-md);border-radius:.75rem;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:var(--space-sm)}.login-modal-alert--success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.login-modal-alert--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.login-modal-submit{width:100%;min-height:var(--touch-min);padding:var(--space-md) var(--space-xl);border-radius:.75rem;border:2px solid var(--accent-cyan-bold);background:var(--action-primary);color:#fff;font-size:1rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:all .2s ease;box-shadow:var(--glow-cyan-strong);margin-top:var(--space-md)}.login-modal-submit:hover:not(:disabled){background:var(--action-primary-hover);border-color:var(--accent-cyan-bright);transform:translateY(-2px);box-shadow:var(--glow-cyan-intense)}.login-modal-submit:active:not(:disabled){transform:translateY(0)}.login-modal-submit:disabled{opacity:.5;cursor:not-allowed;background:var(--action-secondary);box-shadow:none}.login-modal-footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid rgba(0,217,255,.1);display:flex;flex-direction:column;gap:var(--space-md);align-items:center}.login-modal-toggle{font-size:.875rem;color:var(--color-text-secondary);text-align:center}.login-modal-toggle button{color:var(--accent-cyan);font-weight:700;text-decoration:none;cursor:pointer;background:none;border:none;padding:0;transition:all .2s ease}.login-modal-toggle button:hover{color:var(--accent-cyan-bright);text-decoration:underline}.login-modal-offline{width:100%;padding:var(--space-sm);font-size:.875rem;font-weight:600;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;transition:all .2s ease;text-align:center}.login-modal-offline:hover{color:var(--accent-cyan)}@media(max-width:640px){.login-modal-overlay{padding:var(--space-md)}.login-modal-content{padding:var(--space-xl)}.login-modal-title{font-size:1.5rem}}@media(max-width:360px){.login-modal-overlay{padding:var(--space-sm)}.login-modal-content{padding:var(--space-lg)}.login-modal-title{font-size:1.25rem}.login-modal-input{font-size:.875rem;padding:var(--space-sm) var(--space-md)}}.app-header{position:sticky;top:0;z-index:50;width:100%;background:linear-gradient(135deg,#0a0e1afa,#121827fa);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:2px solid var(--accent-cyan-bold);box-shadow:0 8px 32px #00000080,inset 0 1px #ffffff0d,var(--glow-cyan)}.app-header-content{max-width:80rem;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);gap:var(--space-md)}.app-header-brand-section{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}@media(max-width:768px){.app-header-brand-section{flex-direction:row;align-items:center;gap:var(--space-sm)}.app-header-status{display:none}}@media(max-width:640px){.app-header-content{padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.app-header-brand-text{font-size:1rem}}@media(max-width:480px){.app-header-content{padding:var(--space-sm);gap:var(--space-xs)}.app-header-menu-label{display:none}}@media(max-width:360px){.app-header-content{padding:var(--space-xs) var(--space-sm)}.app-header-brand-text{font-size:.9rem}}@media(max-width:320px){.app-header-content{padding:var(--space-xs);gap:var(--space-xs)}}.app-header-brand{display:flex;align-items:center;gap:var(--space-sm)}.app-header-logo{font-size:1.5rem;line-height:1;filter:drop-shadow(0 0 8px rgba(0,217,255,.6))}.app-header-brand-text{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#00d9ff,#00f0ff,#09f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px rgba(0,217,255,.3))}.app-header-status{font-size:.8rem;color:#e8eef5d9;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:640px){.app-header-logo{font-size:1.3rem}.app-header-brand-text{font-size:1.1rem}.app-header-status{font-size:.75rem}}@media(max-width:480px){.app-header-logo{font-size:1.2rem}.app-header-brand-text{font-size:1rem}.app-header-status{font-size:.7rem}}@media(max-width:360px){.app-header-brand{gap:var(--space-xs)}.app-header-logo{font-size:1.1rem}.app-header-brand-text{font-size:.95rem}.app-header-status{font-size:.65rem}}@media(max-width:320px){.app-header-brand{gap:var(--space-xs)}.app-header-logo{font-size:1rem}.app-header-brand-text{font-size:.9rem}.app-header-status{font-size:.6rem}}.app-header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}@media(max-width:640px){.app-header-actions{gap:var(--space-xs)}}.app-header-user{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:999px;background:#00d9ff1a;border:1px solid rgba(0,217,255,.3)}.app-header-user-text{display:flex;align-items:center;gap:var(--space-xs);font-size:.85rem;color:var(--text-primary);font-weight:600}.app-header-user-icon{font-size:1rem}@media(max-width:480px){.app-header-user-text{font-size:.75rem}}.app-header-auth-button{min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);border-radius:.75rem;border:2px solid var(--accent-cyan-bold);background:var(--action-secondary);color:var(--accent-cyan-bright);font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;transition:all .2s ease;cursor:pointer}.app-header-auth-button:hover{background:var(--action-secondary-hover);border-color:var(--accent-cyan-bright);transform:translateY(-1px);box-shadow:var(--glow-cyan)}.app-header-auth-button:active{transform:translateY(0)}.app-header-auth-button:focus-visible{outline:3px solid var(--accent-cyan-bright);outline-offset:2px}@media(max-width:640px){.app-header-auth-button{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}}.app-header-session-indicator{min-height:var(--touch-min);display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:999px;background:#22c55e26;border:1px solid rgba(34,197,94,.4);color:var(--accent-green);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.app-header-session-indicator:hover{background:#22c55e40;border-color:#22c55e99;transform:translateY(-1px)}.app-header-session-indicator:focus-visible{outline:3px solid var(--accent-green);outline-offset:2px}.app-header-menu-button{min-height:var(--touch-min);display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:.75rem;border:2px solid var(--accent-cyan-bold);background:var(--action-primary);color:#fff;font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;box-shadow:var(--glow-cyan);transition:all .2s ease;cursor:pointer}.app-header-menu-button:hover{background:var(--action-primary-hover);border-color:var(--accent-cyan-bright);transform:translateY(-1px);box-shadow:var(--glow-cyan-intense)}.app-header-menu-button:active{transform:translateY(0)}.app-header-menu-button:focus-visible{outline:3px solid var(--accent-cyan-bright);outline-offset:2px}.app-header-menu-icon{font-size:1.2rem;line-height:1}.app-header-menu-label{font-size:.85rem}@media(max-width:640px){.app-header-menu-button{padding:var(--space-xs) var(--space-sm);font-size:.75rem}.app-header-menu-icon{font-size:1rem}}.nav-menu-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-xl);overflow-y:auto}@media(max-width:640px){.nav-menu-overlay{padding:var(--space-md)}}.nav-menu-dropdown{background:linear-gradient(135deg,#0a0e1afa,#121827fa);border:2px solid var(--accent-cyan-bold);border-radius:1.5rem;box-shadow:0 20px 60px #000c,var(--glow-cyan-intense);max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:menuSlideIn .2s ease-out}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.nav-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid rgba(0,217,255,.2);background:#00d9ff0d}.nav-menu-title{font-size:1.25rem;font-weight:800;color:var(--accent-cyan-bright);margin:0}.nav-menu-close{min-height:var(--touch-min);min-width:var(--touch-min);display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:var(--text-primary);font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s ease}.nav-menu-close:hover{background:#f053;border-color:var(--accent-danger);color:var(--accent-danger)}.nav-menu-content{padding:var(--space-md);overflow-y:auto;flex:1}.nav-menu-group{margin-bottom:var(--space-lg)}.nav-menu-group:last-child{margin-bottom:0}.nav-menu-group-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#00d9ff14;border-radius:.75rem;border:1px solid rgba(0,217,255,.2);margin-bottom:var(--space-sm)}.nav-menu-group-icon{font-size:1.5rem;line-height:1}.nav-menu-group-text{display:flex;flex-direction:column;gap:var(--space-xs)}.nav-menu-group-label{font-size:.9rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-cyan-bright)}.nav-menu-group-helper{font-size:.75rem;color:var(--text-secondary)}.nav-menu-group-items{display:flex;flex-direction:column;gap:var(--space-xs)}.nav-menu-item{min-height:var(--touch-min);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:.75rem;border:1px solid rgba(0,217,255,.15);background:#1a233280;color:var(--text-primary);text-align:left;transition:all .2s ease;cursor:pointer}.nav-menu-item:hover{background:#00d9ff1a;border-color:var(--accent-cyan-bold);transform:translate(4px)}.nav-menu-item.active{background:var(--action-primary);border-color:var(--accent-cyan-bright);box-shadow:var(--glow-cyan)}.nav-menu-item.primary{border-color:var(--accent-cyan-bold);background:linear-gradient(135deg,#00d9ff26,#0099ff1a)}.nav-menu-item.primary:hover{background:var(--action-primary);box-shadow:var(--glow-cyan-strong)}.nav-menu-item-icon{font-size:1.5rem;line-height:1;flex-shrink:0}.nav-menu-item-text{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0}.nav-menu-item-label{font-size:.9rem;font-weight:700;color:var(--text-primary)}.nav-menu-item-description{font-size:.75rem;color:var(--text-secondary)}.nav-menu-item-action{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-cyan);padding:var(--space-xs) var(--space-sm);border-radius:.5rem;background:#00d9ff1a;border:1px solid rgba(0,217,255,.3);flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.main-nav{width:100%;max-width:100vw;overflow-x:hidden}.main-nav-container{display:flex;max-width:80rem;width:100%;margin:0 auto;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.main-nav-container::-webkit-scrollbar{display:none}.main-nav-button{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:64px;padding:.75rem clamp(.5rem,2vw,1rem);gap:.375rem;font-size:.875rem;font-weight:700;transition:all .2s ease;border:none;background:transparent;cursor:pointer;color:#8b92a8;text-decoration:none;outline:none;overflow:hidden}.main-nav-button:hover{background-color:#1a233280;color:#e8eef5}.main-nav-button:focus{outline:2px solid #00d9ff;outline-offset:2px}.main-nav-button:active{transform:scale(.95)}.main-nav-button.active{color:var(--accent-cyan);background-color:var(--accent-cyan-soft);border-bottom:4px solid var(--accent-cyan);box-shadow:0 0 15px #00d9ff4d}.main-nav-button.inactive{border-bottom:2px solid transparent}.main-nav-button.inactive:hover{border-bottom-color:#00d9ff33}.main-nav--header{position:relative;padding:.1rem}.main-nav--header:before,.main-nav--header:after{content:"";position:absolute;inset:-.25rem;border-radius:1.4rem;background:conic-gradient(from 140deg,#00d9ff24,#7850ff14,#00d9ff24);filter:blur(20px);opacity:.4;pointer-events:none;animation:navAura 6s ease-in-out infinite}.main-nav--header:after{inset:-.15rem;background:linear-gradient(135deg,#00d9ff33,#147dff1f);filter:blur(15px);opacity:.32;animation:navAura 8s ease-in-out infinite reverse}.main-nav--header .main-nav-container{position:relative;z-index:1;display:flex;flex-wrap:wrap;align-items:stretch;gap:var(--space-md);padding:var(--space-md);background:linear-gradient(135deg,#081220f0,#0d1e30f5);border-radius:1.15rem;border:1px solid rgba(0,217,255,.22);box-shadow:inset 0 1px #ffffff0d,0 10px 26px #00d9ff1f;overflow:visible}.main-nav--header .main-nav-group{display:flex;flex-direction:column;gap:var(--space-sm);flex:1 1 230px;min-width:220px;padding:var(--space-md);border-radius:1rem;background:#0b1a2da6;border:1px solid rgba(0,217,255,.15);box-shadow:inset 0 1px #ffffff0d}.main-nav--header .main-nav-group-header{display:flex;align-items:center;gap:.55rem}.main-nav--header .main-nav-group-icon{font-size:1.1rem;line-height:1;color:var(--accent-cyan)}.main-nav--header .main-nav-group-text{display:flex;flex-direction:column;gap:.15rem}.main-nav--header .main-nav-group-label{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#89c5ffe6}.main-nav--header .main-nav-group-helper{font-size:.68rem;color:#add1ffad}.main-nav--header .main-nav-group-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.4rem .45rem}.main-nav-item-wrapper{display:flex;flex-direction:column;gap:.35rem}.main-nav-action{align-self:flex-start;min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);border-radius:.75rem;border:2px solid var(--accent-cyan-bold);background:var(--action-primary);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;box-shadow:var(--glow-cyan-strong);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;cursor:pointer}.main-nav-action:hover{transform:translateY(-2px) scale(1.03);background:var(--action-primary-hover);border-color:var(--accent-cyan-bright);box-shadow:var(--glow-cyan-intense)}.main-nav-action:active{transform:translateY(0) scale(.98)}.main-nav--header .main-nav-container:before{content:"";position:absolute;inset:.25rem;border-radius:1rem;background:radial-gradient(circle at 25% 25%,rgba(0,217,255,.12),transparent 60%),radial-gradient(circle at 75% 15%,rgba(0,118,255,.12),transparent 55%);opacity:.35;pointer-events:none}.main-nav-button--header{position:relative;flex:unset;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);gap:var(--space-xs);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--accent-cyan-soft);border-radius:.85rem;background:linear-gradient(135deg,#122238e0,#101c34e0);color:#e8eef5;box-shadow:0 6px 18px #040e1c47;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,color .18s ease;overflow:hidden;cursor:pointer}.main-nav-button--header.is-primary{background:var(--action-primary);border-color:var(--accent-cyan-bright);color:#fff;font-weight:700;box-shadow:var(--glow-cyan-intense);animation:primaryPulse 3s ease-in-out infinite}.main-nav-button--header.is-primary:hover{background:var(--action-primary-hover);transform:translateY(-3px) scale(1.02);box-shadow:0 0 50px #00d9ffe6,0 0 100px #00d9ff80}.main-nav-button--header.is-primary:after{content:"";position:absolute;inset:1px;border-radius:inherit;border:1px solid rgba(255,255,255,.3);pointer-events:none}@keyframes primaryPulse{0%,to{box-shadow:var(--glow-cyan-intense)}50%{box-shadow:0 0 50px #00d9ffe6,0 0 100px #00d9ff80}}.main-nav-button--header:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle,rgba(0,217,255,.3),transparent 60%);opacity:0;transition:opacity .2s ease}.main-nav-button--header:hover{transform:translateY(-2px);border-color:var(--accent-cyan-bold);box-shadow:0 12px 24px #00d9ff2e;color:var(--accent-cyan-bright)}.main-nav-button--header:hover:before{opacity:.35}.main-nav-button--header:active{transform:translateY(0)}.main-nav-button--header:focus-visible{outline:3px solid var(--accent-cyan-bright);outline-offset:2px}.main-nav--header .main-nav-button.active{border-bottom:none;border-color:var(--accent-cyan-bold);background:linear-gradient(135deg,#00d9ff40,#09264aeb);box-shadow:0 14px 28px #00d9ff38,inset 0 1px #ffffff1f;color:var(--accent-cyan)}.main-nav--header .main-nav-button.active:after{content:"";position:absolute;inset:1px;border-radius:inherit;border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 0 20px #00d9ff33;pointer-events:none}.main-nav--header .main-nav-button.inactive{border-bottom:none}.main-nav--header .main-nav-icon{font-size:1rem}.main-nav--header .main-nav-label{font-size:.68rem;letter-spacing:.05em}@keyframes navAura{0%{transform:rotate(0);opacity:.35}50%{opacity:.7}to{transform:rotate(360deg);opacity:.35}}@media(max-width:1024px){.main-nav--header .main-nav-container{gap:.7rem}.main-nav--header .main-nav-group{flex:1 1 calc(50% - .7rem);min-width:200px}}@media(max-width:767px){.main-nav--header:before,.main-nav--header:after{inset:-.2rem}.main-nav--header .main-nav-container{flex-direction:column;gap:.55rem;padding:.45rem .6rem}.main-nav-button--header{min-height:40px;font-size:.68rem}.main-nav--header .main-nav-group{min-width:100%;padding:.6rem .65rem .75rem}.main-nav--header .main-nav-group-items{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media(max-width:520px){.main-nav-button--header{padding:.55rem .75rem}.main-nav--header .main-nav-group-items{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:360px){.main-nav--header .main-nav-container{gap:.35rem}.main-nav-button--header{font-size:.63rem}.main-nav--header .main-nav-group-items{grid-template-columns:repeat(1,minmax(0,1fr))}}@media(max-width:320px){.main-nav--header .main-nav-group-items{grid-template-columns:repeat(1,minmax(0,1fr))}}.main-nav-icon{font-size:1.125rem;line-height:1}.main-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.more-drawer{position:fixed;inset:0;background:#0006;display:flex;align-items:flex-end;z-index:50}.more-drawer-content{width:100%;background:#0a101efa;border-top:1px solid rgba(0,217,255,.25);box-shadow:0 -14px 30px #00000073;padding:12px;display:grid;gap:8px}.more-item{display:flex;align-items:center;gap:10px;padding:12px 10px;border-radius:10px;background:#1a233299;color:#e8eef5;border:1px solid rgba(0,217,255,.2)}.more-item:active{transform:scale(.98)}.more-icon{font-size:1rem}.more-label{font-size:.9rem;font-weight:600}.more-sep{border:none;border-top:1px solid rgba(255,255,255,.08);margin:6px 0}@media(max-width:767px){.main-nav-container{padding:0}.main-nav-button{min-height:54px;padding:.5rem clamp(.25rem,1.5vw,.5rem);gap:.125rem;font-size:clamp(.65rem,2.5vw,.75rem);flex:1 1 auto;min-width:0}.main-nav-icon{font-size:clamp(.875rem,3vw,1rem)}.main-nav-label{font-size:clamp(.6rem,2vw,.7rem)}.main-nav-button.active{border-bottom:none;border-top:2px solid #00d9ff}.main-nav-button.inactive:hover{border-bottom:none;border-top:2px solid rgba(0,217,255,.2)}}@media(max-width:360px){.main-nav-button{padding:.5rem .25rem;font-size:.65rem}.main-nav-icon{font-size:.875rem}.main-nav-label{font-size:.6rem}}@media(max-width:320px){.main-nav-button{min-height:48px;padding:.4rem .2rem;gap:.1rem;font-size:.6rem}.main-nav-icon{font-size:.8rem}.main-nav-label{font-size:.55rem}}.page-header{position:sticky;top:56px;z-index:35;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);background:linear-gradient(135deg,#0a0e1afa,#121827fa);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:2px solid var(--accent-cyan-bold);box-shadow:0 8px 32px #00000080,inset 0 1px #ffffff0d,var(--glow-cyan);margin-bottom:0}.page-header-main{display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.page-header-text{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0}.page-header-subtitle{font-size:.75rem;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.15em;font-weight:700}.page-header-title{font-size:2.5rem;font-weight:900;background:linear-gradient(135deg,#00d9ff,#00f0ff,#09f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1;letter-spacing:-.03em;filter:drop-shadow(0 0 20px rgba(0,217,255,.3))}.page-header-status{font-size:.9rem;color:var(--text-primary);font-weight:600;padding:var(--space-sm) var(--space-md);border-radius:999px;background:#00d9ff1a;border:1px solid rgba(0,217,255,.3);white-space:nowrap}.page-header-actions{display:flex;gap:var(--space-sm);align-items:center;flex-shrink:0}.page-header-settings{min-height:var(--touch-min);display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:.75rem;background:#00d9ff1a;border:2px solid var(--accent-cyan-bold);color:var(--accent-cyan-bright);font-size:.85rem;font-weight:700;transition:all .2s ease;cursor:pointer}.page-header-settings:hover{background:var(--action-primary);border-color:var(--accent-cyan-bright);transform:translateY(-1px);box-shadow:var(--glow-cyan);color:#fff}.page-header-settings:active{transform:translateY(0)}.page-header-settings:focus-visible{outline:3px solid var(--accent-cyan-bright);outline-offset:2px}.page-header-settings-icon{font-size:1.1rem;line-height:1}.page-header-settings-label{font-size:.85rem;letter-spacing:.05em;text-transform:uppercase}@media(max-width:768px){.page-header{padding:var(--space-md) var(--space-lg);top:56px}.page-header-title{font-size:2rem}.page-header-status{font-size:.8rem}}@media(max-width:640px){.page-header{padding:var(--space-md)}.page-header-main{gap:var(--space-md)}.page-header-title{font-size:1.75rem}.page-header-subtitle{font-size:.7rem}.page-header-status{font-size:.75rem;padding:var(--space-xs) var(--space-sm)}.page-header-settings{padding:var(--space-xs) var(--space-sm);font-size:.75rem}.page-header-settings-label{display:none}}@media(max-width:480px){.page-header{padding:var(--space-sm)}.page-header-title{font-size:1.5rem}.page-header-main{flex-direction:column;align-items:flex-start}.page-header-status{align-self:stretch;text-align:center}.page-header-actions{align-self:stretch;justify-content:center}}@media(max-width:360px){.page-header{padding:var(--space-sm) var(--space-sm)}.page-header-title{font-size:1.3rem}.page-header-subtitle{font-size:.65rem}}@media(max-width:320px){.page-header{padding:var(--space-xs) var(--space-xs)}.page-header-title{font-size:1.2rem}.page-header-main{gap:var(--space-sm)}}.dashboard-nav-tile{position:relative;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xl);min-height:140px;text-align:left;background:linear-gradient(135deg,#1a233299,#121827cc);border:2px solid rgba(0,217,255,.2);border-radius:1.25rem;color:var(--color-text-primary);cursor:pointer;overflow:hidden;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 12px 32px #00000073}.dashboard-nav-tile:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(0,217,255,.1),transparent 70%);opacity:0;transition:opacity .3s ease}.dashboard-nav-tile:after{content:"";position:absolute;inset:-120%;background:conic-gradient(from 90deg,transparent 0deg,rgba(0,217,255,.12) 90deg,transparent 180deg,rgba(0,217,255,.12) 270deg,transparent 360deg);opacity:0;transition:opacity .4s ease;pointer-events:none}.dashboard-nav-tile:hover{transform:translateY(-4px) scale(1.02);border-color:var(--accent-cyan-bold);box-shadow:var(--glow-cyan-strong),0 16px 36px #0000008c}.dashboard-nav-tile:hover:after{opacity:.4}.dashboard-nav-tile.is-active{border-color:var(--accent-cyan-bold);box-shadow:var(--glow-cyan-intense),0 20px 40px #0009;background:linear-gradient(135deg,#0e1e33f2,#122c44f2)}.dashboard-nav-icon{font-size:2.3rem;line-height:1;filter:drop-shadow(0 0 10px rgba(0,217,255,.3))}.dashboard-nav-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-nav-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.dashboard-nav-header h3{margin:0;font-size:1.15rem;font-weight:700;letter-spacing:-.01em}.dashboard-nav-stats{font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-cyan);padding:var(--space-xs) var(--space-sm);background:#00d9ff1f;border:1px solid rgba(0,217,255,.3);border-radius:999px}.dashboard-nav-description{margin:0;font-size:.9rem;line-height:1.6;color:var(--color-text-secondary)}.dashboard-nav-action{position:relative;align-self:flex-start;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-cyan);padding:var(--space-xs) var(--space-md);background:#00d9ff1f;border:1px solid rgba(0,217,255,.35);border-radius:.5rem;transition:all .2s ease}.dashboard-nav-tile:hover .dashboard-nav-action,.dashboard-nav-tile.is-active .dashboard-nav-action{background:#00d9ff33;border-color:var(--accent-cyan-bold);box-shadow:0 0 14px #00d9ff4d}@media(max-width:640px){.dashboard-nav-tile{min-height:120px;padding:var(--space-lg)}.dashboard-nav-icon{font-size:2rem}}@media(max-width:360px){.dashboard-nav-tile{min-height:110px;padding:var(--space-md);border-width:1.5px;border-radius:1rem}.dashboard-nav-icon{font-size:1.75rem}.dashboard-nav-header h3{font-size:1rem}.dashboard-nav-description{font-size:.8rem}.dashboard-nav-action{font-size:.7rem;padding:.25rem var(--space-sm)}}.dashboard-status-card{position:relative;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xl);min-height:170px;border-radius:1.25rem;border:2px solid rgba(0,217,255,.22);background:linear-gradient(135deg,#1a233280,#121827b3);box-shadow:0 14px 32px #00000073,inset 0 1px #ffffff08;color:var(--color-text-primary);overflow:hidden}.dashboard-status-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);opacity:.6}.dashboard-status-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(0,217,255,.1),transparent 70%);opacity:0;transition:opacity .3s ease}.dashboard-status-card:hover{border-color:var(--accent-cyan-bold);box-shadow:var(--glow-cyan-strong),0 18px 40px #0000008c}.dashboard-status-card:hover:after{opacity:1}.dashboard-status-card.tone-success{border-color:#22c55e59}.dashboard-status-card.tone-success:before{background:linear-gradient(90deg,transparent,rgba(34,197,94,.9),transparent)}.dashboard-status-card.tone-warning{border-color:#f59e0b66}.dashboard-status-card.tone-warning:before{background:linear-gradient(90deg,transparent,rgba(245,158,11,.9),transparent)}.dashboard-status-metric{display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-status-value{font-size:2.5rem;font-weight:800;letter-spacing:-.02em;color:var(--color-text-primary);line-height:1}.dashboard-status-card.tone-success .dashboard-status-value{color:#22c55e;text-shadow:0 0 22px rgba(34,197,94,.6)}.dashboard-status-card.tone-warning .dashboard-status-value{color:#f59e0b;text-shadow:0 0 22px rgba(245,158,11,.6)}.dashboard-status-title{font-size:.875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-cyan)}.dashboard-status-meta{margin:0;font-size:.875rem;color:var(--color-text-secondary);flex:1}.dashboard-status-button{align-self:flex-start;min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);border-radius:.75rem;border:2px solid rgba(0,217,255,.28);background:#00d9ff1f;color:var(--accent-cyan);font-size:.875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s ease}.dashboard-status-button:hover{background:#00d9ff2e;border-color:var(--accent-cyan-bold);box-shadow:0 0 18px #00d9ff4d}.dashboard-status-button:active{transform:translateY(1px)}@media(max-width:480px){.dashboard-status-card{padding:var(--space-lg)}.dashboard-status-value{font-size:2rem}}@media(max-width:360px){.dashboard-status-card{padding:var(--space-md);gap:var(--space-sm);border-width:1.5px;border-radius:1rem}.dashboard-status-card:before{height:2px}.dashboard-status-value{font-size:1.75rem}.dashboard-status-title,.dashboard-status-meta,.dashboard-status-button{font-size:.8rem}.dashboard-status-button{min-height:40px;padding:var(--space-xs) var(--space-sm);border-width:1.5px}}.dashboard-quick-action{position:relative;width:100%;min-height:var(--touch-min);display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);text-align:left;background:linear-gradient(135deg,#1a233273,#121827a6);border:2px solid rgba(0,217,255,.18);border-radius:1.25rem;color:var(--color-text-primary);cursor:pointer;transition:all .3s ease;overflow:hidden;box-shadow:0 10px 28px #00000073}.dashboard-quick-action:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,217,255,.08),transparent 70%);opacity:0;transition:opacity .3s ease}.dashboard-quick-action:hover{border-color:var(--accent-cyan-bold);transform:translate(6px);box-shadow:0 14px 32px #00000080,0 0 24px #00d9ff33}.dashboard-quick-icon{font-size:2.1rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(0,217,255,.3))}.dashboard-quick-label{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.dashboard-quick-description{margin:0;font-size:.875rem;line-height:1.55;color:var(--color-text-secondary)}.dashboard-quick-chevron{font-size:1.6rem;color:var(--accent-cyan);flex-shrink:0;transition:transform .3s ease}.dashboard-quick-action:hover .dashboard-quick-chevron{transform:translate(6px)}@media(max-width:640px){.dashboard-quick-action{padding:var(--space-lg)}.dashboard-quick-icon{font-size:1.8rem}}@media(max-width:360px){.dashboard-quick-action{min-height:60px;padding:var(--space-md);gap:var(--space-md);border-width:1.5px;border-radius:1rem;transform:none}.dashboard-quick-icon{font-size:1.6rem}.dashboard-quick-label{font-size:.95rem}.dashboard-quick-description{font-size:.8rem}.dashboard-quick-chevron{font-size:1.2rem}}.dashboard-view{display:flex;flex-direction:column;gap:var(--space-2xl);padding:var(--space-2xl) var(--space-xl);min-height:calc(100vh - 10rem)}.dashboard-hero{display:flex;flex-direction:column;gap:var(--space-xl);background:linear-gradient(135deg,#0a0e1a66,#12182799 40%,#1a2332cc);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(0,217,255,.3);border-radius:2rem;padding:var(--space-2xl);box-shadow:0 30px 90px #0009,0 0 0 1px #ffffff08 inset,0 0 60px #00d9ff26,0 0 120px #00d9ff14;position:relative;overflow:hidden;transition:all .5s ease}.dashboard-hero:hover{border-color:var(--accent-cyan-bold);box-shadow:0 35px 100px #000000b3,0 0 0 1px #ffffff0d inset,0 0 80px #00d9ff40,0 0 140px #00d9ff1f}.dashboard-hero:before{content:"";position:absolute;inset:-100%;background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(0,217,255,.15) 60deg,rgba(0,153,255,.1) 120deg,transparent 180deg,rgba(0,217,255,.15) 240deg,rgba(0,153,255,.1) 300deg,transparent 360deg);pointer-events:none;z-index:0;animation:heroRotate 20s linear infinite;opacity:.3}.dashboard-hero:after{content:"";position:absolute;top:-50%;right:-30%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,217,255,.2) 0%,rgba(0,217,255,.1) 30%,transparent 70%);pointer-events:none;z-index:0;animation:heroGlow 12s ease-in-out infinite;filter:blur(40px)}@keyframes heroRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes heroGlow{0%,to{opacity:.4;transform:translate(0) scale(1)}33%{opacity:.7;transform:translate(-40px,40px) scale(1.15)}66%{opacity:.5;transform:translate(20px,-20px) scale(.95)}}.dashboard-hero-body{display:flex;flex-direction:column;gap:var(--space-xl);position:relative;z-index:1}.dashboard-hero-text{display:flex;flex-direction:column;gap:var(--space-md);max-width:680px}.dashboard-hero-greeting{font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-cyan);text-shadow:0 0 20px rgba(0,217,255,.5)}.dashboard-hero-subtitle{font-size:.8rem;letter-spacing:.05em;color:var(--color-text-secondary);line-height:1.6}.dashboard-hero-title{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#00d9ff,#00f0ff,#09f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:var(--space-sm) 0}.dashboard-hero-description{font-size:1.05rem;line-height:1.7;color:var(--color-text-primary);max-width:600px;opacity:.9}.dashboard-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-sm)}.dashboard-primary-cta{min-height:var(--touch-min);font-size:1rem;font-weight:700;padding:var(--space-md) var(--space-xl);letter-spacing:.03em;text-transform:uppercase}.dashboard-secondary-cta{min-height:var(--touch-min);font-size:1rem;font-weight:600;padding:var(--space-md) var(--space-lg)}.dashboard-hero-status{display:inline-flex;align-items:center;gap:var(--space-sm);border-radius:999px;background:linear-gradient(135deg,#0a0e1ae6,#121827f2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(0,217,255,.4);padding:var(--space-sm) var(--space-lg);font-size:.875rem;font-weight:600;color:var(--color-text-primary);width:fit-content;position:relative;z-index:1;box-shadow:0 4px 16px #0006,inset 0 1px #ffffff0d,0 0 20px #00d9ff26;transition:all .3s ease}.dashboard-hero-status:hover{border-color:var(--accent-cyan-bold);box-shadow:0 6px 20px #00000080,inset 0 1px #ffffff14,0 0 30px #00d9ff40;transform:translateY(-1px)}.dashboard-status-indicator{width:10px;height:10px;border-radius:50%;background:var(--accent-cyan);box-shadow:0 0 #00d9ff99,0 0 8px #00d9ffcc,inset 0 0 4px #ffffff80;animation:dashboardPulse 2s ease-in-out infinite;position:relative}.dashboard-status-indicator:after{content:"";position:absolute;inset:-2px;border-radius:50%;background:radial-gradient(circle,rgba(0,217,255,.4),transparent 70%);animation:dashboardPulseRing 2s ease-in-out infinite}.dashboard-nav-section{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-nav-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg)}.dashboard-nav-tile{min-height:140px;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xl);background:linear-gradient(135deg,#1a233299,#121827cc);border:2px solid rgba(0,217,255,.2);border-radius:1.25rem;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;text-align:left}.dashboard-nav-tile:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(0,217,255,.08),transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.dashboard-nav-tile:hover{transform:translateY(-4px) scale(1.02);border-color:var(--accent-cyan-bold);box-shadow:var(--glow-cyan-strong),0 12px 32px #00000080}.dashboard-nav-tile:hover:before{opacity:1}.dashboard-resume-section{display:flex}.dashboard-resume-card{display:flex;flex-wrap:wrap;gap:var(--space-xl);width:100%;background:linear-gradient(135deg,#1a233299,#121827cc);border:2px solid rgba(0,217,255,.25);border-radius:1.5rem;padding:var(--space-2xl);box-shadow:0 12px 40px #0009,inset 0 1px #ffffff08;position:relative;overflow:hidden}.dashboard-resume-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at bottom left,rgba(0,217,255,.06),transparent 60%);pointer-events:none}.dashboard-resume-card.empty{background:linear-gradient(135deg,#12182780,#1a233280);border-color:#00d9ff26}.dashboard-resume-content{flex:1 1 320px;display:flex;flex-direction:column;gap:var(--space-md);color:var(--color-text-primary);position:relative;z-index:1}.resume-badge{width:fit-content;padding:var(--space-xs) var(--space-md);border-radius:999px;background:#00d9ff26;border:1px solid rgba(0,217,255,.4);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-cyan);box-shadow:0 0 12px #00d9ff33}.dashboard-resume-content h2{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:800;letter-spacing:-.02em;margin:0;color:var(--color-text-primary)}.dashboard-resume-content p{font-size:1rem;color:var(--color-text-secondary);margin:0}.dashboard-resume-actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-sm)}.dashboard-resume-actions .btn{min-height:var(--touch-min);font-weight:600}.dashboard-resume-actions .btn-ghost{border:2px solid rgba(0,217,255,.3);background:transparent;color:var(--accent-cyan);transition:all .2s ease}.dashboard-resume-actions .btn-ghost:hover{background:#00d9ff1a;border-color:var(--accent-cyan-bold);box-shadow:0 0 16px #00d9ff4d}.dashboard-resume-meta{flex:1 1 280px;display:grid;gap:var(--space-md);padding:var(--space-xl);background:#0a0e1acc;border-radius:1.25rem;border:2px solid rgba(0,217,255,.15);box-shadow:inset 0 2px 8px #0000004d;position:relative;z-index:1}.resume-meta-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid rgba(0,217,255,.1)}.resume-meta-row:last-child{border-bottom:none;padding-bottom:0}.resume-meta-label{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-cyan)}.resume-meta-value{font-size:.95rem;font-weight:700;color:var(--color-text-primary)}.dashboard-quick-section{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.dashboard-quick-action{min-height:var(--touch-min);display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);background:linear-gradient(135deg,#1a233266,#12182799);border:2px solid rgba(0,217,255,.15);border-radius:1.25rem;cursor:pointer;transition:all .3s ease;text-align:left;position:relative;overflow:hidden}.dashboard-quick-action:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,217,255,.05),transparent);opacity:0;transition:opacity .3s ease;pointer-events:none}.dashboard-quick-action:hover{border-color:var(--accent-cyan-bold);transform:translate(4px);box-shadow:0 8px 24px #0006,0 0 20px #00d9ff33}.dashboard-quick-action:hover:before{opacity:1}.dashboard-quick-icon{font-size:2rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(0,217,255,.3))}.dashboard-quick-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-quick-label{font-size:1.05rem;font-weight:700;color:var(--color-text-primary);letter-spacing:-.01em}.dashboard-quick-description{font-size:.875rem;line-height:1.5;color:var(--color-text-secondary);margin:0}.dashboard-quick-chevron{font-size:1.5rem;color:var(--accent-cyan);flex-shrink:0;transition:transform .3s ease}.dashboard-quick-action:hover .dashboard-quick-chevron{transform:translate(4px)}.dashboard-status-section{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg)}@keyframes dashboardPulse{0%,to{box-shadow:0 0 #00d9ff99,0 0 8px #00d9ffcc,inset 0 0 4px #ffffff80;transform:scale(1)}50%{box-shadow:0 0 0 4px #00d9ff00,0 0 12px #00d9ff,inset 0 0 6px #ffffffb3;transform:scale(1.1)}}@keyframes dashboardPulseRing{0%{transform:scale(1);opacity:.8}50%{transform:scale(2.5);opacity:0}to{transform:scale(1);opacity:0}}@media(max-width:768px){.dashboard-view{padding-bottom:8rem;gap:var(--space-xl)}.dashboard-hero{padding:var(--space-xl)}.dashboard-hero-actions{flex-direction:column;align-items:stretch}.dashboard-hero-actions .btn,.dashboard-hero-status{width:100%;justify-content:center}.dashboard-resume-card{flex-direction:column}.dashboard-resume-meta{width:100%}.dashboard-nav-grid,.dashboard-status-grid{grid-template-columns:1fr}}@media(max-width:640px){.dashboard-view{padding:var(--space-xl) var(--space-md)}.dashboard-hero-title{font-size:1.75rem}.dashboard-hero-description{font-size:.95rem}.dashboard-nav-tile{min-height:120px;padding:var(--space-lg)}.dashboard-nav-icon{font-size:2rem}.dashboard-quick-grid{grid-template-columns:1fr}}@media(max-width:480px){.dashboard-view{padding:var(--space-lg) var(--space-sm);gap:var(--space-lg)}.dashboard-hero{padding:var(--space-lg);gap:var(--space-lg)}.dashboard-hero-body{gap:var(--space-lg)}.dashboard-hero-title{font-size:1.5rem}.dashboard-resume-card{padding:var(--space-lg)}.dashboard-resume-content h2{font-size:1.5rem}}@media(max-width:360px){.dashboard-view{padding:var(--space-md) var(--space-xs);gap:var(--space-md)}.dashboard-hero{padding:var(--space-md);gap:var(--space-md);border-width:1.5px;border-radius:1rem}.dashboard-hero-body{gap:var(--space-md)}.dashboard-hero-text{gap:var(--space-sm)}.dashboard-hero-greeting{font-size:.7rem}.dashboard-hero-subtitle{font-size:.75rem}.dashboard-hero-title{font-size:1.35rem;margin:var(--space-xs) 0}.dashboard-hero-description{font-size:.875rem;line-height:1.6}.dashboard-hero-actions{gap:var(--space-sm)}.dashboard-primary-cta,.dashboard-secondary-cta{padding:var(--space-sm) var(--space-md);font-size:.9rem}.dashboard-hero-status{padding:var(--space-xs) var(--space-md);font-size:.8rem}.dashboard-resume-card{padding:var(--space-md);gap:var(--space-md);border-width:1.5px;border-radius:1rem}.dashboard-resume-content{gap:var(--space-sm)}.resume-badge{font-size:.65rem;padding:.25rem var(--space-sm)}.dashboard-resume-content h2{font-size:1.35rem}.dashboard-resume-content p{font-size:.875rem}.dashboard-resume-actions{gap:var(--space-sm)}.dashboard-resume-actions .btn{padding:var(--space-sm) var(--space-md);font-size:.875rem}.dashboard-resume-meta{padding:var(--space-md);gap:var(--space-sm);border-width:1.5px}.resume-meta-row{gap:var(--space-sm);padding-bottom:var(--space-xs)}.resume-meta-label{font-size:.7rem}.resume-meta-value{font-size:.875rem}.dashboard-nav-grid{gap:var(--space-md)}.dashboard-nav-tile{min-height:110px;padding:var(--space-md);gap:var(--space-sm);border-width:1.5px;border-radius:1rem}.dashboard-nav-icon{font-size:1.75rem}.dashboard-nav-header h3{font-size:1rem}.dashboard-nav-stats{font-size:.7rem;padding:.25rem var(--space-xs)}.dashboard-nav-description{font-size:.8rem}.dashboard-nav-action{font-size:.7rem;padding:.25rem var(--space-sm)}.dashboard-quick-grid{gap:var(--space-md)}.dashboard-quick-action{padding:var(--space-md);gap:var(--space-md);border-width:1.5px;border-radius:1rem}.dashboard-quick-icon{font-size:1.75rem}.dashboard-quick-label{font-size:.95rem}.dashboard-quick-description{font-size:.8rem}.dashboard-quick-chevron{font-size:1.25rem}.dashboard-status-grid{gap:var(--space-md)}.dashboard-status-card{padding:var(--space-md);gap:var(--space-sm);border-width:1.5px;border-radius:1rem}.dashboard-status-value{font-size:1.75rem}.dashboard-status-title,.dashboard-status-meta{font-size:.8rem}.dashboard-status-button{padding:var(--space-xs) var(--space-sm);font-size:.8rem;border-width:1.5px}}@media(max-width:320px){.dashboard-view{padding:var(--space-sm) 0;gap:var(--space-md)}.dashboard-hero{padding:var(--space-sm);margin:0 var(--space-xs);gap:var(--space-sm);border-width:1px;border-radius:.75rem}.dashboard-hero-body{gap:var(--space-sm)}.dashboard-hero-text{gap:var(--space-xs)}.dashboard-hero-greeting{font-size:.65rem}.dashboard-hero-subtitle{font-size:.7rem;line-height:1.5}.dashboard-hero-title{font-size:1.25rem;margin:0}.dashboard-hero-description{font-size:.8rem;line-height:1.5}.dashboard-hero-actions{gap:var(--space-xs)}.dashboard-primary-cta,.dashboard-secondary-cta{padding:var(--space-xs) var(--space-sm);font-size:.85rem;min-height:40px}.dashboard-hero-status{padding:var(--space-xs) var(--space-sm);font-size:.75rem;gap:var(--space-xs)}.dashboard-status-indicator{width:8px;height:8px}.dashboard-resume-section,.dashboard-nav-section,.dashboard-quick-section,.dashboard-status-section{padding:0 var(--space-xs)}.dashboard-resume-card{padding:var(--space-sm);gap:var(--space-sm);border-width:1px;border-radius:.75rem}.dashboard-resume-content{gap:var(--space-xs)}.resume-badge{font-size:.6rem;padding:.2rem var(--space-xs)}.dashboard-resume-content h2{font-size:1.25rem}.dashboard-resume-content p{font-size:.8rem}.dashboard-resume-actions{gap:var(--space-xs)}.dashboard-resume-actions .btn{padding:var(--space-xs) var(--space-sm);font-size:.8rem;min-height:40px}.dashboard-resume-meta{padding:var(--space-sm);gap:var(--space-xs);border-width:1px;border-radius:.75rem}.resume-meta-row{gap:var(--space-xs);padding-bottom:.25rem}.resume-meta-label{font-size:.65rem}.resume-meta-value{font-size:.8rem}.dashboard-nav-grid{gap:var(--space-sm)}.dashboard-nav-tile{min-height:100px;padding:var(--space-sm);gap:var(--space-xs);border-width:1px;border-radius:.75rem}.dashboard-nav-tile:hover{transform:translateY(-2px) scale(1.01)}.dashboard-nav-icon{font-size:1.5rem}.dashboard-nav-header h3{font-size:.9rem}.dashboard-nav-stats{font-size:.65rem;padding:.2rem var(--space-xs)}.dashboard-nav-description{font-size:.75rem;line-height:1.4}.dashboard-nav-action{font-size:.65rem;padding:.2rem var(--space-xs)}.dashboard-quick-grid{gap:var(--space-sm)}.dashboard-quick-action{min-height:60px;padding:var(--space-sm);gap:var(--space-sm);border-width:1px;border-radius:.75rem}.dashboard-quick-action:hover{transform:translate(2px)}.dashboard-quick-icon{font-size:1.5rem}.dashboard-quick-label{font-size:.875rem}.dashboard-quick-description{font-size:.75rem;line-height:1.4}.dashboard-quick-chevron{font-size:1.1rem}.dashboard-status-grid{gap:var(--space-sm)}.dashboard-status-card{padding:var(--space-sm);gap:var(--space-xs);border-width:1px;border-radius:.75rem}.dashboard-status-card:before{height:2px}.dashboard-status-metric{gap:.25rem}.dashboard-status-value{font-size:1.5rem}.dashboard-status-title,.dashboard-status-meta{font-size:.75rem}.dashboard-status-button{min-height:40px;padding:var(--space-xs) var(--space-sm);font-size:.75rem;border-width:1px;border-radius:.5rem}}.beat-flash-container{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.measure-progress-bar{width:100%;max-width:20rem;height:.5rem;background:#1a233266;border-radius:1rem;overflow:hidden;position:relative;border:1px solid rgba(0,217,255,.2)}.measure-progress-fill{height:100%;background:linear-gradient(90deg,#00d9ffcc,#00d9ff);transition:width .05s linear;border-radius:1rem;box-shadow:0 0 10px #00d9ff80}.beat-circle{position:relative;width:12rem;height:12rem;border-radius:50%;border:4px solid;transition:all .15s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center}.beat-circle.idle{background:#1a23324d;border-color:#00d9ff33;transform:scale(1)}.beat-circle.flashing{animation:beatPulse .15s cubic-bezier(.4,0,.2,1)}.beat-circle.accent{background:#f456;border-color:#f45c;box-shadow:0 0 60px #f459,inset 0 0 40px #f453}.beat-circle.regular{background:#00d9ff66;border-color:#00d9ffcc;box-shadow:0 0 60px #00d9ff99,inset 0 0 40px #00d9ff33}@keyframes beatPulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1.05)}}.beat-pulse-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid;opacity:0;animation:pulseRing .6s ease-out}.beat-pulse-ring.accent{border-color:#f459}.beat-pulse-ring.regular{border-color:#00d9ff99}@keyframes pulseRing{0%{transform:scale(1);opacity:1}to{transform:scale(1.8);opacity:0}}.beat-pulse-ring-secondary{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid;opacity:0;animation:pulseRingSecondary .8s ease-out;animation-delay:.1s}@keyframes pulseRingSecondary{0%{transform:scale(1.2);opacity:.8}to{transform:scale(2.5);opacity:0}}.beat-pulse-center{width:2rem;height:2rem;border-radius:50%;animation:pulseCenterGrow .15s cubic-bezier(.4,0,.2,1)}.beat-pulse-center.accent{background:radial-gradient(circle,#f45,#f456)}.beat-pulse-center.regular{background:radial-gradient(circle,#00d9ff,#00d9ff66)}@keyframes pulseCenterGrow{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:.8}}.beat-number{font-size:4rem;font-weight:900;font-family:Courier New,monospace;text-shadow:0 0 20px currentColor;transition:all .15s ease}.beat-number.accent{color:#f45}.beat-number.regular{color:#00d9ff}.beat-label{margin-top:1rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.1em;color:#e8eef599;font-weight:600;display:flex;align-items:center;gap:.5rem}.accent-indicator{color:#f45;font-weight:700;animation:accentGlow 1s ease-in-out infinite}@keyframes accentGlow{0%,to{opacity:1}50%{opacity:.6}}.beat-indicators{display:flex;gap:.5rem;margin-top:1rem;align-items:center;justify-content:center}.beat-dot{width:.5rem;height:.5rem;border-radius:50%;background:#00d9ff4d;border:1px solid rgba(0,217,255,.2);transition:all .2s ease}.beat-dot.active{width:.75rem;height:.75rem;background:#00d9ffcc;border-color:#00d9ff;box-shadow:0 0 10px #00d9ff99}.beat-dot.accent{background:#ff44554d;border-color:#f453}.beat-dot.accent.active{background:#f45c;border-color:#f45;box-shadow:0 0 10px #f459}.beat-dot.editable{cursor:pointer}.beat-dot.editable:focus{outline:2px solid #00d9ff;outline-offset:2px}.beat-circle.flashing{animation:beatPulse .18s ease-out}.beat-circle{width:9rem;height:9rem}.beat-pulse-ring{animation:pulseRing .6s ease-out}.beat-number{font-size:3.5rem}.color-coded .beat-downbeat{background:#ef444466!important;border-color:#ef4444cc!important;box-shadow:0 0 60px #ef444499,inset 0 0 40px #ef444433!important}.color-coded .beat-downbeat.flashing{background:#ef4444e6!important;box-shadow:0 0 100px #ef4444,0 0 200px #ef4444cc,inset 0 0 60px #ef444499!important}.color-coded .beat-accent{background:#3b82f666!important;border-color:#3b82f6cc!important;box-shadow:0 0 60px #3b82f699,inset 0 0 40px #3b82f633!important}.color-coded .beat-accent.flashing{background:#3b82f6e6!important;box-shadow:0 0 100px #3b82f6,0 0 200px #3b82f6cc,inset 0 0 60px #3b82f699!important}.color-coded .beat-regular{background:#e5e7eb66!important;border-color:#e5e7ebcc!important;box-shadow:0 0 60px #e5e7eb99,inset 0 0 40px #e5e7eb33!important}.color-coded .beat-regular.flashing{background:#ffffffe6!important;box-shadow:0 0 100px #fff,0 0 200px #fffc,inset 0 0 60px #fff9!important}.color-coded .beat-number.beat-downbeat{color:#ef4444!important}.color-coded .beat-number.beat-accent{color:#3b82f6!important}.color-coded .beat-number.beat-regular{color:#f3f4f6!important}.color-coded .beat-pulse-ring.beat-downbeat{border-color:#ef444499!important}.color-coded .beat-pulse-ring.beat-accent{border-color:#3b82f699!important}.color-coded .beat-pulse-ring.beat-regular{border-color:#e5e7eb99!important}.beat-flash-stage .beat-circle{width:18rem!important;height:18rem!important;border-width:8px!important}.beat-flash-stage .beat-number{font-size:7rem!important}.beat-flash-stage .measure-progress-bar{max-width:30rem;height:.75rem}.beat-flash-fullscreen{position:fixed;inset:0;background:#000000f2;z-index:9999;display:flex;align-items:center;justify-content:center}.beat-flash-fullscreen .beat-circle{width:30rem!important;height:30rem!important;border-width:12px!important}.beat-flash-fullscreen .beat-number{font-size:12rem!important}.beat-flash-fullscreen .measure-progress-bar{max-width:50rem;height:1rem}.beat-flash-fullscreen .beat-indicators{gap:1rem}.beat-flash-fullscreen .beat-dot{width:1rem;height:1rem}.beat-flash-fullscreen .beat-dot.active{width:1.5rem;height:1.5rem}.performance-view-header{margin-bottom:2rem;padding:1.5rem 0;text-align:center}@media(max-width:480px){.performance-view-header{margin-bottom:1.25rem;padding:1rem 0 .75rem}.performance-view-header h1{font-size:1.85rem;text-shadow:0 0 18px rgba(0,217,255,.25)}}.performance-view-header h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-shadow:0 0 30px rgba(0,217,255,.3)}.setup-mode-container{width:100%;max-width:1000px;margin:0 auto;padding:2rem 1rem;background:#1a23324d;border-radius:1.5rem;border:1px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:480px){.setup-mode-container{padding:1.25rem .875rem 1.5rem;border-radius:1.25rem}}.performance-mode{transition:all .3s ease}.performance-mode.active{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.setlist-section{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}@media(max-width:480px){.setlist-section{flex-direction:column;align-items:stretch;gap:.6rem;margin-bottom:1.5rem}}.setlist-select{flex:1;min-width:250px;padding:.875rem 1.25rem;border-radius:.875rem;background-color:#1a2332cc;border:2px solid rgba(0,217,255,.3);color:#e8eef5;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:480px){.setlist-select{min-width:0;width:100%;font-size:.95rem;padding:.75rem 1rem}}.setlist-select:hover{border-color:#00d9ff80;background-color:#1a2332e6;box-shadow:0 0 15px #00d9ff33}.setlist-select:focus{outline:none;border-color:#00d9ff;box-shadow:0 0 0 3px #00d9ff4d,0 0 20px #00d9ff33;background-color:#1a2332}.setlist-select option{background-color:#1a2332;color:#e8eef5;padding:.5rem}.setlist-button{padding:.875rem 1.75rem;border-radius:.875rem;background:linear-gradient(135deg,#00d9ff1a,#6366f11a);border:2px solid rgba(0,217,255,.3);color:#e8eef5;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:480px){.setlist-button{width:100%;padding:.75rem 1rem;text-align:center}}.setlist-button:hover{background:linear-gradient(135deg,#00d9ff33,#6366f133);border-color:#00d9ff;color:#00d9ff;transform:translateY(-2px);box-shadow:0 4px 15px #00d9ff4d}.setlist-button:active{transform:scale(.95) translateY(0)}.setlist-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.song-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid rgba(0,217,255,.2)}.song-list-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#e8eef5;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.song-list-section{width:100%}@media(max-width:480px){.song-list-section{margin-top:.5rem}}.song-list-tip{display:block;background:linear-gradient(135deg,#00d9ff1a,#6366f11a);padding:.875rem 1rem;border-radius:.75rem;margin-bottom:1rem;color:#8b92a8;font-size:.875rem;border:1px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.song-list-container{background:linear-gradient(135deg,#1a233266,#1a233299);border-radius:1rem;padding:1.25rem;margin-bottom:1.5rem;max-height:400px;overflow-y:auto;border:2px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 2px 10px #0000004d}@media(max-width:480px){.song-list-container{padding:1rem;margin-bottom:1.25rem;max-height:260px}}.song-list-empty{text-align:center;padding:3rem 2rem;background:#1a23324d;border-radius:.75rem;border:2px dashed rgba(0,217,255,.2)}.lyrics-empty-state{text-align:center;padding:20px}.empty-state-help{margin-top:20px;max-width:500px;margin-left:auto;margin-right:auto}.help-text{color:var(--text-secondary);margin-bottom:15px;font-size:.95rem}.help-actions{margin:15px 0}.help-details{margin-top:15px;text-align:left;background:var(--surface-light);border-radius:8px;padding:15px}.help-details summary{cursor:pointer;font-weight:600;color:var(--primary-color);-webkit-user-select:none;user-select:none}.help-details summary:hover{color:var(--accent-cyan)}.help-details ol{margin-top:10px;padding-left:20px}.help-details li{margin:8px 0;line-height:1.6}.help-details code{background:var(--surface);padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:var(--accent-cyan)}.link-button{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;padding:0;font:inherit;transition:color .2s ease}.link-button:hover{color:var(--accent-cyan)}.link-button:focus{outline:2px solid var(--primary-color);outline-offset:2px}.empty-actions{margin-top:20px;display:flex;justify-content:center;gap:10px}.empty-message{color:#8b92a8;font-size:1rem;font-style:italic;margin:0 0 1.5rem}.empty-tips{text-align:left;max-width:400px;margin:0 auto;padding:1.5rem;background:#00d9ff0d;border-radius:.75rem;border:1px solid rgba(0,217,255,.2)}.tip-title{color:#00d9ff;font-weight:600;font-size:.9375rem;margin:0 0 .75rem}.tip-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.tip-list li{color:#8b92a8;font-size:.875rem;line-height:1.5;padding-left:1.5rem;position:relative}.tip-list li:before{content:"→";position:absolute;left:0;color:#00d9ff;font-weight:700}.tip-list li strong{color:#00d9ff;font-weight:600}.lyrics-placeholder{text-align:center;padding:3rem 2rem;color:#8b92a8}@media(max-width:480px){.lyrics-placeholder{padding:2rem 1.5rem;font-size:.95rem}}.empty-hint{margin-top:1rem;font-size:.875rem;color:#6366f1;font-style:normal}.song-item-card{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;padding:1.25rem;border-radius:.875rem;cursor:pointer;transition:all .3s ease;margin-bottom:.75rem;align-items:center;background:linear-gradient(135deg,#1a233280,#1a23324d);border:2px solid transparent;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(max-width:480px){.song-item-card{grid-template-columns:1fr;grid-template-rows:repeat(3,auto);gap:.5rem;padding:1rem;text-align:left}.song-number{order:-1;width:auto;justify-self:flex-start}.song-bpm-display{justify-self:flex-start}}.song-item-card:hover{background:linear-gradient(135deg,#1a2332cc,#1a233299);border-color:#00d9ff66;transform:translateY(-3px);box-shadow:0 6px 20px #00d9ff33}.song-item-card.active{background:linear-gradient(135deg,#00d9ff40,#6366f140);border-color:#00d9ff;box-shadow:0 0 25px #00d9ff66,inset 0 0 20px #00d9ff1a;transform:translateY(-2px)}.song-number{font-weight:700;font-size:1rem;min-width:2rem;color:#00d9ff;text-align:center}.song-item-card.active .song-number{color:#00d9ff;font-size:1.125rem}.song-name-display{display:flex;flex-direction:column;gap:.25rem}.song-name{font-weight:600;color:#e8eef5;font-size:1rem}.song-artist-small{font-size:.875rem;color:#8b92a8;font-weight:400}.song-bpm-display{font-size:.875rem;color:#8b92a8;font-weight:500}.song-item-card.active .song-name,.song-item-card.active .song-bpm-display{color:#00d9ff}.song-list-container::-webkit-scrollbar{width:8px}.song-list-container::-webkit-scrollbar-track{background:#1a23324d;border-radius:4px}.song-list-container::-webkit-scrollbar-thumb{background:#00d9ff4d;border-radius:4px}.song-list-container::-webkit-scrollbar-thumb:hover{background:#00d9ff80}.mini-status{position:fixed;left:50%;transform:translate(-50%);bottom:calc(72px + env(safe-area-inset-bottom));background:#0a101ee6;border:1px solid rgba(0,217,255,.25);border-radius:999px;padding:6px 12px;display:none;gap:8px;align-items:center;color:#e8eef5;z-index:45;font-size:.85rem}.fab-play{position:fixed;left:50%;transform:translate(-50%);bottom:calc(110px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#00d9ff40,#6366f140);border:2px solid rgba(0,217,255,.35);color:#e8eef5;display:none;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 8px 24px #00000059;z-index:46}.fab-play.playing{background:#f8717140;border-color:#f8717173}@media(max-width:480px){.mini-status,.fab-play{display:inline-flex}}@media(max-width:360px){.performance-view-header{padding:.75rem 0 .5rem;margin-bottom:1rem}.performance-view-header h1{font-size:1.5rem}.setup-mode-container{padding:1rem .75rem 1.25rem}.setlist-section{gap:.75rem}.song-item-card{padding:.875rem;gap:.75rem}.song-name{font-size:.95rem}.song-artist-small,.song-bpm-display{font-size:.8rem}}@media(max-width:320px){.performance-view-header{padding:.5rem 0;margin-bottom:.875rem}.performance-view-header h1{font-size:1.35rem}.setup-mode-container{padding:.875rem .625rem 1rem;border-radius:1rem}.setlist-section{gap:.625rem}.setlist-select,.setlist-button{padding:.625rem .875rem;font-size:.85rem}.song-item-card{padding:.75rem;gap:.625rem;border-radius:.75rem}.song-number{font-size:.9rem;min-width:1.75rem}.song-name{font-size:.9rem}.song-artist-small,.song-bpm-display{font-size:.75rem}}.setlists-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}@media(max-width:360px){.setlists-container{grid-template-columns:1fr;padding:1rem .5rem;gap:1rem}}.setlist-card{background:linear-gradient(135deg,#1a233299,#1a2332cc);border-radius:1rem;border:2px solid rgba(0,217,255,.25);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease;overflow:hidden;box-shadow:0 4px 12px #0000004d}.setlist-card:hover{border-color:var(--accent-cyan-bold);transform:translateY(-2px);box-shadow:0 8px 25px #00d9ff40,var(--glow-cyan)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);border-bottom:2px solid rgba(0,217,255,.2);background:linear-gradient(135deg,#00d9ff14,#6366f114);flex-wrap:wrap}@media(max-width:640px){.card-header{padding:var(--space-md);flex-direction:column;align-items:stretch}}.card-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#e8eef5;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.card-actions .btn{min-height:var(--touch-min);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);font-size:.85rem;font-weight:700;white-space:nowrap;border-radius:.75rem;transition:all .2s ease;cursor:pointer}.card-actions .btn-small{min-height:40px;padding:var(--space-xs) var(--space-sm);font-size:.8rem}.card-actions .btn-primary{background:var(--action-primary);border:2px solid var(--accent-cyan-bold);color:#fff;box-shadow:var(--glow-cyan)}.card-actions .btn-primary:hover{background:var(--action-primary-hover);border-color:var(--accent-cyan-bright);transform:translateY(-1px);box-shadow:var(--glow-cyan-intense)}.card-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.card-actions .btn-secondary{background:#00d9ff1a;border:2px solid var(--accent-cyan-soft);color:var(--accent-cyan-bright)}.card-actions .btn-secondary:hover{background:#00d9ff33;border-color:var(--accent-cyan-bold);transform:translateY(-1px)}.card-actions .btn-danger{background:#ff00551a;border:2px solid rgba(255,0,85,.3);color:#f45}.card-actions .btn-danger:hover{background:#f053;border-color:var(--accent-danger);transform:translateY(-1px);box-shadow:0 4px 12px #ff00554d}@media(max-width:640px){.card-actions{width:100%;justify-content:flex-start}.card-actions .btn{flex:1 1 auto}}@media(max-width:360px){.setlist-card{border-radius:.75rem}.card-header,.card-body{padding:var(--space-sm)}.card-header h3{font-size:1.1rem}}@media(max-width:320px){.card-header,.card-body{padding:var(--space-xs)}.card-actions .btn{font-size:.75rem;padding:var(--space-xs)}}.btn-icon.delete-setlist:hover{border-color:#f45;background:#f453}.card-body{padding:1.25rem}.card-body p{margin:.5rem 0;color:#e8eef5;font-size:.9375rem}.card-body strong{color:#00d9ff;font-weight:600}.song-list-inline{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.5rem}.song-list-inline li{color:#8b92a8;font-size:.875rem;padding:.5rem .75rem;background:#1a233266;border-radius:.5rem;border-left:3px solid rgba(0,217,255,.3)}.song-list-inline li em{color:#6366f1;font-style:normal}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#8b92a8;font-size:1.125rem;background:linear-gradient(135deg,#1a23324d,#1a233280);border-radius:1rem;border:2px dashed rgba(0,217,255,.2)}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem 0}.btn-primary:active{transform:scale(.95) translateY(0)}.setlists-view{max-width:1200px;margin:0 auto;padding:2rem 1rem 4rem;display:flex;flex-direction:column;gap:2rem}.header-subtitle{margin-top:.35rem;font-size:.95rem;color:#d4e1ffa6;letter-spacing:.08em;text-transform:uppercase}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem 2rem;color:#e8eef5;font-size:1rem;background:linear-gradient(135deg,#1a233266,#1a2332a6);border-radius:1.25rem;border:2px dashed rgba(0,217,255,.25);display:flex;flex-direction:column;gap:1.5rem;align-items:center}.empty-title{margin:0;font-size:1.1rem;letter-spacing:.04em}.empty-actions{display:grid;gap:.75rem;width:min(360px,100%)}.card-heading{display:flex;flex-direction:column;gap:.35rem}.card-meta{margin:0;font-size:.85rem;color:#d4e1ffa6;letter-spacing:.08em;text-transform:uppercase}.setlist-summary{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}.summary-chip{padding:.45rem .9rem;border-radius:999px;background:#00d9ff1f;border:1px solid rgba(0,217,255,.28);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#e2f1ffbf}.setlist-quick-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.setlist-song-table{display:flex;flex-direction:column;gap:.75rem}.song-row{display:grid;grid-template-columns:auto minmax(0,2.2fr) minmax(0,2fr) auto;gap:1rem;align-items:center;padding:.9rem 1rem;border-radius:.9rem;background:#0c1320bf;border:1px solid rgba(0,217,255,.12)}@media(max-width:820px){.song-row{grid-template-columns:auto minmax(0,1fr);gap:.75rem}.song-metrics,.song-actions{grid-column:2 / -1}}.song-row.empty{justify-content:center;color:#d4e1ff99;border-style:dashed}.song-index{font-size:1.1rem;font-weight:700;color:#6366f1d9}.song-title{display:flex;flex-direction:column;gap:.2rem}.song-name{font-size:1rem;font-weight:600;color:#e8eef5}.song-artist{font-size:.85rem;color:#d4e1ffa6}.song-metrics{display:flex;flex-wrap:wrap;gap:.45rem}.metric-tag{padding:.3rem .65rem;border-radius:.75rem;background:#00d9ff1f;border:1px solid rgba(0,217,255,.2);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:#e2f1ffbf}.metric-tag.muted{background:#6366f11f;border-color:#6366f147}.song-actions{display:flex;gap:.5rem}.song-action{border:1px solid rgba(0,217,255,.2);background:#0c132099;color:#e2f1ffd9;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:.45rem .75rem;border-radius:.65rem;transition:all .2s ease}.song-action:hover{border-color:#00d9ff73;background:#00d9ff29}.setlist-drawer-backdrop{position:fixed;inset:0;background:#060a14a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;justify-content:flex-end;z-index:1100}.setlist-drawer{width:min(420px,100%);background:#0a101efa;border-left:1px solid rgba(0,217,255,.18);padding:2rem 2.25rem;display:flex;flex-direction:column;gap:1.5rem;box-shadow:-14px 0 32px #03071273}.drawer-header{display:flex;flex-direction:column;gap:.4rem;position:relative}.drawer-header h2{margin:0;font-size:1.3rem;letter-spacing:.04em}.drawer-header p{margin:0;color:#d4e1ffa6;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem}.drawer-close{position:absolute;top:0;right:0;border:none;background:none;color:#d4e1ffa6;font-size:1.5rem;cursor:pointer}.drawer-form{display:flex;flex-direction:column;gap:1.1rem}.drawer-field{display:flex;flex-direction:column;gap:.4rem}.drawer-field span{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#d4e1ffbf}.drawer-field input,.drawer-field select{border-radius:.75rem;border:1px solid rgba(0,217,255,.35);background:#070c18d9;color:#f5f7ff;padding:.6rem .75rem;font-size:1rem}.drawer-field small{font-size:.75rem;color:#d4e1ff8c}.drawer-error{padding:.6rem .75rem;border-radius:.65rem;background:#f8717129;border:1px solid rgba(248,113,113,.35);color:#fecaca;font-size:.85rem}@media(max-width:480px){.setlists-container{grid-template-columns:1fr;padding:1rem .5rem;gap:1rem}.setlists-view{padding:1rem .5rem 3rem}header{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem 0;margin-bottom:1.5rem}header h1{font-size:clamp(1.5rem,6vw,2rem)}.btn{padding:.75rem 1.25rem;font-size:.85rem;width:100%}.setlist-card{border-radius:.875rem}.card-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.card-header h3{font-size:1rem;width:100%;word-break:break-word}.card-actions{width:100%;justify-content:flex-end}.card-body{padding:1rem}.song-row{grid-template-columns:auto 1fr;gap:.5rem;padding:.75rem}.song-metrics,.song-actions{grid-column:1 / -1;margin-top:.5rem}.setlist-drawer{width:100%;padding:1.5rem 1rem}.empty-state{padding:2.5rem 1rem}}@media(max-width:360px){.setlists-container{padding:.75rem .375rem}.setlists-view{padding:.75rem .375rem 2.5rem}header{padding:.75rem 0}header h1{font-size:1.4rem}.btn{padding:.625rem 1rem;font-size:.8rem}.card-header,.card-body{padding:.875rem}.song-row{padding:.625rem}}@media(max-width:320px){.setlists-container{padding:.5rem .25rem;gap:.75rem}.setlists-view{padding:.5rem .25rem 2rem;gap:1rem}header{padding:.5rem 0;margin-bottom:1rem}header h1{font-size:1.25rem}.btn{padding:.5rem .875rem;font-size:.75rem}.card-header,.card-body{padding:.75rem}.song-row{padding:.5rem;font-size:.875rem}.empty-state{padding:2rem .75rem}.setlist-drawer{padding:1rem .75rem}}.songs-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}@media(max-width:360px){.songs-container{grid-template-columns:1fr;padding:1rem .5rem;gap:1rem}}.song-card{background:linear-gradient(135deg,#1a233299,#1a2332cc);border-radius:1rem;border:2px solid rgba(0,217,255,.25);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease;overflow:hidden;box-shadow:0 4px 12px #0000004d}.song-card:hover{border-color:var(--accent-cyan-bold);transform:translateY(-2px);box-shadow:0 8px 25px #00d9ff40,var(--glow-cyan)}.song-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);border-bottom:2px solid rgba(0,217,255,.2);background:linear-gradient(135deg,#00d9ff14,#6366f114);flex-wrap:wrap}@media(max-width:640px){.song-card .card-header{padding:var(--space-md);flex-direction:column;align-items:stretch}.song-card .card-actions{width:100%;justify-content:flex-start}.song-card .card-actions .btn{flex:1 1 auto}}@media(max-width:360px){.song-card{border-radius:.75rem}.song-card .card-header,.song-card .card-body{padding:var(--space-sm)}.song-card .card-header h3{font-size:1rem}.song-artist{font-size:.85rem}}@media(max-width:320px){.song-card .card-header,.song-card .card-body{padding:var(--space-xs)}.song-card .card-actions .btn{font-size:.75rem;padding:var(--space-xs)}}.song-card .card-header h3{margin:0;font-size:1.125rem;font-weight:700;color:#e8eef5;flex:1}.song-artist{font-weight:400;color:#8b92a8;font-size:.9375rem}.song-card .card-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.song-card .card-actions .btn{min-height:var(--touch-min);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);font-size:.85rem;font-weight:700;white-space:nowrap}.song-card .card-actions .btn-small{min-height:40px;padding:var(--space-xs) var(--space-sm);font-size:.8rem}.song-card .card-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.4rem}.song-card .card-body.compact{gap:.3rem}.song-card .card-body p{margin:0;color:#e8eef5;font-size:.875rem;line-height:1.3;display:flex;flex-wrap:wrap;gap:.5rem}.song-card .card-body strong{color:#00d9ff;font-weight:600}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#1a23324d,#1a233280);border-radius:1rem;border:2px dashed rgba(0,217,255,.2)}.empty-state p{color:#8b92a8;font-size:1.125rem;margin-bottom:1.5rem}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem 0;flex-wrap:wrap;gap:1rem}.btn{padding:.875rem 1.75rem;border-radius:.875rem;border:2px solid rgba(0,217,255,.3);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.btn-primary:hover{background:linear-gradient(135deg,#00d9ff4d,#6366f14d);border-color:#00d9ff;color:#00d9ff;transform:translateY(-2px);box-shadow:0 4px 15px #00d9ff4d}.btn:active{transform:scale(.95) translateY(0)}.btn-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;border:2px solid rgba(0,217,255,.3);background:#1a233299;color:#e8eef5;font-size:1.125rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-icon:hover{border-color:#00d9ff;background:#00d9ff33;transform:scale(1.1)}.btn-icon.delete-song:hover{border-color:#f45;background:#f453}select.btn{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2300d9ff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}@media(max-width:480px){.songs-container{grid-template-columns:1fr;padding:1rem .5rem;gap:1rem}header{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem 0;margin-bottom:1.5rem}header h1{font-size:clamp(1.5rem,6vw,2rem)}.btn{padding:.75rem 1.25rem;font-size:.85rem;width:100%}.song-card{border-radius:.875rem}.song-card .card-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.song-card .card-header h3{font-size:1rem;width:100%;word-break:break-word}.song-card .card-actions{width:100%;justify-content:flex-end}.song-card .card-body{padding:1rem}.empty-state{padding:2.5rem 1rem}}@media(max-width:360px){.songs-container{padding:.75rem .375rem}header{padding:.75rem 0}header h1{font-size:1.4rem}.btn{padding:.625rem 1rem;font-size:.8rem}.song-card .card-header,.song-card .card-body{padding:.875rem}}@media(max-width:320px){.songs-container{padding:.5rem .25rem;gap:.75rem}header{padding:.5rem 0;margin-bottom:1rem}header h1{font-size:1.25rem}.btn{padding:.5rem .875rem;font-size:.75rem}.song-card .card-header,.song-card .card-body{padding:.75rem}.empty-state{padding:2rem .75rem}.empty-state p{font-size:1rem}}.midi-controls{max-width:1000px;margin:0 auto;padding:2rem 1rem}.control-group{background:linear-gradient(135deg,#1a233266,#1a233299);border-radius:1rem;padding:1.5rem;border:2px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:1.5rem}.control-group label{display:block;margin-bottom:.75rem;font-weight:600;color:#e8eef5;font-size:1rem}.control-group select{width:100%;padding:.875rem 3rem .875rem 1.25rem;border-radius:.875rem;background-color:#1a2332cc;border:2px solid rgba(0,217,255,.3);color:#e8eef5;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2300d9ff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.control-group select:hover{border-color:#00d9ff80;background-color:#1a2332e6;box-shadow:0 0 15px #00d9ff33}.control-group select:focus{outline:none;border-color:#00d9ff;box-shadow:0 0 0 3px #00d9ff4d,0 0 20px #00d9ff33}.control-group select option{background-color:#1a2332;color:#e8eef5;padding:.5rem}.control-group small{display:block;margin-top:.75rem;color:#8b92a8;font-size:.875rem}.helix-connection-info{background:linear-gradient(135deg,#00d9ff1a,#6366f11a);border:2px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.helix-connection-info h3{margin:0 0 1rem;font-size:1.25rem;font-weight:700;color:#e8eef5;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.helix-connection-info p{color:#8b92a8;line-height:1.6}.midi-notes{background:linear-gradient(135deg,#1a233266,#1a233299);border:2px solid rgba(0,217,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.midi-notes h3{margin:0 0 1rem;font-size:1.25rem;font-weight:700;color:#e8eef5;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.note-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:.75rem;max-height:400px;overflow-y:auto;padding:1rem;background:#1a23324d;border-radius:.75rem}.note-grid button{padding:.75rem .5rem;border-radius:.75rem;border:2px solid rgba(0,217,255,.3);background:#1a233299;color:#e8eef5;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.note-grid button:hover{border-color:#00d9ff;background:#00d9ff33;transform:translateY(-2px);box-shadow:0 4px 12px #00d9ff4d}.note-grid button:active{transform:scale(.95)}.alert{padding:1.25rem;border-radius:.875rem;border:2px solid;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.alert-warning{background:linear-gradient(135deg,#ff98001a,#ff98000d);border-color:#ff98004d;color:#e8eef5}.alert-warning strong{color:#ff9800;display:block;margin-bottom:.5rem}header{margin-bottom:2rem;padding:1.5rem 0}header h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#00d9ff,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-shadow:0 0 30px rgba(0,217,255,.3)}.btn{padding:.875rem 1.75rem;border-radius:.875rem;border:2px solid rgba(0,217,255,.3);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-primary{background:linear-gradient(135deg,#00d9ff33,#6366f133);color:#e8eef5}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#00d9ff4d,#6366f14d);border-color:#00d9ff;color:#00d9ff;transform:translateY(-2px);box-shadow:0 4px 15px #00d9ff4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#1a233299;color:#e8eef5}.btn-secondary:hover{background:#1a2332cc;border-color:#00d9ff80;color:#00d9ff;transform:translateY(-2px);box-shadow:0 4px 15px #00d9ff33}.btn:active:not(:disabled){transform:scale(.95) translateY(0)}.note-grid::-webkit-scrollbar{width:8px}.note-grid::-webkit-scrollbar-track{background:#1a23324d;border-radius:4px}.note-grid::-webkit-scrollbar-thumb{background:#00d9ff4d;border-radius:4px}.note-grid::-webkit-scrollbar-thumb:hover{background:#00d9ff80}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.test-feedback{animation:fadeIn .3s ease}@media(max-width:480px){.midi-controls{padding:1rem .5rem}header{padding:1rem 0;margin-bottom:1.5rem}header h1{font-size:clamp(1.5rem,6vw,2rem)}.control-group{padding:1rem;border-radius:.875rem;margin-bottom:1rem}.control-group label{font-size:.9rem;margin-bottom:.5rem}.control-group select{padding:.75rem 2.5rem .75rem 1rem;font-size:.9rem}.note-grid{grid-template-columns:repeat(auto-fill,minmax(55px,1fr));gap:.5rem;padding:.75rem}.note-grid button{padding:.625rem .375rem;font-size:.8rem;min-height:50px}.btn{padding:.75rem 1.25rem;font-size:.85rem;width:100%}.alert{padding:1rem}}@media(max-width:360px){.midi-controls{padding:.75rem .375rem}header{padding:.75rem 0}header h1{font-size:1.4rem}.control-group{padding:.875rem}.note-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.375rem}.note-grid button{padding:.5rem .25rem;font-size:.75rem;min-height:45px}.btn{padding:.625rem 1rem;font-size:.8rem}}@media(max-width:320px){.midi-controls{padding:.5rem .25rem}header{padding:.5rem 0;margin-bottom:1rem}header h1{font-size:1.25rem}.control-group{padding:.75rem;margin-bottom:.75rem}.control-group label{font-size:.85rem}.control-group select{padding:.625rem 2rem .625rem .875rem;font-size:.85rem}.note-grid{grid-template-columns:repeat(auto-fill,minmax(45px,1fr));gap:.25rem;padding:.5rem}.note-grid button{padding:.5rem .25rem;font-size:.7rem;min-height:40px}.btn{padding:.5rem .875rem;font-size:.75rem}.alert{padding:.875rem}}.metronome-settings-view{display:flex;flex-direction:column;gap:2rem;padding-bottom:4rem}.metronome-settings-view .view-header{display:flex;flex-direction:column;gap:.75rem}@media(min-width:768px){.metronome-settings-view .view-header{flex-direction:row;justify-content:space-between;align-items:center}}.metronome-settings-view .view-subtitle{color:var(--text-secondary, rgba(212, 225, 255, .75));font-size:.95rem;line-height:1.5;max-width:48rem}.status-pill{display:inline-flex;align-items:center;gap:.5rem;background:#6366f11f;color:var(--text, #e8eef5);border:1px solid rgba(99,102,241,.3);border-radius:999px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;align-self:flex-start}.settings-section{background:#1a233299;border-radius:1.25rem;padding:1.75rem;border:1px solid rgba(99,102,241,.2);display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 18px 40px #090e1959}.section-header{display:flex;flex-direction:column;gap:.35rem}.section-header h2{font-size:1.3rem;font-weight:700;letter-spacing:.01em}.section-description{color:var(--text-secondary, rgba(212, 225, 255, .75));font-size:.95rem;line-height:1.6;max-width:50ch}.settings-grid{display:grid;gap:1rem}@media(min-width:768px){.settings-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}}.settings-field{display:flex;flex-direction:column;gap:.45rem;padding:.9rem 1rem;border-radius:.9rem;background:#0f162799;border:1px solid rgba(255,255,255,.05)}.settings-field.toggle-field{flex-direction:row;align-items:center;gap:.75rem}.settings-label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#e2f1ffe0}.settings-input,.settings-select{appearance:none;border-radius:.75rem;border:1px solid rgba(99,102,241,.35);background:#070c18cc;color:var(--text, #f8fbff);padding:.65rem .85rem;font-size:1rem}.settings-input:focus,.settings-select:focus,.settings-field input[type=range]:focus{outline:none;border-color:#818cf8cc;box-shadow:0 0 0 3px #6366f140}.settings-help{font-size:.8rem;color:#d4e1ff99;line-height:1.4}.accent-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:.85rem}.accent-cell{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.95rem .5rem;border-radius:.9rem;border:1px solid rgba(99,102,241,.25);background:#0a0f1bbf;color:#e8eef5d9;transition:transform .18s ease,border-color .18s ease,background .18s ease}.accent-cell:hover{transform:translateY(-2px);border-color:#818cf880}.accent-cell.accented{background:#6366f12e;border-color:#6366f199;color:#f4f6ff;box-shadow:0 10px 24px #6366f140}.accent-number{font-size:1.35rem;font-weight:700}.accent-dot{font-size:1.15rem;color:#6366f1e6}.accent-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between}.accent-preview{display:inline-flex;align-items:baseline;gap:.35rem;font-size:.9rem;color:#d4e1ffbf}.accent-preview-label{text-transform:uppercase;letter-spacing:.08em;font-weight:600}.preview-wrapper{margin-top:.5rem;display:flex;justify-content:center}.sound-grid{display:grid;gap:1rem}@media(min-width:768px){.sound-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}.inline-help{border-radius:.9rem;background:#0b1221a6;border:1px solid rgba(255,255,255,.06);padding:1rem 1.25rem;color:#d4e1ffbf}.inline-help summary{cursor:pointer;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem}.inline-help ul{margin-top:.75rem;margin-bottom:0;padding-left:1.2rem;display:grid;gap:.35rem}.tip-card-grid{display:grid;gap:1rem}@media(min-width:768px){.tip-card-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}.tip-card{background:#09101eb3;border:1px solid rgba(129,140,248,.12);border-radius:1rem;padding:1.2rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 14px 30px #070c1852}.tip-card h3{font-size:1rem;font-weight:700}.tip-card p{font-size:.9rem;color:#d4e1ffb3;line-height:1.5}.btn.btn-link{color:#818cf8f2;text-decoration:underline;font-weight:600;padding:0;align-self:flex-start}@media(max-width:480px){.metronome-settings-view{gap:1.5rem;padding-bottom:3rem}.metronome-settings-view .view-header h1{font-size:clamp(1.5rem,6vw,1.75rem)}.metronome-settings-view .view-subtitle{font-size:.85rem}.status-pill{padding:.5rem .875rem;font-size:.8rem}.settings-section{padding:1.25rem;border-radius:1rem}.section-header h2{font-size:1.1rem}.section-description{font-size:.85rem}.settings-field{padding:.75rem .875rem}.settings-label{font-size:.8rem}.settings-input,.settings-select{padding:.6rem .75rem;font-size:.9rem}.accent-grid{grid-template-columns:repeat(auto-fit,minmax(50px,1fr));gap:.625rem}.accent-cell{padding:.75rem .375rem}.accent-number{font-size:1.1rem}.accent-actions{flex-direction:column;align-items:stretch;gap:.75rem}.accent-preview{font-size:.85rem}.sound-grid,.tip-card-grid{grid-template-columns:1fr}.tip-card{padding:1rem}}@media(max-width:360px){.metronome-settings-view{gap:1.25rem;padding-bottom:2.5rem}.settings-section{padding:1rem}.section-header h2{font-size:1rem}.accent-grid{grid-template-columns:repeat(auto-fit,minmax(45px,1fr));gap:.5rem}.accent-cell{padding:.625rem .25rem}.accent-number{font-size:1rem}}@media(max-width:320px){.metronome-settings-view{gap:1rem;padding-bottom:2rem}.metronome-settings-view .view-header h1{font-size:1.25rem}.metronome-settings-view .view-subtitle{font-size:.8rem}.status-pill{padding:.5rem .75rem;font-size:.75rem}.settings-section{padding:.875rem;border-radius:.875rem}.section-header h2{font-size:.95rem}.section-description{font-size:.8rem}.settings-field{padding:.625rem .75rem}.settings-label{font-size:.75rem}.settings-input,.settings-select{padding:.5rem .625rem;font-size:.85rem}.accent-grid{grid-template-columns:repeat(auto-fit,minmax(40px,1fr));gap:.375rem}.accent-cell{padding:.5rem .25rem}.accent-number{font-size:.95rem}.accent-dot{font-size:1rem}.accent-preview{font-size:.8rem}.tip-card{padding:.875rem}.tip-card h3{font-size:.9rem}.tip-card p{font-size:.85rem}}.stage-mode-view{display:flex;flex-direction:column;gap:1.75rem;min-height:calc(100vh - 6rem);padding:2.5rem 1.5rem 6rem;touch-action:pan-y;align-items:center;width:100%}.stage-header{display:flex;flex-direction:column;gap:1rem;width:min(100%,420px);margin:0 auto}.stage-header-actions{display:flex;align-items:center;gap:.75rem}.stage-sync-button{padding:.6rem 1rem;font-size:.85rem;font-weight:600;border-radius:999px;border:1px solid rgba(226,241,255,.2);background:#e2f1ff1a;color:#f7f8ffe6;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer}.stage-sync-button.connected{background:#22c55e26;border-color:#22c55e59;color:#bbf7d0e6}.stage-sync-button:hover{background:#e2f1ff33;border-color:#e2f1ff80}.stage-sync-button.connected:hover{background:#22c55e4d;border-color:#22c55ea6}.stage-sync-button:focus-visible{outline:2px solid var(--accent-green, #22c55e);outline-offset:2px}@media(min-width:768px){.stage-header{flex-direction:row;justify-content:space-between;align-items:center}}.stage-status{display:inline-flex;align-items:center;gap:.65rem;padding:.6rem 1rem;border-radius:999px;background:linear-gradient(135deg,#202a44d1,#121928d1);border:1px solid rgba(129,140,248,.25);font-weight:600;color:#e2f1ffd9;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;flex-wrap:wrap;justify-content:center;text-align:center}.stage-status-light{width:.65rem;height:.65rem;border-radius:50%;background:#94a3ff73;box-shadow:0 0 #818cf859;transition:background .2s ease,box-shadow .2s ease}.stage-status-light.online{background:#22c55e;box-shadow:0 0 0 6px #22c55e33}.stage-status-light.standby{background:#94a3ff59}.stage-divider{opacity:.4}.stage-setlist-name{font-weight:500;letter-spacing:.05em}.stage-live-toggle{border-radius:999px;border:1px solid rgba(226,241,255,.2);padding:.6rem 1.4rem;background:#e2f1ff1a;color:#f7f8ffe6;font-weight:700;text-transform:uppercase;letter-spacing:.12em;transition:background .2s ease,border-color .2s ease,color .2s ease}.stage-live-toggle:hover{border-color:#e2f1ff66;background:#e2f1ff33}.stage-live-toggle.locked{background:#22c55e24;border-color:#22c55e73;color:#bbf7d0}.stage-main{display:flex;flex-direction:column;gap:2rem;background:linear-gradient(180deg,#0e1423cc,#090f1beb);border-radius:2rem;border:1px solid rgba(255,255,255,.05);padding:2.5rem 2rem;box-shadow:0 18px 48px #05050f66;width:min(100%,420px);margin:0 auto}.stage-song-info{text-align:center;display:flex;flex-direction:column;gap:.6rem}.stage-song-info h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:.04em;text-transform:uppercase}.stage-song-meta{font-size:1.1rem;color:#d4e1ffb3;letter-spacing:.08em;text-transform:uppercase}.stage-beat-visual{display:flex;justify-content:center;align-items:center;min-height:220px}.stage-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.stage-control-btn{border-radius:1.5rem;padding:1.2rem;font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border:1px solid rgba(129,140,248,.25);background:#101626cc;color:#e8eef5d9;transition:transform .18s ease,background .18s ease,border-color .18s ease}.stage-control-btn.primary{font-size:1.4rem;padding:1.4rem 1.2rem}.stage-control-btn.primary.start{background:linear-gradient(135deg,#4ecdc4cc,#2aaba0d9);border-color:#2aaba0cc;color:#051b16}.stage-control-btn.primary.stop{background:linear-gradient(135deg,#f87171d9,#dc2626d9);border-color:#dc2626cc;color:#fffbf5}.stage-control-btn.secondary:hover:not(:disabled),.stage-control-btn.primary:hover:not(:disabled){transform:translateY(-2px);border-color:#e2e8ff99}.stage-control-btn:disabled{opacity:.4;cursor:not-allowed}.stage-toggles{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.stage-toggle{display:inline-flex;align-items:center;gap:.6rem;font-size:1rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.stage-footer{display:flex;flex-direction:column;gap:1.5rem;width:min(100%,420px);margin:0 auto}.stage-footer-grid{display:grid;gap:1rem}@media(min-width:768px){.stage-footer-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.stage-footer-card{background:#0b111ebf;border:1px solid rgba(255,255,255,.05);border-radius:1.1rem;padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;text-transform:uppercase;letter-spacing:.08em}.stage-footer-card h3{font-size:.85rem;color:#94a3ffb3}.stage-footer-card p{font-size:1rem;font-weight:600;color:#e8eef5d9}.stage-empty{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;padding:1.4rem;background:#080d19bf;border:1px dashed rgba(129,140,248,.4);border-radius:1rem;color:#d4e1ffbf}.stage-footer-links{display:flex;gap:.75rem;justify-content:center;align-items:center;font-size:.85rem;color:#d4e1ffa6}.stage-footer-links .link-button{background:none;border:none;color:#818cf8d9;text-decoration:underline;text-transform:uppercase;letter-spacing:.08em;font-weight:600;cursor:pointer}.stage-advanced-controls{display:flex;gap:10px;margin-top:15px;flex-wrap:wrap;justify-content:center}.stage-advanced-controls .btn-small{font-size:.8rem;padding:6px 12px}.stage-mode-view.high-contrast{background:#000}.stage-mode-view.high-contrast .stage-main{background:linear-gradient(180deg,#0a0a0a,#000);border-color:#fff3}.stage-mode-view.high-contrast .stage-song-info h1{color:#fff;text-shadow:0 4px 12px rgba(255,255,255,.3)}.stage-mode-view.high-contrast .stage-song-meta{color:#fffc}.stage-mode-view.high-contrast .stage-status{background:#0009;border-color:#fff6;color:#fff}.stage-mode-view.high-contrast .stage-control-btn{background:#ffffff26;border-color:#ffffff4d;color:#fff}.stage-mode-view.high-contrast .stage-control-btn:hover{background:#ffffff40;border-color:#ffffff80}.stage-mode-view.high-contrast .stage-control-btn.primary.start{background:#22c55e66;border-color:#22c55eb3;color:#fff}.stage-mode-view.high-contrast .stage-control-btn.primary.stop{background:#ef444466;border-color:#ef4444b3;color:#fff}.stage-mode-view.high-contrast .stage-toggle{color:#fff}.stage-mode-view.high-contrast .stage-footer{background:#000c;border-color:#fff3;width:min(100%,340px)}.stage-mode-view.high-contrast .stage-footer-card{background:#0009;border-color:#ffffff26}.stage-mode-view.high-contrast .stage-footer-card h3{color:#fff9}.stage-mode-view.high-contrast .stage-footer-card p{color:#fff}.stage-mode-view.high-contrast .stage-empty{background:#0009;border-color:#fff6;color:#fffc}.stage-mode-view.high-contrast .stage-lyrics{background:#0009;border-color:#ffffff4d}@media(max-width:1024px){.stage-mode-view{padding:2.25rem 1.25rem 5rem}.stage-main{padding:2rem 1.75rem;border-radius:1.75rem}}@media(max-width:768px){.stage-mode-view{gap:1.5rem;padding:2rem 1rem 4.5rem}.stage-header{gap:1.25rem;align-items:stretch;width:min(100%,360px)}.stage-header-actions{width:100%;justify-content:center;flex-wrap:wrap}.stage-live-toggle,.stage-sync-button{flex:1 1 12rem;text-align:center}.stage-main{padding:1.75rem 1.25rem;border-radius:1.5rem;width:min(100%,360px)}.stage-beat-visual{min-height:200px}.stage-controls{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.stage-controls .stage-control-btn.primary{grid-column:span 2}.stage-advanced-controls{gap:.75rem}.stage-advanced-controls .btn-small{flex:1 1 9rem}.stage-footer-grid{grid-template-columns:1fr}.stage-lyrics{max-width:100%}.stage-footer{width:min(100%,360px)}.stage-status{flex-direction:column;gap:.4rem}.stage-status .stage-divider{display:none}}@media(max-width:540px){.stage-mode-view{padding:1.75rem 1rem 4rem}.stage-header-actions{gap:.5rem}.stage-live-toggle,.stage-sync-button{flex:1 1 100%}.stage-main{padding:1.5rem 1rem;border-radius:1.25rem;width:min(100%,340px)}.stage-song-info h1{font-size:clamp(1.75rem,7vw,2.4rem)}.stage-song-meta{font-size:.95rem}.stage-control-btn{padding:1rem;font-size:1rem}.stage-toggles{gap:.85rem}.stage-toggles label span{font-size:.85rem}.stage-advanced-controls .btn-small{flex:1 1 100%}.stage-status{gap:.35rem}.stage-lyrics{max-height:40vh}}
