*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;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}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.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}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.right-0{right:0}.right-3{right:.75rem}.right-5{right:1.25rem}.top-0{top:0}.top-14{top:3.5rem}.top-3{top:.75rem}.top-5{top:1.25rem}.z-10{z-index:10}.z-50{z-index:50}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-11{height:2.75rem}.h-12{height:3rem}.h-16{height:4rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.max-h-\[85vh\]{max-height:85vh}.min-h-\[300px\]{min-height:300px}.min-h-\[44px\]{min-height:44px}.min-h-\[60vh\]{min-height:60vh}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-16{width:4rem}.w-3{width:.75rem}.w-32{width:8rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.min-w-\[44px\]{min-width:44px}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.border-red-500\/50{border-color:#ef444480}.border-slate-700{--tw-border-opacity: 1;border-color:rgb(51 65 85 / var(--tw-border-opacity, 1))}.border-slate-800\/50{border-color:#1e293b80}.border-teal-500{--tw-border-opacity: 1;border-color:rgb(20 184 166 / var(--tw-border-opacity, 1))}.border-white\/30{border-color:#ffffff4d}.border-t-transparent{border-top-color:transparent}.border-t-white{--tw-border-opacity: 1;border-top-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.bg-black\/70{background-color:#000000b3}.bg-blue-500\/20{background-color:#3b82f633}.bg-emerald-500\/20{background-color:#10b98133}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-900\/80{background-color:#111827cc}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-500\/20{background-color:#22c55e33}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))}.bg-purple-500\/20{background-color:#a855f733}.bg-red-500\/20{background-color:#ef444433}.bg-red-900\/30{background-color:#7f1d1d4d}.bg-slate-700{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity, 1))}.bg-slate-800{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity, 1))}.bg-slate-900{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity, 1))}.bg-slate-900\/50{background-color:#0f172a80}.bg-teal-500{--tw-bg-opacity: 1;background-color:rgb(20 184 166 / var(--tw-bg-opacity, 1))}.bg-teal-900\/30{background-color:#134e4a4d}.bg-yellow-500\/20{background-color:#eab30833}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-teal-400{--tw-gradient-from: #2dd4bf var(--tw-gradient-from-position);--tw-gradient-to: rgb(45 212 191 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-teal-500{--tw-gradient-from: #14b8a6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(20 184 166 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-orange-400{--tw-gradient-to: #fb923c var(--tw-gradient-to-position)}.to-teal-400{--tw-gradient-to: #2dd4bf var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-contain{-o-object-fit:contain;object-fit:contain}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-4{padding-bottom:1rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-relaxed{line-height:1.625}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.text-cyan-500{--tw-text-opacity: 1;color:rgb(6 182 212 / var(--tw-text-opacity, 1))}.text-gray-100{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-green-500{--tw-text-opacity: 1;color:rgb(34 197 94 / var(--tw-text-opacity, 1))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity, 1))}.text-orange-500{--tw-text-opacity: 1;color:rgb(249 115 22 / var(--tw-text-opacity, 1))}.text-pink-400{--tw-text-opacity: 1;color:rgb(244 114 182 / var(--tw-text-opacity, 1))}.text-pink-500{--tw-text-opacity: 1;color:rgb(236 72 153 / var(--tw-text-opacity, 1))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-purple-500{--tw-text-opacity: 1;color:rgb(168 85 247 / var(--tw-text-opacity, 1))}.text-red-300{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-teal-300{--tw-text-opacity: 1;color:rgb(94 234 212 / var(--tw-text-opacity, 1))}.text-teal-400{--tw-text-opacity: 1;color:rgb(45 212 191 / var(--tw-text-opacity, 1))}.text-teal-500{--tw-text-opacity: 1;color:rgb(20 184 166 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.accent-teal-500{accent-color:#14b8a6}.opacity-50{opacity:.5}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-teal-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(20 184 166 / var(--tw-ring-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@keyframes fade-in-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in-up{animation:fade-in-up .6s ease-out forwards;opacity:0}.animate-fade-in-scale{animation:fade-in-scale .5s ease-out forwards;opacity:0}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.delay-600{animation-delay:.6s}.delay-700{animation-delay:.7s}.delay-800{animation-delay:.8s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #14b8a64d}50%{box-shadow:0 0 40px #14b8a680}}.animate-float{animation:float 4s ease-in-out infinite}.animate-pulse-glow{animation:pulse-glow 3s ease-in-out infinite}.btn-elite{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-elite:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-elite:hover:before{left:100%}.btn-elite:hover{transform:translateY(-2px);box-shadow:0 10px 40px #14b8a666}.btn-elite:active{transform:translateY(0)}.card-elite{transition:all .3s cubic-bezier(.4,0,.2,1)}.card-elite:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.glow-border{position:relative}.glow-border:after{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,#14b8a6,#f97316,#14b8a6);border-radius:inherit;z-index:-1;opacity:0;transition:opacity .3s}.glow-border:hover:after{opacity:1;filter:blur(8px)}.hero-gradient{background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(20,184,166,.15),transparent),radial-gradient(ellipse 60% 40% at 80% 60%,rgba(249,115,22,.1),transparent),radial-gradient(ellipse 50% 30% at 20% 80%,rgba(20,184,166,.1),transparent)}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.text-shimmer{background:linear-gradient(90deg,#2dd4bf,#fff,#2dd4bf,#fb923c,#2dd4bf);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s linear infinite}.gradient-text{background:linear-gradient(135deg,#2dd4bf,#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.controls-panel-glass{background:#1e293bcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d}@keyframes pulse-play{0%,to{box-shadow:0 0 #22c55e80;transform:scale(1)}50%{box-shadow:0 0 0 12px #22c55e00;transform:scale(1.02)}}.btn-play{position:relative;transition:all .2s ease-in-out}.btn-play:hover:not(:disabled){transform:scale(1.05);box-shadow:0 0 20px #22c55e66}.btn-play:active:not(:disabled){transform:scale(.98)}.btn-play.playing{animation:pulse-play 1.5s ease-in-out infinite}.btn-stop{transition:all .2s ease-in-out}.btn-stop:hover{transform:scale(1.05);box-shadow:0 0 20px #ef444466}.btn-loop{transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.btn-loop.active{box-shadow:0 0 20px #f9731680,0 0 40px #f973164d}.btn-loop.active:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,#f97316,#fb923c,#f97316);border-radius:inherit;z-index:-1;animation:rotate-glow 3s linear infinite;filter:blur(4px)}@keyframes rotate-glow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tempo-slider{-moz-appearance:none;appearance:none;-webkit-appearance:none;height:8px;border-radius:4px;background:linear-gradient(90deg,#334155,#475569);outline:none}.tempo-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#2dd4bf);cursor:pointer;box-shadow:0 0 10px #14b8a680;-webkit-transition:all .2s ease;transition:all .2s ease}.tempo-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 20px #14b8a6b3}.tempo-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#2dd4bf);cursor:pointer;border:none;box-shadow:0 0 10px #14b8a680}.progress-bar-elite{height:6px;border-radius:3px;background:linear-gradient(90deg,#334155,#475569);overflow:hidden;position:relative}.progress-bar-elite .fill{height:100%;background:linear-gradient(90deg,#14b8a6,#2dd4bf,#f97316);background-size:200% 100%;animation:gradient-flow 2s linear infinite;transition:width .1s linear}@keyframes gradient-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}.sheet-music-container{position:relative;border-radius:12px;overflow:hidden}.sheet-music-container:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#14b8a64d,#f973164d);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.metronome-toggle{position:relative;width:48px;height:24px;background:#334155;border-radius:12px;cursor:pointer;transition:all .3s ease}.metronome-toggle.active{background:linear-gradient(135deg,#14b8a6,#2dd4bf)}.metronome-toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 4px #0003}.metronome-toggle.active:after{transform:translate(24px)}.spinner-elite{width:40px;height:40px;border:3px solid rgba(20,184,166,.2);border-top-color:#14b8a6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header-elite{background:linear-gradient(135deg,#14b8a61a,#f973161a);border-bottom:1px solid rgba(255,255,255,.1)}.at-cursor-bar{background:linear-gradient(180deg,#14b8a6,#2dd4bf)!important;width:3px!important;opacity:.9!important;box-shadow:0 0 10px #14b8a699,0 0 20px #14b8a666!important;border-radius:2px!important}.at-cursor-beat{background:#f973164d!important;border-left:2px solid #f97316!important;transition:left .05s linear!important}.at-selection div{background:#14b8a633!important;border:1px solid rgba(20,184,166,.5)!important;border-radius:4px!important}.at-highlight *{fill:#f97316!important;color:#f97316!important}.at-main{scroll-behavior:smooth!important}.tabplayer-viewport{max-height:600px;overflow-x:hidden;overflow-y:auto;scroll-behavior:smooth;position:relative;width:100%;max-width:900px;margin:0 auto}.tabplayer-viewport canvas{display:block}.at-bar-cursor{background:linear-gradient(90deg,#14b8a60d,#14b8a626,#14b8a60d)!important}@keyframes note-pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.at-note-active{animation:note-pulse .15s ease-out!important}.at-cursor-countdown{background:#f9731680!important;border:2px dashed #f97316!important}.at-loading{background:#1e293be6!important;color:#14b8a6!important}.at-track{background:#1e293b99!important;border-bottom:1px solid rgba(20,184,166,.3)!important}.at-surface{background:transparent!important}.tabplayer-viewport::-webkit-scrollbar{height:8px}.tabplayer-viewport::-webkit-scrollbar-track{background:#1e293b;border-radius:4px}.tabplayer-viewport::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#14b8a6,#2dd4bf);border-radius:4px}.tabplayer-viewport::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#2dd4bf,#14b8a6)}.tabplayer-viewport text,.tabplayer-viewport .at-surface text,.at-surface text,.at-main text{fill:#fff!important}.tabplayer-viewport svg text,.at-surface svg text{fill:#fff!important}[class*=at-] text{fill:#fff!important}.btn-play{width:56px;height:56px;border-radius:50%;background:linear-gradient(145deg,#2ade6a,#18a84a);box-shadow:0 4px 15px #22c55e66,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003;transition:all .15s ease;border:2px solid rgba(255,255,255,.1);color:#fff;font-weight:700}.btn-play:hover{transform:scale(1.08);box-shadow:0 6px 25px #22c55e99,inset 0 2px 4px #ffffff4d}.btn-play:active{transform:scale(.95);box-shadow:0 2px 10px #22c55e66,inset 0 -2px 4px #ffffff1a}.btn-play.playing{animation:pulse-play 1.5s infinite;background:linear-gradient(145deg,#4ade80,#22c55e)}@keyframes pulse-play{0%,to{box-shadow:0 0 #22c55e80,0 4px 15px #22c55e66}50%{box-shadow:0 0 0 15px #22c55e00,0 4px 15px #22c55e66}}.btn-stop{width:56px;height:56px;border-radius:50%;background:linear-gradient(145deg,#f87171,#dc2626);box-shadow:0 4px 15px #ef444466,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003;transition:all .15s ease;border:2px solid rgba(255,255,255,.1);color:#fff;font-weight:700}.btn-stop:hover{transform:scale(1.08);box-shadow:0 6px 25px #ef444499,inset 0 2px 4px #ffffff4d}.btn-stop:active{transform:scale(.95)}.btn-loop{height:44px;padding:0 20px;border-radius:22px;background:linear-gradient(145deg,#475569,#334155);box-shadow:0 4px 12px #0000004d,inset 0 1px 2px #ffffff1a;transition:all .15s ease;border:2px solid rgba(255,255,255,.05);font-weight:600;letter-spacing:.5px;color:#fff}.btn-loop:hover{transform:scale(1.05);background:linear-gradient(145deg,#64748b,#475569)}.btn-loop:active{transform:scale(.97)}.btn-loop.active{background:linear-gradient(145deg,#fb923c,#ea580c);box-shadow:0 4px 20px #f9731680,inset 0 1px 2px #fff3;animation:loop-glow 2s ease-in-out infinite}@keyframes loop-glow{0%,to{box-shadow:0 4px 15px #f9731666}50%{box-shadow:0 4px 25px #f97316b3,0 0 30px #f973164d}}.tempo-label{color:#14b8a6;font-weight:600;text-shadow:0 0 10px rgba(20,184,166,.3)}.metronome-switch{width:52px;height:28px;border-radius:14px;background:linear-gradient(145deg,#334155,#1e293b);box-shadow:inset 0 2px 4px #0000004d,0 1px 2px #ffffff0d;transition:all .2s ease;cursor:pointer;position:relative}.metronome-switch:after{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:linear-gradient(145deg,#64748b,#475569);top:3px;left:3px;transition:all .2s ease;box-shadow:0 2px 4px #0000004d}.metronome-switch.active{background:linear-gradient(145deg,#14b8a6,#0d9488)}.metronome-switch.active:after{left:27px;background:linear-gradient(145deg,#fff,#e2e8f0)}.fretboard-elite{background:linear-gradient(180deg,#1a1a1a,#0d0d0d);border:1px solid rgba(20,184,166,.2);border-radius:12px;box-shadow:0 4px 20px #00000080,inset 0 1px #ffffff0d,0 0 40px #14b8a60d;position:relative;overflow:hidden}.fretboard-elite:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(139,90,43,.03) 2px,rgba(139,90,43,.03) 4px);pointer-events:none}.fret-inlay{position:absolute;width:8px;height:8px;border-radius:50%;background:radial-gradient(circle,#e2e8f0,#94a3b8);box-shadow:inset 0 1px 2px #0000004d;opacity:.6}.string-elite{transition:all .15s ease}.string-elite:hover{background:#14b8a61a}.fret-dot-elite{transition:all .15s ease;box-shadow:0 2px 4px #0000004d}.fret-dot-root{background:linear-gradient(145deg,#14b8a6,#0d9488);box-shadow:0 2px 8px #14b8a680,inset 0 1px 2px #ffffff4d}.fret-dot-scale{background:linear-gradient(145deg,#64748b,#475569);box-shadow:0 2px 4px #0000004d,inset 0 1px 2px #ffffff1a}.fret-dot-active{background:linear-gradient(145deg,#fb923c,#ea580c);box-shadow:0 0 20px #f97316b3,0 2px 8px #f9731680,inset 0 1px 2px #ffffff4d;animation:note-pulse .3s ease-out}@keyframes note-pulse{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1.25)}}.pattern-btn-elite{background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(100,116,139,.3);border-radius:12px;transition:all .2s ease;position:relative;overflow:hidden}.pattern-btn-elite:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 50%);pointer-events:none}.pattern-btn-elite:hover{transform:translateY(-2px);border-color:#14b8a666;box-shadow:0 8px 25px #0000004d,0 0 20px #14b8a61a}.pattern-btn-elite:active{transform:translateY(0)}.pattern-btn-elite.selected{background:linear-gradient(145deg,#14b8a626,#14b8a60d);border-color:#14b8a6;box-shadow:0 0 20px #14b8a633,inset 0 1px #14b8a633}.root-btn-elite{background:linear-gradient(145deg,#334155,#1e293b);border:1px solid rgba(100,116,139,.3);border-radius:8px;font-weight:600;transition:all .15s ease;position:relative}.root-btn-elite:hover{transform:scale(1.05);border-color:#14b8a680;box-shadow:0 4px 12px #0000004d}.root-btn-elite.selected{background:linear-gradient(145deg,#14b8a6,#0d9488);border-color:#2dd4bf;color:#fff;box-shadow:0 4px 15px #14b8a666,inset 0 1px 2px #fff3;animation:root-glow 2s ease-in-out infinite}@keyframes root-glow{0%,to{box-shadow:0 4px 12px #14b8a64d}50%{box-shadow:0 4px 20px #14b8a680,0 0 25px #14b8a633}}.export-btn-elite{background:linear-gradient(145deg,#334155,#1e293b);border:1px solid rgba(100,116,139,.3);border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s ease;position:relative;overflow:hidden}.export-btn-elite:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .4s ease}.export-btn-elite:hover:before{left:100%}.export-btn-elite:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.export-btn-copy{border-color:#64748b80}.export-btn-tab{background:linear-gradient(145deg,#14b8a6,#0d9488);border-color:#2dd4bf;color:#fff}.export-btn-tab:hover{box-shadow:0 4px 15px #14b8a666}.export-btn-midi{background:linear-gradient(145deg,#f97316,#ea580c);border-color:#fb923c;color:#fff}.export-btn-midi:hover{box-shadow:0 4px 15px #f9731666}.export-btn-gp5{background:linear-gradient(145deg,#a855f7,#9333ea);border-color:#c084fc;color:#fff}.export-btn-gp5:hover{box-shadow:0 4px 15px #a855f766}.settings-panel-elite{background:#1e293bcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(100,116,139,.2);border-radius:16px;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d}.section-header-elite{color:#14b8a6;font-weight:600;font-size:1.1rem;text-shadow:0 0 20px rgba(20,184,166,.3);position:relative;padding-bottom:8px}.section-header-elite:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:2px;background:linear-gradient(90deg,#14b8a6,transparent)}.tab-display-elite{background:linear-gradient(145deg,#0f172a,#020617);border:1px solid rgba(20,184,166,.3);border-radius:12px;box-shadow:0 4px 20px #0006,inset 0 1px #ffffff05;font-family:JetBrains Mono,Fira Code,monospace}.tab-text-elite{color:#4ade80;text-shadow:0 0 10px rgba(74,222,128,.2)}.progress-elite{height:4px;background:linear-gradient(90deg,#1e293b,#334155);border-radius:2px;overflow:hidden;position:relative}.progress-elite-fill{height:100%;background:linear-gradient(90deg,#14b8a6,#2dd4bf,#14b8a6);background-size:200% 100%;animation:progress-shimmer 2s linear infinite;border-radius:2px;box-shadow:0 0 10px #14b8a680;transition:width .1s ease}@keyframes progress-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.shortcuts-panel-elite{background:#1e293b80;border:1px solid rgba(100,116,139,.15);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.kbd-elite{background:linear-gradient(145deg,#334155,#1e293b);border:1px solid rgba(100,116,139,.3);border-radius:6px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:12px;color:#e2e8f0;box-shadow:0 2px 4px #0003,inset 0 1px #ffffff0d}.slider-elite{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:linear-gradient(90deg,#1e293b,#334155);border-radius:3px;outline:none}.slider-elite::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(145deg,#14b8a6,#0d9488);cursor:pointer;box-shadow:0 2px 8px #14b8a666,inset 0 1px 2px #fff3;-webkit-transition:all .15s ease;transition:all .15s ease}.slider-elite::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 15px #14b8a680,inset 0 1px 2px #fff3}.slider-elite::-moz-range-thumb{width:18px;height:18px;border:none;border-radius:50%;background:linear-gradient(145deg,#14b8a6,#0d9488);cursor:pointer;box-shadow:0 2px 8px #14b8a666,inset 0 1px 2px #fff3}.select-elite{background:linear-gradient(145deg,#1e293b,#0f172a);border:1px solid rgba(100,116,139,.3);border-radius:8px;padding:10px 14px;color:#e2e8f0;font-size:14px;transition:all .2s ease;cursor:pointer}.select-elite:hover{border-color:#14b8a680}.select-elite:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a633;outline:none}.scale-info-elite{background:linear-gradient(145deg,#14b8a61a,#14b8a60d);border:1px solid rgba(20,184,166,.2);border-radius:10px;padding:12px 16px}.scale-notes-display{font-family:JetBrains Mono,monospace;color:#2dd4bf;letter-spacing:.05em}.interactive-fretboard-container{background:linear-gradient(180deg,#1a1a1a,#0d0d0d);border-radius:12px;padding:16px;border:1px solid rgba(20,184,166,.3);box-shadow:0 4px 20px #0006,inset 0 1px #ffffff0d;overflow-x:auto}.fretboard-fret-numbers{display:flex;padding-left:28px;margin-bottom:4px}.fret-number-label{width:28px;flex-shrink:0}.fret-number{font-size:10px;color:#64748b;text-align:center;font-family:JetBrains Mono,monospace}.fret-marker-number{color:#94a3b8;font-weight:600}.fretboard-body{display:flex;flex-direction:column;gap:2px}.fretboard-string-row{display:flex;align-items:center;height:28px}.string-label{width:24px;font-size:12px;font-family:JetBrains Mono,monospace;color:#64748b;text-align:center;flex-shrink:0}.string-frets{display:flex;flex:1;height:100%;border-bottom:2px solid #475569;position:relative}.fret-cell{position:relative;display:flex;align-items:center;justify-content:center;border-right:1px solid #374151;cursor:pointer;transition:background-color .15s ease;min-width:32px}.fret-cell:hover{background-color:#14b8a61a}.fret-cell.nut-fret{border-left:4px solid #94a3b8;background:linear-gradient(90deg,rgba(148,163,184,.1) 0%,transparent 100%)}.fret-marker-dot{position:absolute;width:6px;height:6px;border-radius:50%;background:#475569;opacity:.5;pointer-events:none}.fret-note-dot{width:24px;height:24px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:9px;font-weight:700;cursor:pointer;transition:all .15s ease;position:relative;z-index:1}.fret-note-dot .note-label{font-size:8px;opacity:.8}.fret-note-dot .fret-label{font-size:10px;font-weight:700}.fret-note-dot.note-scale{background:linear-gradient(135deg,#374151,#1f2937);color:#94a3b8;border:1px solid #4b5563}.fret-note-dot.note-scale:hover{background:linear-gradient(135deg,#475569,#374151);transform:scale(1.1)}.fret-note-dot.note-root{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:2px solid #2dd4bf;box-shadow:0 0 12px #14b8a680;animation:root-pulse 2s ease-in-out infinite}.fret-note-dot.note-active{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:2px solid #fb923c;box-shadow:0 0 20px #f97316cc;transform:scale(1.3);animation:active-pulse .3s ease-in-out}@keyframes root-pulse{0%,to{box-shadow:0 0 12px #14b8a680}50%{box-shadow:0 0 20px #14b8a6cc}}@keyframes active-pulse{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1.3)}}.fretboard-legend{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid #374151;font-size:12px}.legend-item{display:flex;align-items:center;gap:6px;color:#94a3b8}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);border:1px solid #2dd4bf}.legend-dot.scale{background:linear-gradient(135deg,#374151,#1f2937);border:1px solid #4b5563}.legend-dot.active{background:linear-gradient(135deg,#f97316,#ea580c);border:1px solid #fb923c}.legend-status{display:flex;align-items:center;gap:6px;color:#22c55e;margin-left:auto}.status-pulse{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:status-blink 1s ease-in-out infinite}@keyframes status-blink{0%,to{opacity:1}50%{opacity:.3}}.daw-controls-panel{background:linear-gradient(180deg,#1e293be6,#0f172af2);border-radius:16px;padding:20px;border:1px solid rgba(20,184,166,.2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d}.daw-controls-row{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.daw-btn{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 4px 12px #0000004d,inset 0 2px #ffffff1a,inset 0 -2px #0003}.daw-btn:active{transform:scale(.95)}.daw-btn-play{background:linear-gradient(180deg,#22c55e,#16a34a);color:#fff}.daw-btn-play:hover{background:linear-gradient(180deg,#4ade80,#22c55e);box-shadow:0 4px 20px #22c55e80,inset 0 2px #ffffff1a}.daw-btn-stop{background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff;animation:playing-pulse 1s ease-in-out infinite}.daw-btn-stop:hover{background:linear-gradient(180deg,#f87171,#ef4444)}@keyframes playing-pulse{0%,to{box-shadow:0 4px 12px #ef44444d}50%{box-shadow:0 4px 24px #ef444499}}.daw-btn-loop{background:linear-gradient(180deg,#475569,#334155);color:#94a3b8;width:44px;height:44px;font-size:16px}.daw-btn-loop.active{background:linear-gradient(180deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 4px 16px #14b8a680,inset 0 2px #ffffff1a}.daw-btn-metronome{background:linear-gradient(180deg,#475569,#334155);color:#94a3b8;width:44px;height:44px;font-size:16px}.daw-btn-metronome.active{background:linear-gradient(180deg,#f97316,#ea580c);color:#fff;box-shadow:0 4px 16px #f9731680,inset 0 2px #ffffff1a}.daw-btn-regen{background:linear-gradient(180deg,#6366f1,#4f46e5);color:#fff;width:44px;height:44px;font-size:18px}.daw-btn-regen:hover{background:linear-gradient(180deg,#818cf8,#6366f1);box-shadow:0 4px 16px #6366f180,inset 0 2px #ffffff1a}.daw-tempo-display{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:#0f172acc;border-radius:8px;border:1px solid #334155}.daw-tempo-display .tempo-value{font-size:24px;font-weight:700;color:#2dd4bf;font-family:JetBrains Mono,monospace;text-shadow:0 0 10px rgba(45,212,191,.5)}.daw-tempo-display .tempo-unit{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.1em}.daw-progress-container{margin-top:16px}.daw-progress-bar{height:8px;background:#1e293b;border-radius:4px;overflow:hidden;border:1px solid #334155}.daw-progress-fill{height:100%;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:4px;transition:width .1s linear;box-shadow:0 0 12px #14b8a680}.daw-progress-labels{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12px;color:#64748b}.loop-indicator{color:#14b8a6;font-weight:500}.playing-indicator{color:#22c55e;animation:status-blink 1s ease-in-out infinite}.open-tabplayer-btn{padding:8px 16px;background:linear-gradient(135deg,#14b8a633,#14b8a61a);border:1px solid rgba(20,184,166,.3);border-radius:8px;color:#2dd4bf;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s ease}.open-tabplayer-btn:hover{background:linear-gradient(135deg,#14b8a64d,#14b8a633);border-color:#14b8a6;box-shadow:0 4px 12px #14b8a64d;transform:translateY(-1px)}.tab-with-cursor{position:relative}.navbar-elite{background:#0f172ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(20,184,166,.2);box-shadow:0 4px 20px #0000004d}.navbar-logo{transition:all .3s ease;padding:4px 8px;border-radius:8px}.navbar-logo:hover{transform:scale(1.05);text-shadow:0 0 20px rgba(20,184,166,.5)}.navbar-logo:hover div{filter:drop-shadow(0 0 8px rgba(20,184,166,.6))}.nav-link{transition:all .2s ease;position:relative;color:#cbd5e1}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:linear-gradient(90deg,#14b8a6,#f97316);transition:all .3s ease;transform:translate(-50%)}.nav-link:hover:after{width:80%}.nav-link-teal{color:#cbd5e1}.nav-link-teal:hover{color:#2dd4bf;background:#14b8a61a}.nav-link-orange{color:#cbd5e1}.nav-link-orange:hover{color:#fb923c;background:#f973161a}.nav-link-active-teal{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;box-shadow:0 0 15px #14b8a666;animation:active-glow-teal 2s ease-in-out infinite}@keyframes active-glow-teal{0%,to{box-shadow:0 0 10px #14b8a666}50%{box-shadow:0 0 20px #14b8a699}}.nav-link-active-orange{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;box-shadow:0 0 15px #f9731666;animation:active-glow-orange 2s ease-in-out infinite}@keyframes active-glow-orange{0%,to{box-shadow:0 0 10px #f9731666}50%{box-shadow:0 0 20px #f9731699}}.mobile-menu-btn{background:#1e293bcc;border:1px solid rgba(20,184,166,.3);transition:all .2s ease}.mobile-menu-btn:hover{background:#14b8a633;border-color:#14b8a6;box-shadow:0 0 12px #14b8a64d}.mobile-menu{background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(20,184,166,.2);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-nav-link{background:#1e293b99;border:1px solid rgba(51,65,85,.5);transition:all .2s ease;color:#cbd5e1}.mobile-nav-link:hover{border-color:#14b8a680;transform:translateY(-2px)}.more-dropdown{background:#0f172af2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(20,184,166,.3);animation:dropdownSlide .2s ease-out;z-index:60}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-link{color:#cbd5e1;transition:all .15s ease;position:relative}.dropdown-link:hover{color:#2dd4bf;background:#14b8a61a;padding-left:1.25rem}.dropdown-link-active{color:#14b8a6;background:#14b8a626;border-left:3px solid #14b8a6}.dropdown-link-active:hover{background:#14b8a633}.tuner-page{background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);min-height:100vh}.tuner-page-inner{max-width:56rem;margin:0 auto;padding:2rem 1rem}.tuner-header{text-align:center;margin-bottom:2.5rem;position:relative}.tuner-header:after{content:"";position:absolute;bottom:-1rem;left:50%;transform:translate(-50%);width:120px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.tuner-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#14b8a6,#2dd4bf,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.tuner-subtitle{color:#94a3b8;font-size:1rem}.tuner-control-panel{background:#1e293bcc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(20,184,166,.2);border-radius:1rem;padding:2rem;margin-bottom:1.5rem;text-align:center;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.tuner-button-start{width:160px;height:160px;border-radius:50%;font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:.05em;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer;border:none;outline:none}.tuner-button-inactive{background:linear-gradient(180deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 8px 32px #14b8a666,inset 0 2px #fff3,inset 0 -2px #0003}.tuner-button-inactive:hover{transform:scale(1.05);box-shadow:0 12px 48px #14b8a680,inset 0 2px #fff3,inset 0 -2px #0003}.tuner-button-active{background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff;box-shadow:0 8px 32px #ef444466,inset 0 2px #fff3,inset 0 -2px #0003;animation:tuner-pulse 2s ease-in-out infinite}.tuner-button-active:hover{transform:scale(1.05)}@keyframes tuner-pulse{0%,to{box-shadow:0 8px 32px #ef444466,inset 0 2px #fff3,inset 0 -2px #0003}50%{box-shadow:0 8px 48px #ef444499,inset 0 2px #fff3,inset 0 -2px #0003,0 0 0 8px #ef444433}}.tuner-button-ring{position:absolute;inset:-8px;border-radius:50%;border:2px solid rgba(255,255,255,.1);pointer-events:none}.tuner-listening-text{color:#94a3b8;font-size:1rem;margin-top:1.5rem;animation:tuner-fade 1.5s ease-in-out infinite}@keyframes tuner-fade{0%,to{opacity:.5}50%{opacity:1}}.tuner-error{margin-top:1rem;padding:1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#fca5a5}.tuner-gauge-panel{background:#1e293bcc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(20,184,166,.2);border-radius:1rem;padding:2rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.tuner-note-display{text-align:center;margin-bottom:1.5rem}.tuner-note-name{font-size:4.5rem;font-weight:800;line-height:1;transition:color .3s ease}.tuner-note-status{font-size:1.5rem;font-weight:600;margin-top:.5rem;transition:color .3s ease}.tuner-note-string{font-size:1rem;color:#94a3b8;margin-top:.25rem}.tuner-pitch-indicator{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-bottom:1rem}.tuner-pitch-marker{width:12px;height:12px;border-radius:50%;background:#334155;transition:all .2s ease}.tuner-pitch-marker.flat{background:#3b82f6;box-shadow:0 0 12px #3b82f699}.tuner-pitch-marker.sharp{background:#f97316;box-shadow:0 0 12px #f9731699}.tuner-pitch-marker.perfect{background:#14b8a6;box-shadow:0 0 16px #14b8a6cc;animation:tuner-perfect-glow 1s ease-in-out infinite}@keyframes tuner-perfect-glow{0%,to{box-shadow:0 0 16px #14b8a6cc;transform:scale(1)}50%{box-shadow:0 0 24px #14b8a6;transform:scale(1.2)}}.tuner-detection-circles{display:flex;justify-content:center;gap:8px;margin-bottom:1.5rem}.tuner-detection-dot{width:24px;height:24px;border-radius:50%;background:#33415580;border:2px solid #475569;transition:all .2s ease;position:relative}.tuner-detection-dot.active{background:#14b8a64d;border-color:#14b8a6;box-shadow:0 0 12px #14b8a680}.tuner-detection-dot.active:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:#14b8a6}.tuner-detection-dot-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:10px;color:#64748b}.tuner-gauge-canvas{display:flex;justify-content:center;margin-bottom:1.5rem}.tuner-gauge-canvas canvas{max-width:100%;height:auto}.tuner-freq-info{text-align:center;display:flex;flex-direction:column;gap:.5rem}.tuner-freq-row{font-size:1rem;color:#94a3b8}.tuner-freq-value{font-family:ui-monospace,monospace;font-weight:700}.tuner-freq-detected{color:#60a5fa}.tuner-freq-target{color:#14b8a6}.tuner-reference-panel{background:#1e293bcc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(20,184,166,.2);border-radius:1rem;padding:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.tuner-reference-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.tuner-string-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:768px){.tuner-string-grid{grid-template-columns:repeat(3,1fr)}}.tuner-string-card{padding:1rem;background:#33415566;border:2px solid #475569;border-radius:.75rem;text-align:center;transition:all .3s ease;cursor:default}.tuner-string-card:hover{border-color:#14b8a680;background:#14b8a61a;transform:translateY(-2px)}.tuner-string-card.detected{border-color:#14b8a6;background:#14b8a626;box-shadow:0 0 20px #14b8a64d,inset 0 0 20px #14b8a61a}.tuner-string-num{font-size:.75rem;color:#64748b;margin-bottom:.25rem}.tuner-string-name{font-size:1.75rem;font-weight:700;color:#14b8a6}.tuner-string-freq{font-size:.75rem;color:#64748b;font-family:ui-monospace,monospace;margin-top:.25rem}.tuner-instructions{background:#1e293bcc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(20,184,166,.2);border-radius:1rem;padding:1.5rem;margin-top:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.tuner-instructions-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.tuner-instructions-list{list-style:decimal;list-style-position:inside;color:#cbd5e1}.tuner-instructions-list li{margin-bottom:.75rem;line-height:1.5}.tuner-instructions-list ul{list-style:disc;list-style-position:inside;margin-left:1.5rem;margin-top:.5rem}.tuner-instructions-list .flat-hint{color:#3b82f6}.tuner-instructions-list .perfect-hint{color:#14b8a6}.tuner-instructions-list .sharp-hint{color:#f97316}.tuner-back-link{display:inline-flex;align-items:center;gap:.5rem;color:#14b8a6;transition:all .2s ease;margin-bottom:1.5rem}.tuner-back-link:hover{color:#2dd4bf;transform:translate(-4px)}.tuner-meter-svg{width:100%;max-width:400px;height:auto}.tuner-meter-arc{fill:none;stroke:#334155;stroke-width:20;stroke-linecap:round}.tuner-meter-needle{fill:none;stroke:#14b8a6;stroke-width:4;stroke-linecap:round;transition:all .15s ease-out;filter:drop-shadow(0 0 8px rgba(20,184,166,.5))}.tuner-meter-needle.flat{stroke:#3b82f6;filter:drop-shadow(0 0 8px rgba(59,130,246,.5))}.tuner-meter-needle.sharp{stroke:#f97316;filter:drop-shadow(0 0 8px rgba(249,115,22,.5))}.tuner-meter-needle.perfect{stroke:#14b8a6;filter:drop-shadow(0 0 12px rgba(20,184,166,.8))}.tuner-meter-center{fill:#14b8a6;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.tuner-cents-display{text-align:center;margin-top:1rem}.tuner-cents-value{font-size:2rem;font-weight:700;font-family:ui-monospace,monospace;transition:color .3s ease}.tuner-cents-label{font-size:.875rem;color:#64748b}.metronome-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.metronome-header{text-align:center;margin-bottom:2rem}.metronome-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#14b8a6,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.metronome-title:before{content:"";display:block;width:60px;height:4px;background:linear-gradient(90deg,#14b8a6,#f97316);margin:0 auto 1rem;border-radius:2px}.metronome-subtitle{color:#94a3b8;font-size:1rem}.metronome-control-panel{background:#1e293bcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(20,184,166,.3);border-radius:1rem;padding:2rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0000004d}.metronome-beat-container{display:flex;justify-content:center;margin-bottom:2rem}.metronome-beat-circle{width:12rem;height:12rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:700;transition:all .1s ease;position:relative;background:#334155cc;color:#64748b;border:3px solid #334155}.metronome-beat-circle.downbeat{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;transform:scale(1.1);box-shadow:0 0 40px #14b8a680;border-color:#14b8a6}.metronome-beat-circle.upbeat{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;transform:scale(1.1);box-shadow:0 0 40px #f9731680;border-color:#f97316}.metronome-beat-ring{position:absolute;inset:0;border-radius:50%;border:3px solid currentColor;animation:metronome-ping .5s ease-out;opacity:0}@keyframes metronome-ping{0%{transform:scale(1);opacity:.8}to{transform:scale(1.3);opacity:0}}.metronome-button-start{width:100%;padding:1rem 1.5rem;border-radius:.75rem;font-size:1.125rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:none;cursor:pointer;transition:all .2s ease}.metronome-button-start.inactive{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;box-shadow:0 4px 15px #14b8a666,inset 0 1px #fff3}.metronome-button-start.inactive:hover{transform:translateY(-2px);box-shadow:0 6px 20px #14b8a680,inset 0 1px #fff3}.metronome-button-start.active{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 15px #ef444466,inset 0 1px #fff3;animation:metronome-active-pulse 1s ease-in-out infinite}@keyframes metronome-active-pulse{0%,to{box-shadow:0 4px 15px #ef444466}50%{box-shadow:0 4px 25px #ef444499}}.metronome-button-tap{width:100%;padding:1rem 1.5rem;border-radius:.75rem;font-size:1.125rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:none;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 15px #3b82f666,inset 0 1px #fff3}.metronome-button-tap:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.metronome-button-tap:disabled{opacity:.5;cursor:not-allowed}.metronome-tempo-section{margin-bottom:1.5rem}.metronome-label{display:block;color:#e2e8f0;font-weight:600;margin-bottom:.75rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.metronome-tempo-controls{display:flex;align-items:center;gap:1rem}.metronome-slider{flex:1;height:8px;border-radius:4px;background:#334155;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.metronome-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#0d9488);cursor:pointer;box-shadow:0 2px 8px #14b8a666;-webkit-transition:transform .2s ease;transition:transform .2s ease}.metronome-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.metronome-slider:disabled{opacity:.5;cursor:not-allowed}.metronome-bpm-input{width:5rem;padding:.5rem;text-align:center;font-family:ui-monospace,monospace;font-size:1.25rem;font-weight:600;background:#334155cc;border:1px solid #475569;border-radius:.5rem;color:#e2e8f0;transition:border-color .2s ease}.metronome-bpm-input:focus{outline:none;border-color:#14b8a6}.metronome-bpm-input:disabled{opacity:.5;cursor:not-allowed}.metronome-button-grid{display:grid;gap:.5rem}.metronome-button-grid.cols-2{grid-template-columns:repeat(2,1fr)}.metronome-button-grid.cols-3,.metronome-button-grid.cols-6{grid-template-columns:repeat(3,1fr)}@media(min-width:640px){.metronome-button-grid.cols-6{grid-template-columns:repeat(6,1fr)}}.metronome-option-btn{padding:.75rem 1rem;border-radius:.5rem;font-family:ui-monospace,monospace;font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all .2s ease;background:#334155cc;color:#94a3b8;border:1px solid #475569}.metronome-option-btn:hover:not(:disabled){background:#475569cc;color:#e2e8f0}.metronome-option-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;border-color:#14b8a6;box-shadow:0 2px 10px #14b8a64d}.metronome-option-btn.selected-alt{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;border-color:#f97316;box-shadow:0 2px 10px #f973164d}.metronome-option-btn:disabled{opacity:.5;cursor:not-allowed}.metronome-volume-section{margin-top:1.5rem}.metronome-volume-controls{display:flex;align-items:center;gap:1rem}.metronome-volume-icon{font-size:1.5rem;color:#64748b}.metronome-volume-value{width:3rem;text-align:center;font-family:ui-monospace,monospace;font-size:.875rem;color:#94a3b8}.metronome-instructions{background:#1e293bcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(20,184,166,.2);border-radius:1rem;padding:1.5rem}.metronome-instructions-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.metronome-instructions-list{display:flex;flex-direction:column;gap:.75rem}.metronome-instruction-item{display:flex;align-items:flex-start;color:#cbd5e1;font-size:.875rem;line-height:1.5}.metronome-instruction-bullet{color:#14b8a6;margin-right:.5rem;flex-shrink:0}.metronome-instruction-highlight{color:#f97316;font-weight:600}.metronome-instruction-teal{color:#14b8a6;font-weight:600}.ear-training-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.ear-training-header{text-align:center;margin-bottom:2rem}.ear-training-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#14b8a6,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;position:relative;display:inline-block}.ear-training-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:80px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.ear-training-subtitle{color:#94a3b8;font-size:1rem;margin-top:1rem}.ear-training-panel{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.ear-training-label{display:block;color:#94a3b8;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.ear-training-mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.ear-training-mode-btn{padding:1rem;border-radius:12px;border:2px solid transparent;background:#33415599;color:#cbd5e1;text-align:left;cursor:pointer;transition:all .2s ease}.ear-training-mode-btn:hover:not(.selected){background:#334155cc;border-color:#94a3b84d}.ear-training-mode-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;border-color:#14b8a6;box-shadow:0 0 20px #14b8a64d}.ear-training-mode-btn .mode-name{font-weight:700;font-size:1rem;margin-bottom:.25rem}.ear-training-mode-btn .mode-desc{font-size:.875rem;opacity:.8}.ear-training-difficulty-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.ear-training-difficulty-btn{padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(51,65,85,.8);background:#33415566;color:#cbd5e1;cursor:pointer;transition:all .2s ease}.ear-training-difficulty-btn:hover:not(.selected){background:#334155b3}.ear-training-difficulty-btn.selected{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;border-color:#f97316;box-shadow:0 0 15px #f973164d}.ear-training-difficulty-btn .diff-name{font-weight:700;font-size:.875rem}.ear-training-difficulty-btn .diff-desc{font-size:.75rem;opacity:.8}.ear-training-start-btn{width:100%;padding:1rem;border-radius:12px;border:none;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #14b8a64d,inset 0 1px #fff3}.ear-training-start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #14b8a666,inset 0 1px #fff3}.ear-training-score-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.ear-training-score{font-size:1.125rem;color:#94a3b8}.ear-training-score .score-value{font-weight:700;color:#14b8a6}.ear-training-streak{padding:.5rem 1rem;background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;font-weight:700;border-radius:9999px;font-size:.875rem;animation:streak-pulse 1.5s ease-in-out infinite}@keyframes streak-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ear-training-play-container{text-align:center;margin-bottom:2rem}.ear-training-play-btn{width:8rem;height:8rem;border-radius:50%;border:none;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 30px #14b8a666,inset 0 2px #fff3}.ear-training-play-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 12px 40px #14b8a680,inset 0 2px #fff3}.ear-training-play-btn:disabled{cursor:not-allowed}.ear-training-play-btn.playing{background:linear-gradient(135deg,#f97316,#ea580c);animation:play-pulse .6s ease-in-out infinite;box-shadow:0 0 40px #f9731680}@keyframes play-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.ear-training-play-btn .play-icon{font-size:2.5rem;line-height:1}.ear-training-play-btn .play-label{font-size:.875rem;font-weight:700;margin-top:.25rem}.ear-training-play-hint{color:#94a3b8;font-size:.875rem;margin-top:1rem}.ear-training-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.ear-training-option-btn{padding:1rem;border-radius:12px;border:2px solid rgba(51,65,85,.8);background:#33415580;color:#cbd5e1;cursor:pointer;transition:all .2s ease}.ear-training-option-btn:hover:not(:disabled){background:#334155cc;border-color:#14b8a6;transform:translateY(-2px)}.ear-training-option-btn:disabled{cursor:not-allowed}.ear-training-option-btn .option-name{font-weight:700;font-size:1.125rem}.ear-training-option-btn .option-hint{font-size:.75rem;color:#94a3b8;margin-top:.25rem}.ear-training-option-btn.correct{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#22c55e;color:#0f172a;box-shadow:0 0 20px #22c55e66}.ear-training-option-btn.incorrect{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#0f172a;box-shadow:0 0 20px #ef444466}.ear-training-option-btn.disabled-other{background:#3341554d;border-color:#33415566;color:#64748b}.ear-training-result{text-align:center;padding:1rem 0}.ear-training-result-text{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.ear-training-result-text.correct{color:#22c55e}.ear-training-result-text.incorrect{color:#ef4444}.ear-training-next-btn{padding:.75rem 2rem;border-radius:8px;border:none;background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #f973164d}.ear-training-next-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9731666}.ear-training-reference{background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px;padding:1.5rem}.ear-training-reference-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.ear-training-reference-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:640px){.ear-training-reference-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.ear-training-reference-grid{grid-template-columns:repeat(4,1fr)}}.ear-training-interval-card{padding:.75rem;border-radius:8px;border:1px solid rgba(51,65,85,.6);background:#3341554d;transition:all .2s ease}.ear-training-interval-card.active{border-color:#14b8a6;background:#14b8a61a}.ear-training-interval-card.inactive{opacity:.4}.ear-training-interval-card .interval-name{font-weight:700;font-size:.875rem;color:#f1f5f9}.ear-training-interval-card .interval-example{font-size:.75rem;color:#94a3b8;margin-top:.25rem}.ear-training-instructions{background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px;padding:1.5rem;margin-top:1.5rem}.ear-training-instructions-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.ear-training-instructions-list{list-style:none;padding:0;margin:0;counter-reset:step}.ear-training-instructions-list li{position:relative;padding-left:2rem;margin-bottom:.75rem;color:#cbd5e1;font-size:.9375rem;counter-increment:step}.ear-training-instructions-list li:before{content:counter(step);position:absolute;left:0;top:0;width:1.5rem;height:1.5rem;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;font-weight:700;font-size:.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.backing-tracks-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.backing-tracks-header{text-align:center;margin-bottom:2rem}.backing-tracks-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#f97316,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;position:relative;display:inline-block}.backing-tracks-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:80px;height:3px;background:linear-gradient(90deg,#f97316,#14b8a6);border-radius:2px}.backing-tracks-subtitle{color:#94a3b8;font-size:1rem;margin-top:1rem}.backing-tracks-panel{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.backing-tracks-label{display:block;color:#94a3b8;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.backing-tracks-chord-display{display:flex;justify-content:center;margin-bottom:2rem}.backing-tracks-chord-circle{width:12rem;height:12rem;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#334155cc;color:#94a3b8;transition:all .1s ease;position:relative}.backing-tracks-chord-circle.playing{background:#334155cc;color:#f97316}.backing-tracks-chord-circle.downbeat{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;transform:scale(1.1);box-shadow:0 0 40px #f9731680}.backing-tracks-chord-name{font-size:2.5rem;font-weight:700}.backing-tracks-beat-label{font-size:.875rem;margin-top:.5rem;opacity:.8}.backing-tracks-chord-ring{position:absolute;inset:0;border-radius:50%;border:4px solid #f97316;animation:backing-ring-pulse .6s ease-out forwards;opacity:.75}@keyframes backing-ring-pulse{0%{transform:scale(1);opacity:.75}to{transform:scale(1.3);opacity:0}}.backing-tracks-progression{display:flex;justify-content:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.backing-tracks-progression-chord{padding:.5rem 1rem;border-radius:8px;font-family:monospace;font-size:.875rem;background:#33415599;color:#94a3b8;transition:all .15s ease}.backing-tracks-progression-chord.active{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;transform:scale(1.1);box-shadow:0 0 15px #f9731666}.backing-tracks-key-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media(min-width:640px){.backing-tracks-key-grid{grid-template-columns:repeat(12,1fr)}}.backing-tracks-key-btn{padding:.75rem .5rem;border-radius:8px;border:1px solid rgba(51,65,85,.8);background:#33415566;color:#cbd5e1;font-weight:500;cursor:pointer;transition:all .2s ease}.backing-tracks-key-btn:hover:not(:disabled):not(.selected){background:#334155b3}.backing-tracks-key-btn.selected{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;border-color:#f97316}.backing-tracks-key-btn:disabled{opacity:.5;cursor:not-allowed}.backing-tracks-style-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}@media(min-width:640px){.backing-tracks-style-grid{grid-template-columns:repeat(4,1fr)}}.backing-tracks-style-btn{padding:.5rem .75rem;border-radius:8px;border:1px solid rgba(51,65,85,.8);background:#33415566;color:#cbd5e1;font-size:.875rem;cursor:pointer;transition:all .2s ease}.backing-tracks-style-btn:hover:not(:disabled):not(.selected){background:#334155b3}.backing-tracks-style-btn.selected{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;border-color:#f97316}.backing-tracks-style-btn:disabled{opacity:.5;cursor:not-allowed}.backing-tracks-style-name{color:#64748b;font-size:.875rem;margin-top:.5rem}.backing-tracks-tempo-row{display:flex;align-items:center;gap:1rem}.backing-tracks-slider{flex:1;height:8px;background:#334155cc;border-radius:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.backing-tracks-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #f9731666}.backing-tracks-slider:disabled{opacity:.5;cursor:not-allowed}.backing-tracks-bpm-input{width:5rem;background:#334155cc;border:1px solid rgba(71,85,105,.8);border-radius:8px;padding:.5rem .75rem;color:#f1f5f9;font-family:monospace;font-size:1.125rem;text-align:center}.backing-tracks-bpm-input:disabled{opacity:.5;cursor:not-allowed}.backing-tracks-button-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.backing-tracks-play-btn{padding:1rem 1.5rem;border-radius:12px;border:none;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .2s ease}.backing-tracks-play-btn.start{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;box-shadow:0 4px 15px #f973164d,inset 0 1px #fff3}.backing-tracks-play-btn.start:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9731666,inset 0 1px #fff3}.backing-tracks-play-btn.stop{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 15px #ef44444d}.backing-tracks-play-btn.stop:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.backing-tracks-tap-btn{padding:1rem 1.5rem;border-radius:12px;border:none;background:#334155cc;color:#f1f5f9;font-weight:700;font-size:1.125rem;cursor:pointer;transition:all .2s ease}.backing-tracks-tap-btn:hover:not(:disabled){background:#475569cc}.backing-tracks-tap-btn:disabled{opacity:.5;cursor:not-allowed}.backing-tracks-volume-row{display:flex;align-items:center;gap:1rem}.backing-tracks-volume-icon{font-size:1.5rem;color:#64748b}.backing-tracks-volume-value{width:3rem;text-align:center;font-family:monospace;font-size:.875rem;color:#94a3b8}.backing-tracks-instructions{background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px;padding:1.5rem}.backing-tracks-instructions-title{font-size:1.25rem;font-weight:700;color:#f97316;margin-bottom:1rem}.backing-tracks-instructions-list{list-style:none;padding:0;margin:0}.backing-tracks-instructions-list li{display:flex;align-items:flex-start;margin-bottom:.75rem;color:#cbd5e1;font-size:.9375rem}.backing-tracks-step-num{color:#f97316;font-weight:700;margin-right:.5rem;min-width:1.5rem}.backing-tracks-chord-circle.counting-in{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;animation:count-in-pulse .5s ease-in-out infinite}@keyframes count-in-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.backing-tracks-scales{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#33415580;border-radius:.75rem;border:1px solid rgba(71,85,105,.5)}.backing-tracks-scale-primary,.backing-tracks-scale-alt{display:flex;align-items:center;gap:.75rem}.backing-tracks-scale-label{font-size:.875rem;color:#94a3b8;min-width:5rem}.backing-tracks-scale-primary .backing-tracks-scale-name{font-size:1.125rem;font-weight:600;color:#14b8a6}.backing-tracks-scale-alt .backing-tracks-scale-name{font-size:1rem;font-weight:500;color:#cbd5e1}.backing-tracks-drum-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.backing-tracks-drum-toggle{padding:.375rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:.375rem;background:#33415599;color:#94a3b8;border:1px solid rgba(71,85,105,.5);cursor:pointer;transition:all .15s ease}.backing-tracks-drum-toggle:hover{background:#334155cc}.backing-tracks-drum-toggle.enabled{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;border-color:#14b8a6}.backing-tracks-drum-toggle.enabled:hover{background:linear-gradient(135deg,#2dd4bf,#14b8a6)}.chord-dictionary-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.chord-dictionary-header{text-align:center;margin-bottom:2rem}.chord-dictionary-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#14b8a6,#2dd4bf,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;position:relative;display:inline-block}.chord-dictionary-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.chord-dictionary-subtitle{color:#94a3b8;font-size:1.125rem;margin-top:1rem}.chord-dictionary-back-btn{display:inline-flex;align-items:center;gap:.5rem;color:#14b8a6;font-weight:500;transition:all .2s ease;margin-bottom:1.5rem}.chord-dictionary-back-btn:hover{color:#2dd4bf;transform:translate(-4px)}.chord-dictionary-search-panel{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.chord-dictionary-search-grid{display:grid;gap:1rem}@media(min-width:768px){.chord-dictionary-search-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}.chord-dictionary-label{display:block;font-size:.875rem;font-weight:600;color:#f97316;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.chord-dictionary-search-input{width:100%;background:#0f172a99;border:1px solid rgba(51,65,85,.8);border-radius:8px;padding:.75rem 1rem;color:#f1f5f9;font-size:1rem;transition:all .2s ease}.chord-dictionary-search-input::-moz-placeholder{color:#64748b}.chord-dictionary-search-input::placeholder{color:#64748b}.chord-dictionary-search-input:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a626}.chord-dictionary-filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}@media(min-width:640px){.chord-dictionary-filter-grid{grid-template-columns:repeat(6,1fr)}}.chord-dictionary-filter-btn{padding:.5rem .25rem;border-radius:8px;font-weight:600;font-size:.8125rem;text-align:center;transition:all .2s ease;background:#1e293b99;border:1px solid rgba(51,65,85,.6);color:#94a3b8}.chord-dictionary-filter-btn:hover{background:#334155cc;color:#f1f5f9}.chord-dictionary-filter-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#14b8a6;color:#fff;box-shadow:0 2px 8px #14b8a64d}.chord-dictionary-results-count{color:#94a3b8;font-size:.9375rem;margin-bottom:1rem}.chord-dictionary-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:640px){.chord-dictionary-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.chord-dictionary-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.chord-dictionary-grid{grid-template-columns:repeat(4,1fr)}}.chord-dictionary-card{background:#1e293bb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.6);border-radius:12px;padding:1rem;transition:all .2s ease}.chord-dictionary-card:hover{border-color:#14b8a6;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.chord-dictionary-card-title{font-size:1.125rem;font-weight:700;color:#14b8a6;text-align:center;margin-bottom:.75rem}.chord-dictionary-play-btn{width:100%;padding:.5rem 1rem;margin-top:1rem;border-radius:8px;font-weight:600;font-size:.875rem;transition:all .2s ease;background:#33415599;border:1px solid rgba(71,85,105,.6);color:#cbd5e1}.chord-dictionary-play-btn:hover{background:#475569cc;color:#f1f5f9}.chord-dictionary-play-btn.playing{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff;box-shadow:0 0 12px #10b98166}.chord-dictionary-no-results{text-align:center;padding:3rem 1.5rem;background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px}.chord-dictionary-no-results p{color:#94a3b8;font-size:1.125rem;margin-bottom:1rem}.chord-dictionary-clear-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.chord-dictionary-clear-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #14b8a64d}.chord-dictionary-legend{margin-top:2rem;background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px;padding:1.5rem}.chord-dictionary-legend-title{font-size:1.25rem;font-weight:700;color:#f97316;margin-bottom:1rem}.chord-dictionary-legend-grid{display:grid;gap:1rem}@media(min-width:768px){.chord-dictionary-legend-grid{grid-template-columns:repeat(3,1fr)}}.chord-dictionary-legend-item{display:flex;align-items:flex-start;gap:.75rem}.chord-dictionary-legend-icon{flex-shrink:0;margin-top:.125rem}.chord-dictionary-legend-icon.open{width:1.5rem;height:1.5rem;border-radius:50%;border:2px solid #10b981}.chord-dictionary-legend-icon.fretted{width:1.5rem;height:1.5rem;border-radius:50%;background:#14b8a6}.chord-dictionary-legend-icon.muted{color:#ef4444;font-size:1.25rem;font-weight:700;width:1.5rem;text-align:center}.chord-dictionary-legend-text{font-size:.875rem}.chord-dictionary-legend-text strong{display:block;color:#cbd5e1;margin-bottom:.25rem}.chord-dictionary-legend-text span{color:#64748b}.scale-trainer-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.scale-trainer-header{text-align:center;margin-bottom:2rem}.scale-trainer-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#14b8a6,#2dd4bf,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;position:relative;display:inline-block}.scale-trainer-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.scale-trainer-subtitle{color:#94a3b8;font-size:1.125rem;margin-top:1rem}.scale-trainer-panel{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.scale-trainer-label{display:block;font-size:.875rem;font-weight:600;color:#f97316;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.scale-trainer-note-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media(min-width:640px){.scale-trainer-note-grid{grid-template-columns:repeat(12,1fr)}}.scale-trainer-note-btn{padding:.75rem .5rem;border-radius:8px;font-weight:600;font-size:.875rem;text-align:center;transition:all .2s ease;background:#1e293b99;border:1px solid rgba(51,65,85,.6);color:#cbd5e1}.scale-trainer-note-btn:hover:not(:disabled){background:#334155cc;color:#f1f5f9}.scale-trainer-note-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#14b8a6;color:#0f172a;box-shadow:0 2px 8px #14b8a64d}.scale-trainer-scale-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}@media(min-width:640px){.scale-trainer-scale-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:1024px){.scale-trainer-scale-grid{grid-template-columns:repeat(6,1fr)}}.scale-trainer-scale-btn{padding:.5rem .75rem;border-radius:8px;font-weight:500;font-size:.8125rem;text-align:center;transition:all .2s ease;background:#1e293b99;border:1px solid rgba(51,65,85,.6);color:#94a3b8}.scale-trainer-scale-btn:hover:not(:disabled){background:#334155cc;color:#f1f5f9}.scale-trainer-scale-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#14b8a6;color:#0f172a;box-shadow:0 2px 8px #14b8a64d}.scale-trainer-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.scale-trainer-mode-btn{padding:.5rem .75rem;border-radius:8px;font-weight:500;font-size:.8125rem;text-align:center;transition:all .2s ease;background:#1e293b99;border:1px solid rgba(51,65,85,.6);color:#94a3b8}.scale-trainer-mode-btn:hover:not(:disabled){background:#334155cc;color:#f1f5f9}.scale-trainer-mode-btn.selected{background:linear-gradient(135deg,#06b6d4,#0891b2);border-color:#06b6d4;color:#0f172a;box-shadow:0 2px 8px #06b6d44d}.scale-trainer-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}.scale-trainer-listen-btn{padding:1rem 1.5rem;border-radius:12px;font-weight:700;font-size:1rem;transition:all .2s ease;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;color:#0f172a;box-shadow:0 4px 12px #14b8a64d}.scale-trainer-listen-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #14b8a666}.scale-trainer-listen-btn.active{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d}.scale-trainer-listen-btn.active:hover{box-shadow:0 6px 16px #ef444466}.scale-trainer-practice-btn{padding:1rem 1.5rem;border-radius:12px;font-weight:700;font-size:1rem;transition:all .2s ease;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;color:#0f172a;box-shadow:0 4px 12px #06b6d44d}.scale-trainer-practice-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #06b6d466}.scale-trainer-error{margin-top:1rem;padding:1rem;background:#7f1d1d80;border:1px solid #ef4444;border-radius:8px;color:#fca5a5}.scale-trainer-practice-display{text-align:center;padding:1.5rem}.scale-trainer-target-label{font-size:.875rem;color:#94a3b8;margin-bottom:.5rem}.scale-trainer-target-note{font-size:4rem;font-weight:800;color:#14b8a6;transition:all .2s ease}.scale-trainer-target-note.correct{color:#22c55e;transform:scale(1.1)}.scale-trainer-target-note.incorrect{color:#ef4444}.scale-trainer-detected{font-size:1.125rem;color:#94a3b8;margin-top:.5rem}.scale-trainer-detected .match{color:#22c55e}.scale-trainer-detected .no-match{color:#ef4444}.scale-trainer-progress{display:flex;justify-content:center;gap:.5rem;margin:1.5rem 0;flex-wrap:wrap}.scale-trainer-progress-note{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;transition:all .2s ease;background:#33415599;color:#94a3b8}.scale-trainer-progress-note.completed{background:linear-gradient(135deg,#22c55e,#16a34a);color:#0f172a}.scale-trainer-progress-note.current{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;transform:scale(1.1);box-shadow:0 0 12px #14b8a680}.scale-trainer-score{text-align:center;margin-top:1rem}.scale-trainer-score-value{font-size:1.5rem;font-weight:700;color:#22c55e}.scale-trainer-score-total{color:#94a3b8}.scale-trainer-fretboard-title{font-size:1.25rem;font-weight:700;color:#14b8a6;margin-bottom:1rem}.scale-trainer-fretboard-content{min-width:-moz-max-content;min-width:max-content}.scale-trainer-fret-label{width:3rem}.scale-trainer-fret-num{width:3.5rem;text-align:center;font-size:.75rem;color:#64748b}.scale-trainer-string{display:flex;align-items:center;margin-bottom:.25rem}.scale-trainer-string-label{width:3rem;font-size:.875rem;font-weight:500;color:#94a3b8}.scale-trainer-fret{width:3.5rem;height:2.5rem;border:1px solid rgba(51,65,85,.6);display:flex;align-items:center;justify-content:center;position:relative}.scale-trainer-note-dot{width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;transition:all .2s ease}.scale-trainer-note-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a}.scale-trainer-note-dot.scale{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#0f172a}.scale-trainer-note-dot.target{background:linear-gradient(135deg,#facc15,#eab308);color:#0f172a;animation:pulse 1s ease-in-out infinite}.scale-trainer-fret-marker{position:absolute;bottom:2px;width:6px;height:6px;border-radius:50%;background:#47556999}.scale-trainer-legend{margin-top:1rem;display:flex;flex-wrap:wrap;gap:1.5rem;font-size:.875rem;color:#94a3b8}.scale-trainer-legend-item{display:flex;align-items:center;gap:.5rem}.scale-trainer-legend-dot.root{background:#14b8a6}.scale-trainer-legend-dot.scale{background:#06b6d4}.scale-trainer-legend-dot.target{background:#facc15}.scale-trainer-instructions{background:#1e293b99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(51,65,85,.5);border-radius:12px;padding:1.5rem;margin-top:1.5rem}.scale-trainer-instructions-title{font-size:1.25rem;font-weight:700;color:#f97316;margin-bottom:1rem}.scale-trainer-instructions-list{list-style:decimal;list-style-position:inside;color:#cbd5e1}.scale-trainer-instructions-list li{margin-bottom:.5rem}.catalog-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem}.catalog-header{margin-bottom:2rem}.catalog-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#14b8a6,#f97316,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;position:relative;display:inline-block}.catalog-title:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.catalog-subtitle{color:#94a3b8;font-size:.95rem;margin-top:1rem}.catalog-progress-panel{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.catalog-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.catalog-progress-text{font-size:.875rem;color:#cbd5e1;font-weight:500}.catalog-progress-percent{font-size:.875rem;font-weight:700;color:#14b8a6}.catalog-progress-track{width:100%;height:8px;background:#334155cc;border-radius:4px;overflow:hidden}.catalog-progress-fill{height:100%;background:linear-gradient(90deg,#14b8a6,#0d9488);border-radius:4px;transition:width .3s ease;box-shadow:0 0 12px #14b8a666}.catalog-controls{margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.catalog-search-wrapper{position:relative;width:100%;max-width:24rem}.catalog-search-input{width:100%;padding:.875rem 2.5rem .875rem 1.25rem;font-size:.95rem;background:#1e293bcc;border:1px solid rgba(51,65,85,.6);border-radius:10px;color:#f8fafc;transition:all .2s ease;outline:none}.catalog-search-input::-moz-placeholder{color:#64748b}.catalog-search-input::placeholder{color:#64748b}.catalog-search-input:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a626,0 4px 12px #0003}.catalog-search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);padding:.25rem;color:#64748b;background:transparent;border:none;cursor:pointer;transition:color .2s ease}.catalog-search-clear:hover{color:#e2e8f0}.catalog-filters{display:flex;flex-wrap:wrap;gap:1rem}.catalog-filter-group{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.catalog-filter-label{font-size:.8rem;font-weight:600;color:#f97316;text-transform:uppercase;letter-spacing:.05em}.catalog-filter-btn{padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:9999px;border:1px solid rgba(51,65,85,.6);background:#1e293b99;color:#94a3b8;cursor:pointer;transition:all .2s ease;min-height:44px}.catalog-filter-btn:hover{background:#334155cc;border-color:#64748b99;color:#e2e8f0}.catalog-filter-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#14b8a6;color:#0f172a;box-shadow:0 0 12px #14b8a64d}.catalog-filter-btn.favorites.selected{background:linear-gradient(135deg,#ec4899,#db2777);border-color:#ec4899;color:#0f172a;box-shadow:0 0 12px #ec48994d}.catalog-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1.25rem}@media(min-width:768px){.catalog-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.catalog-grid{grid-template-columns:repeat(3,1fr)}}.catalog-card{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:12px;padding:1.25rem;position:relative;transition:all .2s ease;display:flex;flex-direction:column}.catalog-card:hover{border-color:#64748b99;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d;transform:translateY(-2px)}.catalog-card-icon{position:absolute;padding:.5rem;border-radius:8px;background:#0f172acc;border:1px solid rgba(51,65,85,.4);cursor:pointer;transition:all .2s ease;color:#64748b}.catalog-card-icon:hover{color:#e2e8f0;background:#1e293be6}.catalog-card-icon.favorite{top:.75rem;right:.75rem}.catalog-card-icon.favorite.active{color:#ec4899}.catalog-card-icon.share{top:3.5rem;right:.75rem}.catalog-card-title{font-size:1.1rem;font-weight:600;color:#f8fafc;margin-bottom:.5rem;padding-right:2.5rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-card-description{font-size:.875rem;color:#94a3b8;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog-card-category{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.catalog-card-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.catalog-badge{padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:6px;text-transform:capitalize}.catalog-badge.beginner{background:#10b98126;color:#34d399}.catalog-badge.intermediate{background:#f59e0b26;color:#fbbf24}.catalog-badge.advanced{background:#ef444426;color:#f87171}.catalog-badge.tier{display:flex;align-items:center;gap:.25rem;border:1px solid}.catalog-badge.tier.free{background:#10b98126;color:#34d399;border-color:#10b9814d}.catalog-badge.tier.premium{background:#3b82f626;color:#60a5fa;border-color:#3b82f64d}.catalog-badge.tier.pro{background:#8b5cf626;color:#a78bfa;border-color:#8b5cf64d}.catalog-card-techniques{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.catalog-technique{padding:.25rem .5rem;font-size:.7rem;background:#33415599;color:#cbd5e1;border-radius:4px}.catalog-card-actions{display:flex;align-items:center;gap:.625rem;margin-top:auto}.catalog-completion-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:44px;flex-shrink:0}.catalog-completion-btn.incomplete{background:#33415599;border:1px solid rgba(71,85,105,.6);color:#94a3b8}.catalog-completion-btn.incomplete:hover{border-color:#14b8a6;color:#14b8a6}.catalog-completion-btn.completed{background:#14b8a626;border:1px solid #14b8a6;color:#14b8a6}.catalog-completion-btn.completed:hover{background:#14b8a640}.catalog-preview-btn{flex:1;padding:.625rem 1rem;font-size:.875rem;font-weight:600;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;color:#0f172a;cursor:pointer;transition:all .2s ease;min-height:44px;box-shadow:0 2px 8px #14b8a64d}.catalog-preview-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #14b8a666}.catalog-empty{text-align:center;padding:3rem 1rem}.catalog-empty-text{font-size:1.1rem;color:#94a3b8;margin-bottom:1rem}.catalog-clear-btn{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;background:#33415599;border:1px solid rgba(71,85,105,.6);border-radius:8px;color:#e2e8f0;cursor:pointer;transition:all .2s ease}.catalog-clear-btn:hover{background:#47556999;border-color:#64748b99}.catalog-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.catalog-modal{background:#1e293bf2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:1.5rem;max-width:28rem;width:100%;box-shadow:0 8px 32px #0006}.catalog-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.catalog-modal-title{font-size:1.25rem;font-weight:700;color:#f8fafc}.catalog-modal-close{padding:.25rem;color:#64748b;background:transparent;border:none;cursor:pointer;transition:color .2s ease}.catalog-modal-close:hover{color:#e2e8f0}.catalog-modal-lesson{color:#cbd5e1;margin-bottom:1.5rem}.catalog-share-buttons{display:flex;flex-direction:column;gap:.75rem}.catalog-share-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;font-size:.95rem;font-weight:500;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;color:#f8fafc}.catalog-share-btn.twitter{background:linear-gradient(135deg,#1d9bf0,#1a8cd8)}.catalog-share-btn.twitter:hover{background:linear-gradient(135deg,#1a8cd8,#1681c9)}.catalog-share-btn.facebook{background:linear-gradient(135deg,#1877f2,#166fe5)}.catalog-share-btn.facebook:hover{background:linear-gradient(135deg,#166fe5,#1466d8)}.catalog-share-btn.copy{background:#334155cc;border:1px solid rgba(71,85,105,.6)}.catalog-share-btn.copy:hover{background:#475569cc}.pricing-page{min-height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b,#0f172a);padding:3rem 1rem}.pricing-header{text-align:center;margin-bottom:3rem}.pricing-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#2dd4bf,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;position:relative;display:inline-block}.pricing-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px}.pricing-subtitle{color:#94a3b8;font-size:1.125rem;max-width:36rem;margin:0 auto;line-height:1.6}.pricing-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:2rem;max-width:72rem;margin:0 auto}@media(min-width:768px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}.pricing-card{background:#1e293bcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(51,65,85,.6);border-radius:16px;padding:2rem;position:relative;transition:all .3s ease}.pricing-card:hover{border-color:#475569cc;transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.pricing-card.highlight{background:linear-gradient(180deg,#14b8a626,#1e293be6);border:2px solid #14b8a6;box-shadow:0 0 30px #14b8a633}.pricing-card.highlight:hover{border-color:#2dd4bf;box-shadow:0 0 40px #14b8a64d}.pricing-badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#14b8a6,#f97316);color:#0f172a;padding:.375rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.375rem;white-space:nowrap;box-shadow:0 4px 12px #14b8a666}.pricing-tier-name{font-size:1.5rem;font-weight:700;color:#f1f5f9;margin-bottom:.5rem}.pricing-card.highlight .pricing-tier-name{color:#2dd4bf}.pricing-price{margin-bottom:1rem}.pricing-amount{font-size:2.5rem;font-weight:700;color:#f1f5f9}.pricing-period{color:#94a3b8;font-size:1rem}.pricing-description{color:#94a3b8;margin-bottom:1.5rem;line-height:1.5}.pricing-cta{display:block;width:100%;padding:.875rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;text-align:center;transition:all .2s ease;margin-bottom:2rem;border:none;cursor:pointer;text-decoration:none}.pricing-cta.primary{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#0f172a;box-shadow:0 4px 12px #14b8a64d}.pricing-cta.primary:hover{background:linear-gradient(135deg,#2dd4bf,#14b8a6);transform:translateY(-2px);box-shadow:0 6px 16px #14b8a666}.pricing-cta.secondary{background:linear-gradient(135deg,#f97316,#ea580c);color:#0f172a;box-shadow:0 4px 12px #f973164d}.pricing-cta.secondary:hover{background:linear-gradient(135deg,#fb923c,#f97316);transform:translateY(-2px);box-shadow:0 6px 16px #f9731666}.pricing-cta.disabled{background:#33415599;color:#64748b;cursor:not-allowed;box-shadow:none}.pricing-cta.disabled:hover{transform:none;box-shadow:none}.pricing-cta.current{background:#33415599;color:#94a3b8;cursor:default}.pricing-features{list-style:none;padding:0;margin:0}.pricing-feature{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.pricing-feature-icon{flex-shrink:0;width:1.125rem;height:1.125rem}.pricing-feature-icon.included{color:#14b8a6}.pricing-feature-icon.limited{color:#f97316}.pricing-feature-icon.excluded{color:#475569}.pricing-feature-text{color:#cbd5e1;font-size:.9375rem}.pricing-feature-text.excluded{color:#64748b}.pricing-feature-value{color:#64748b;margin-left:.25rem}.pricing-footer{text-align:center;margin-top:3rem;color:#64748b}.pricing-footer p{margin-bottom:.5rem}.pricing-footer-link{color:#14b8a6;text-decoration:underline;transition:color .2s ease}.pricing-footer-link:hover{color:#2dd4bf}@media(max-width:640px){.pricing-page{padding:2rem 1rem}.pricing-title{font-size:2rem}.pricing-card{padding:1.5rem}.pricing-amount{font-size:2rem}}.fretvision-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative;overflow-x:hidden}.fretvision-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(20,184,166,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(249,115,22,.06) 0%,transparent 50%);pointer-events:none}.fretvision-header{text-align:center;margin-bottom:2rem;position:relative}.fretvision-title{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#2dd4bf,#14b8a6,#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;margin-bottom:.25rem}.fretvision-title-accent{width:80px;height:4px;background:linear-gradient(90deg,#14b8a6,#f97316);border-radius:2px;margin:0 auto .75rem}.fretvision-subtitle{color:#94a3b8;font-size:1.1rem}.fretvision-back-link{display:inline-flex;align-items:center;gap:.5rem;color:#14b8a6;font-weight:500;transition:all .2s ease;padding:.5rem 1rem;border-radius:8px;background:#14b8a61a}.fretvision-back-link:hover{color:#2dd4bf;background:#14b8a633;transform:translate(-4px)}.fretvision-control-panel{background:#1e293bb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(71,85,105,.5);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.fretvision-select-label{display:block;font-size:.875rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.fretvision-select{width:100%;background:linear-gradient(180deg,#1e293b,#0f172a);border:1px solid #475569;border-radius:8px;padding:.75rem 1rem;color:#e2e8f0;font-size:1rem;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.fretvision-select:hover{border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a633}.fretvision-select:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a64d}.fretvision-root-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media(min-width:640px){.fretvision-root-grid{grid-template-columns:repeat(12,1fr)}}.fretvision-root-button{padding:.875rem .5rem;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .2s ease;background:linear-gradient(180deg,#334155,#1e293b);border:1px solid #475569;color:#94a3b8;cursor:pointer;min-height:44px}.fretvision-root-button:hover{background:linear-gradient(180deg,#475569,#334155);border-color:#64748b;color:#e2e8f0;transform:translateY(-1px)}.fretvision-root-button.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#2dd4bf;color:#fff;box-shadow:0 0 20px #14b8a666,inset 0 1px #fff3}.fretvision-fretboard{background:#1e293bb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(71,85,105,.5);border-radius:16px;padding:1.5rem;overflow-x:auto;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.fretvision-fretboard-inner{min-width:-moz-max-content;min-width:max-content}.fretvision-fret-numbers{display:flex;margin-bottom:.5rem}.fretvision-fret-number{width:4rem;text-align:center;font-size:.75rem;font-weight:600;color:#64748b}.fretvision-fret-number:first-child{width:3rem}.fretvision-string-row{display:flex;align-items:center;margin-bottom:2px}.fretvision-string-label{width:3rem;font-size:.875rem;font-weight:600;color:#64748b}.fretvision-fret-cell{width:4rem;height:3rem;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,#3d2914,#5c3d1e 20%,#4a3218,#5c3d1e 80%,#3d2914);border-right:2px solid #c9b896;border-bottom:1px solid rgba(255,255,255,.1)}.fretvision-fret-cell.nut{background:linear-gradient(180deg,beige,#e8e8c8,#d4d4aa);border-right:4px solid #1a1a1a}.fretvision-inlay{position:absolute;bottom:4px;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,beige,#c9b896);box-shadow:inset 0 1px 2px #0000004d;opacity:.8}.fretvision-note-dot{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;transition:all .2s ease;position:relative;z-index:10}.fretvision-note-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 0 20px #14b8a699,0 0 40px #14b8a64d,inset 0 1px #ffffff4d;animation:fretvision-pulse-teal 2s ease-in-out infinite}.fretvision-note-dot.scale{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 0 15px #f9731680,0 0 30px #f9731633,inset 0 1px #fff3}.fretvision-note-dot:hover{transform:scale(1.15)}@keyframes fretvision-pulse-teal{0%,to{box-shadow:0 0 20px #14b8a699,0 0 40px #14b8a64d}50%{box-shadow:0 0 30px #14b8a6cc,0 0 60px #14b8a666}}.fretvision-info-panel{background:#1e293bb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(71,85,105,.5);border-radius:16px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.fretvision-info-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#2dd4bf,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.fretvision-notes-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.fretvision-notes-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.fretvision-note-pill{padding:.5rem 1rem;border-radius:9999px;font-weight:600;font-size:.875rem}.fretvision-note-pill.root{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 0 15px #14b8a666}.fretvision-note-pill.scale{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;box-shadow:0 0 10px #f973164d}.fretvision-legend{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;color:#94a3b8}.fretvision-legend-item{display:flex;align-items:center;gap:.5rem}.fretvision-legend-dot{width:1rem;height:1rem;border-radius:50%}.fretvision-legend-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);box-shadow:0 0 8px #14b8a680}.fretvision-legend-dot.scale{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 0 8px #f9731666}.scale-trainer-page{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:2rem 1rem;position:relative}.scale-trainer-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(20,184,166,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(249,115,22,.06) 0%,transparent 50%);pointer-events:none}.scale-trainer-header{text-align:center;margin-bottom:2rem;position:relative}.scale-trainer-title{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#14b8a6,#2dd4bf,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;margin-bottom:.5rem;letter-spacing:-.02em}.scale-trainer-subtitle{color:#94a3b8;font-size:1.125rem}.scale-trainer-panel{background:#1e293bb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(71,85,105,.5);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff0d}.scale-trainer-label{display:block;color:#94a3b8;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}.scale-trainer-note-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:.5rem}@media(max-width:768px){.scale-trainer-note-grid{grid-template-columns:repeat(6,1fr)}}.scale-trainer-note-btn{padding:.75rem;background:#33415599;border:1px solid rgba(71,85,105,.5);border-radius:8px;color:#e2e8f0;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease}.scale-trainer-note-btn:hover:not(:disabled){background:#475569cc;border-color:#64748bcc;transform:translateY(-2px)}.scale-trainer-note-btn.selected{background:linear-gradient(135deg,#14b8a6,#0d9488);border-color:#2dd4bf;color:#fff;box-shadow:0 0 20px #14b8a666}.scale-trainer-note-btn:disabled{opacity:.5;cursor:not-allowed}.scale-trainer-scale-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}@media(max-width:768px){.scale-trainer-scale-grid{grid-template-columns:repeat(2,1fr)}}.scale-trainer-scale-btn{padding:.75rem 1rem;background:#33415599;border:1px solid rgba(71,85,105,.5);border-radius:8px;color:#e2e8f0;font-weight:500;font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:center}.scale-trainer-scale-btn:hover:not(:disabled){background:#475569cc;border-color:#64748bcc}.scale-trainer-scale-btn.selected{background:linear-gradient(135deg,#f97316,#ea580c);border-color:#fb923c;color:#fff;box-shadow:0 0 15px #f9731666}.scale-trainer-scale-btn:disabled{opacity:.5;cursor:not-allowed}.scale-trainer-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.scale-trainer-mode-btn{padding:1rem;background:#33415599;border:1px solid rgba(71,85,105,.5);border-radius:12px;color:#e2e8f0;font-weight:600;cursor:pointer;transition:all .2s ease}.scale-trainer-mode-btn:hover:not(:disabled){background:#475569cc}.scale-trainer-mode-btn.selected{background:linear-gradient(135deg,#14b8a64d,#f973164d);border-color:#14b8a6;box-shadow:0 0 20px #14b8a633}.scale-trainer-mode-btn:disabled{opacity:.5;cursor:not-allowed}.scale-trainer-action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}.scale-trainer-listen-btn{padding:1rem 1.5rem;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #14b8a64d}.scale-trainer-listen-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #14b8a666}.scale-trainer-listen-btn.active{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 15px #dc262666;animation:scale-trainer-pulse-red 2s ease-in-out infinite}.scale-trainer-practice-btn{padding:1rem 1.5rem;background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #f973164d}.scale-trainer-practice-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #f9731666}.scale-trainer-practice-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.scale-trainer-play-ref-btn{padding:.75rem 1.25rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:10px;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #8b5cf64d;margin-top:1rem}.scale-trainer-play-ref-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #8b5cf666}.scale-trainer-play-ref-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.scale-trainer-play-scale-btn{padding:1rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #8b5cf64d}.scale-trainer-play-scale-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #8b5cf680}.scale-trainer-play-scale-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.scale-trainer-note-dot.playing{background:linear-gradient(135deg,#f97316,#fb923c);box-shadow:0 0 20px #f97316cc,0 0 40px #f9731666;transform:scale(1.3);animation:scale-trainer-pulse-playing .4s ease-in-out infinite}@keyframes scale-trainer-pulse-playing{0%,to{transform:scale(1.3);box-shadow:0 0 20px #f97316cc,0 0 40px #f9731666}50%{transform:scale(1.5);box-shadow:0 0 30px #f97316,0 0 60px #f9731699}}.scale-trainer-error{background:#dc262633;border:1px solid rgba(220,38,38,.5);border-radius:8px;padding:1rem;color:#fca5a5;margin-top:1rem;text-align:center}.scale-trainer-practice-display{text-align:center;padding:2rem}.scale-trainer-target-label{color:#94a3b8;font-size:1rem;margin-bottom:1rem}.scale-trainer-target-note{font-size:5rem;font-weight:800;background:linear-gradient(135deg,#f97316,#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:scale-trainer-pulse-orange 1.5s ease-in-out infinite;margin-bottom:1rem}.scale-trainer-target-note.correct{background:linear-gradient(135deg,#22c55e,#4ade80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:none}.scale-trainer-target-note.incorrect{background:linear-gradient(135deg,#ef4444,#f87171);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.scale-trainer-detected{color:#94a3b8;font-size:1.25rem}.scale-trainer-detected .match{color:#22c55e;font-weight:700}.scale-trainer-detected .no-match{color:#ef4444;font-weight:700}.scale-trainer-progress{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(71,85,105,.5)}.scale-trainer-progress-note{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:#33415599;border:2px solid rgba(71,85,105,.5);border-radius:50%;color:#94a3b8;font-weight:600;font-size:.875rem;transition:all .3s ease}.scale-trainer-progress-note.completed{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#4ade80;color:#fff;box-shadow:0 0 15px #22c55e66}.scale-trainer-progress-note.current{background:linear-gradient(135deg,#f97316,#ea580c);border-color:#fb923c;color:#fff;box-shadow:0 0 20px #f9731680;animation:scale-trainer-pulse-orange 1.5s ease-in-out infinite;transform:scale(1.1)}.scale-trainer-score{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(71,85,105,.5)}.scale-trainer-score-value{font-size:2.5rem;font-weight:800;color:#22c55e}.scale-trainer-score-total{font-size:1.25rem;color:#94a3b8}.scale-trainer-fretboard{overflow-x:auto}.scale-trainer-fretboard-title{font-size:1.5rem;font-weight:700;color:#e2e8f0;text-align:center;margin-bottom:1.5rem}.scale-trainer-fretboard-content{min-width:700px}.scale-trainer-fret-numbers{display:flex;margin-bottom:.5rem}.scale-trainer-fret-label{width:3rem;flex-shrink:0}.scale-trainer-fret-num{flex:1;text-align:center;color:#64748b;font-size:.75rem;font-weight:600}.scale-trainer-string{display:flex;height:2.5rem;position:relative}.scale-trainer-string:before{content:"";position:absolute;top:50%;left:3rem;right:0;height:2px;background:linear-gradient(90deg,#a78bfa,#c4b5fd,#a78bfa);transform:translateY(-50%)}.scale-trainer-string-label{width:3rem;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-weight:700;font-size:.875rem;flex-shrink:0;position:relative;z-index:1}.scale-trainer-fret{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,#3d2914,#5c3d1e 20%,#4a3218,#5c3d1e 80%,#3d2914);border-right:2px solid #c9b896}.scale-trainer-fret:first-of-type{background:linear-gradient(180deg,#1a1a1a,#2a2a2a,#1a1a1a);border-right:4px solid #f5f5dc}.scale-trainer-note-dot{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;position:relative;z-index:2;transition:all .3s ease}.scale-trainer-note-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);box-shadow:0 0 20px #14b8a699;animation:scale-trainer-pulse-teal 2s ease-in-out infinite}.scale-trainer-note-dot.scale{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 0 15px #f9731680}.scale-trainer-note-dot.target{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 0 25px #8b5cf6b3;animation:scale-trainer-pulse-purple 1s ease-in-out infinite;transform:scale(1.2)}.scale-trainer-fret-marker{width:8px;height:8px;border-radius:50%;background:#ffffff26;position:relative;z-index:1}.scale-trainer-legend{display:flex;justify-content:center;gap:2rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(71,85,105,.3)}.scale-trainer-legend-item{display:flex;align-items:center;gap:.5rem;color:#94a3b8;font-size:.875rem}.scale-trainer-legend-dot{width:1rem;height:1rem;border-radius:50%}.scale-trainer-legend-dot.root{background:linear-gradient(135deg,#14b8a6,#0d9488);box-shadow:0 0 8px #14b8a680}.scale-trainer-legend-dot.scale{background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 0 8px #f9731666}.scale-trainer-legend-dot.target{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 0 8px #8b5cf680}.scale-trainer-instructions{background:#1e293b80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(71,85,105,.3);border-radius:12px;padding:1.5rem;margin-top:1.5rem}.scale-trainer-instructions-title{font-size:1.25rem;font-weight:700;color:#e2e8f0;margin-bottom:1rem}.scale-trainer-instructions-list{list-style:decimal;padding-left:1.5rem;color:#94a3b8;line-height:1.8}.scale-trainer-instructions-list li{margin-bottom:.25rem}.scale-trainer-examples{margin-top:2rem}.scale-trainer-examples-title{font-size:1.75rem;font-weight:700;color:#e2e8f0;text-align:center;margin-bottom:1.5rem}.scale-trainer-examples-subtitle{text-align:center;color:#94a3b8;margin-bottom:1.5rem;font-size:1rem}.scale-trainer-examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.scale-trainer-example-card{background:#1e293b99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(71,85,105,.4);border-radius:12px;padding:1.25rem;transition:all .3s ease}.scale-trainer-example-card:hover{border-color:#14b8a680;box-shadow:0 4px 20px #14b8a626;transform:translateY(-2px)}.scale-trainer-example-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.scale-trainer-example-scale{font-size:1.125rem;font-weight:700;color:#14b8a6}.scale-trainer-example-genre{font-size:.75rem;padding:.25rem .75rem;background:#f9731633;border:1px solid rgba(249,115,22,.3);border-radius:9999px;color:#fb923c;font-weight:500}.scale-trainer-example-description{color:#94a3b8;font-size:.875rem;line-height:1.6;margin-bottom:1rem}.scale-trainer-example-songs{border-top:1px solid rgba(71,85,105,.3);padding-top:.75rem}.scale-trainer-example-songs-label{color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.scale-trainer-example-song-list{display:flex;flex-wrap:wrap;gap:.5rem}.scale-trainer-example-song{font-size:.8rem;padding:.25rem .625rem;background:#33415599;border-radius:6px;color:#e2e8f0}@keyframes scale-trainer-pulse-teal{0%,to{box-shadow:0 0 20px #14b8a699}50%{box-shadow:0 0 30px #14b8a6cc}}@keyframes scale-trainer-pulse-orange{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes scale-trainer-pulse-purple{0%,to{box-shadow:0 0 25px #8b5cf6b3;transform:scale(1.2)}50%{box-shadow:0 0 35px #8b5cf6e6;transform:scale(1.25)}}@keyframes scale-trainer-pulse-red{0%,to{box-shadow:0 4px 15px #dc262666}50%{box-shadow:0 4px 25px #dc262699}}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.animate-slide-up{animation:slide-up .3s ease-out forwards}.hover\:scale-110:hover{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-blue-500:hover{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.hover\:border-cyan-500:hover{--tw-border-opacity: 1;border-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.hover\:border-green-500:hover{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.hover\:border-orange-500:hover{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity, 1))}.hover\:border-pink-500:hover{--tw-border-opacity: 1;border-color:rgb(236 72 153 / var(--tw-border-opacity, 1))}.hover\:border-purple-500:hover{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.hover\:border-teal-500:hover{--tw-border-opacity: 1;border-color:rgb(20 184 166 / var(--tw-border-opacity, 1))}.hover\:bg-orange-400:hover{--tw-bg-opacity: 1;background-color:rgb(251 146 60 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-600:hover{--tw-bg-opacity: 1;background-color:rgb(71 85 105 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-700:hover{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity, 1))}.hover\:bg-teal-400:hover{--tw-bg-opacity: 1;background-color:rgb(45 212 191 / var(--tw-bg-opacity, 1))}.hover\:from-teal-400:hover{--tw-gradient-from: #2dd4bf var(--tw-gradient-from-position);--tw-gradient-to: rgb(45 212 191 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-teal-300:hover{--tw-gradient-to: #5eead4 var(--tw-gradient-to-position)}.hover\:text-teal-300:hover{--tw-text-opacity: 1;color:rgb(94 234 212 / var(--tw-text-opacity, 1))}.hover\:text-teal-400:hover{--tw-text-opacity: 1;color:rgb(45 212 191 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:opacity-80:hover{opacity:.8}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-slate-600:disabled{--tw-bg-opacity: 1;background-color:rgb(71 85 105 / var(--tw-bg-opacity, 1))}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-2{--tw-translate-x: .5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-pink-400{--tw-text-opacity: 1;color:rgb(244 114 182 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-teal-400{--tw-text-opacity: 1;color:rgb(45 212 191 / var(--tw-text-opacity, 1))}@media(min-width:640px){.sm\:inline{display:inline}.sm\:text-base{font-size:1rem;line-height:1.5rem}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
