@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,: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%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.-bottom-6{bottom:-1.5rem}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.-top-3{top:-.75rem}.-top-5{top:-1.25rem}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-4{right:1rem}.top-0{top:0}.top-0\.5{top:.125rem}.top-4{top:1rem}.top-full{top:100%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.z-\[9999\]{z-index:9999}.order-1{order:1}.order-2{order:2}.\!m-0{margin:0!important}.mx-auto{margin-left:auto;margin-right:auto}.-mt-0\.5{margin-top:-.125rem}.-mt-1{margin-top:-.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.mr-1{margin-right:.25rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.box-border{box-sizing:border-box}.\!block{display:block!important}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-1\/2{height:50%}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-24{height:6rem}.h-28{height:7rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-40{height:10rem}.h-44{height:11rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-\[30vh\]{height:30vh}.h-\[90dvh\]{height:90dvh}.h-\[90vh\]{height:90vh}.h-full{height:100%}.h-screen{height:100vh}.max-h-\[250px\]{max-height:250px}.max-h-\[300px\]{max-height:300px}.max-h-\[90dvh\]{max-height:90dvh}.max-h-full{max-height:100%}.min-h-0{min-height:0px}.min-h-\[180px\]{min-height:180px}.min-h-\[2\.5rem\]{min-height:2.5rem}.min-h-\[2\.75rem\]{min-height:2.75rem}.min-h-\[200px\]{min-height:200px}.min-h-\[4rem\]{min-height:4rem}.min-h-\[5rem\]{min-height:5rem}.min-h-\[6px\]{min-height:6px}.w-0\.5{width:.125rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-full{width:100%}.w-screen{width:100vw}.min-w-0{min-width:0px}.min-w-\[1\.5em\]{min-width:1.5em}.min-w-\[100px\]{min-width:100px}.min-w-full{min-width:100%}.max-w-4xl{max-width:56rem}.max-w-\[120px\]{max-width:120px}.max-w-\[140px\]{max-width:140px}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.-translate-x-1\/2{--tw-translate-x: -50%;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))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 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))}.scale-\[0\.98\]{--tw-scale-x: .98;--tw-scale-y: .98;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))}.transform{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))}.animate-fade-in{animation:fadeIn .3s ease-out}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-zoom-in{animation:zoomIn .3s ease-out}.cursor-ew-resize{cursor:ew-resize}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-stretch{justify-content:stretch}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-\[min\(0\.75rem\,2vh\)\]{gap:min(.75rem,2vh)}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * 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))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-l-2{border-left-width:2px}.border-r-2{border-right-width:2px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-dashed{border-style:dashed}.border-amber-200\/30{border-color:#fde68a4d}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-amber-500\/30{border-color:#f59e0b4d}.border-amber-500\/50{border-color:#f59e0b80}.border-blue-400{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.border-blue-400\/40{border-color:#60a5fa66}.border-blue-400\/50{border-color:#60a5fa80}.border-blue-400\/60{border-color:#60a5fa99}.border-blue-500\/50{border-color:#3b82f680}.border-emerald-300\/30{border-color:#6ee7b74d}.border-green-500\/50{border-color:#22c55e80}.border-indigo-400{--tw-border-opacity: 1;border-color:rgb(129 140 248 / var(--tw-border-opacity, 1))}.border-indigo-500{--tw-border-opacity: 1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.border-indigo-500\/30{border-color:#6366f14d}.border-indigo-500\/50{border-color:#6366f180}.border-indigo-600{--tw-border-opacity: 1;border-color:rgb(79 70 229 / var(--tw-border-opacity, 1))}.border-pink-400{--tw-border-opacity: 1;border-color:rgb(244 114 182 / var(--tw-border-opacity, 1))}.border-pink-400\/40{border-color:#f472b666}.border-pink-400\/50{border-color:#f472b680}.border-pink-400\/60{border-color:#f472b699}.border-pink-500\/50{border-color:#ec489980}.border-purple-400\/40{border-color:#c084fc66}.border-rose-400\/30{border-color:#fb71854d}.border-rose-500\/20{border-color:#f43f5e33}.border-rose-500\/50{border-color:#f43f5e80}.border-violet-400{--tw-border-opacity: 1;border-color:rgb(167 139 250 / var(--tw-border-opacity, 1))}.border-violet-400\/40{border-color:#a78bfa66}.border-violet-400\/50{border-color:#a78bfa80}.border-violet-400\/60{border-color:#a78bfa99}.border-violet-400\/70{border-color:#a78bfab3}.border-violet-500\/50{border-color:#8b5cf680}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.border-white\/5{border-color:#ffffff0d}.border-zinc-500{--tw-border-opacity: 1;border-color:rgb(113 113 122 / var(--tw-border-opacity, 1))}.border-zinc-700{--tw-border-opacity: 1;border-color:rgb(63 63 70 / var(--tw-border-opacity, 1))}.border-zinc-800{--tw-border-opacity: 1;border-color:rgb(39 39 42 / var(--tw-border-opacity, 1))}.border-zinc-900{--tw-border-opacity: 1;border-color:rgb(24 24 27 / var(--tw-border-opacity, 1))}.border-zinc-950{--tw-border-opacity: 1;border-color:rgb(9 9 11 / var(--tw-border-opacity, 1))}.border-t-transparent{border-top-color:transparent}.bg-\[\#18181b\]{--tw-bg-opacity: 1;background-color:rgb(24 24 27 / var(--tw-bg-opacity, 1))}.bg-amber-400{--tw-bg-opacity: 1;background-color:rgb(251 191 36 / var(--tw-bg-opacity, 1))}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-amber-500\/20{background-color:#f59e0b33}.bg-amber-600{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity, 1))}.bg-amber-700\/90{background-color:#b45309e6}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-black\/40{background-color:#0006}.bg-black\/50{background-color:#00000080}.bg-black\/70{background-color:#000000b3}.bg-black\/80{background-color:#000c}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-blue-950\/20{background-color:#17255433}.bg-emerald-700\/90{background-color:#047857e6}.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-indigo-500{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.bg-indigo-500\/20{background-color:#6366f133}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-indigo-600\/20{background-color:#4f46e533}.bg-indigo-600\/30{background-color:#4f46e54d}.bg-pink-500{--tw-bg-opacity: 1;background-color:rgb(236 72 153 / var(--tw-bg-opacity, 1))}.bg-pink-950\/20{background-color:#50072433}.bg-rose-500\/10{background-color:#f43f5e1a}.bg-rose-500\/15{background-color:#f43f5e26}.bg-rose-500\/20{background-color:#f43f5e33}.bg-violet-600{--tw-bg-opacity: 1;background-color:rgb(124 58 237 / var(--tw-bg-opacity, 1))}.bg-violet-950\/20{background-color:#2e106533}.bg-white\/20{background-color:#fff3}.bg-white\/5{background-color:#ffffff0d}.bg-zinc-500{--tw-bg-opacity: 1;background-color:rgb(113 113 122 / var(--tw-bg-opacity, 1))}.bg-zinc-600{--tw-bg-opacity: 1;background-color:rgb(82 82 91 / var(--tw-bg-opacity, 1))}.bg-zinc-700{--tw-bg-opacity: 1;background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))}.bg-zinc-700\/95{background-color:#3f3f46f2}.bg-zinc-800{--tw-bg-opacity: 1;background-color:rgb(39 39 42 / var(--tw-bg-opacity, 1))}.bg-zinc-800\/50{background-color:#27272a80}.bg-zinc-800\/90{background-color:#27272ae6}.bg-zinc-900{--tw-bg-opacity: 1;background-color:rgb(24 24 27 / var(--tw-bg-opacity, 1))}.bg-zinc-900\/50{background-color:#18181b80}.bg-zinc-900\/80{background-color:#18181bcc}.bg-zinc-950{--tw-bg-opacity: 1;background-color:rgb(9 9 11 / var(--tw-bg-opacity, 1))}.bg-zinc-950\/50{background-color:#09090b80}.bg-\[url\(\'data\:image\/svg\+xml\;base64\,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0IiBoZWlnaHQ9IjQiPgo8cmVjdCB3aWR0aD0iNCIgaGVpZ2h0PSIxIiBmaWxsPSJyZ2JhKDI1NSwgMjU1LDI1NSwgMC4wNSkiLz4KPC9zdmc\+\'\)\]{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0IiBoZWlnaHQ9IjQiPgo8cmVjdCB3aWR0aD0iNCIgaGVpZ2h0PSIxIiBmaWxsPSJyZ2JhKDI1NSwgMjU1LDI1NSwgMC4wNSkiLz4KPC9zdmc+)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-black\/60{--tw-gradient-from: rgb(0 0 0 / .6) var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-400\/45{--tw-gradient-from: rgb(96 165 250 / .45) var(--tw-gradient-from-position);--tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-400{--tw-gradient-from: #818cf8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(129 140 248 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-600{--tw-gradient-from: #4f46e5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-400\/45{--tw-gradient-from: rgb(244 114 182 / .45) var(--tw-gradient-from-position);--tw-gradient-to: rgb(244 114 182 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-violet-400\/45{--tw-gradient-from: rgb(167 139 250 / .45) var(--tw-gradient-from-position);--tw-gradient-to: rgb(167 139 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-white\/10{--tw-gradient-from: rgb(255 255 255 / .1) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-white\/5{--tw-gradient-from: rgb(255 255 255 / .05) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-blue-400\/25{--tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(96 165 250 / .25) var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-pink-400\/25{--tw-gradient-to: rgb(244 114 182 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(244 114 182 / .25) var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-violet-400\/25{--tw-gradient-to: rgb(167 139 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(167 139 250 / .25) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-blue-400\/10{--tw-gradient-to: rgb(96 165 250 / .1) var(--tw-gradient-to-position)}.to-pink-400\/10{--tw-gradient-to: rgb(244 114 182 / .1) var(--tw-gradient-to-position)}.to-purple-400{--tw-gradient-to: #c084fc var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.to-violet-400\/10{--tw-gradient-to: rgb(167 139 250 / .1) var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.stroke-\[3\]{stroke-width:3}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-0{padding:0!important}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-8{padding:2rem}.p-\[min\(1rem\,2vh\)\]{padding:min(1rem,2vh)}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pt-2{padding-top:.5rem}.text-center{text-align:center}.align-super{vertical-align:super}.font-chord{font-family:Plus Jakarta Sans,system-ui,sans-serif}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.font-serif{font-family:Times New Roman,Georgia,serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-7xl{font-size:4.5rem;line-height:1}.text-8xl{font-size:6rem;line-height:1}.text-\[10px\]{font-size:10px}.text-base{font-size:1rem;line-height:1.5rem}.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-extrabold{font-weight:800}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-300{--tw-text-opacity: 1;color:rgb(252 211 77 / var(--tw-text-opacity, 1))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-amber-400\/90{color:#fbbf24e6}.text-amber-600\/90{color:#d97706e6}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-indigo-300{--tw-text-opacity: 1;color:rgb(165 180 252 / var(--tw-text-opacity, 1))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.text-pink-400{--tw-text-opacity: 1;color:rgb(244 114 182 / var(--tw-text-opacity, 1))}.text-rose-100{--tw-text-opacity: 1;color:rgb(255 228 230 / var(--tw-text-opacity, 1))}.text-rose-300{--tw-text-opacity: 1;color:rgb(253 164 175 / var(--tw-text-opacity, 1))}.text-rose-400{--tw-text-opacity: 1;color:rgb(251 113 133 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-violet-100{--tw-text-opacity: 1;color:rgb(237 233 254 / var(--tw-text-opacity, 1))}.text-violet-400{--tw-text-opacity: 1;color:rgb(167 139 250 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/30{color:#ffffff4d}.text-white\/40{color:#fff6}.text-white\/50{color:#ffffff80}.text-white\/60{color:#fff9}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-white\/90{color:#ffffffe6}.text-zinc-100{--tw-text-opacity: 1;color:rgb(244 244 245 / var(--tw-text-opacity, 1))}.text-zinc-200{--tw-text-opacity: 1;color:rgb(228 228 231 / var(--tw-text-opacity, 1))}.text-zinc-300{--tw-text-opacity: 1;color:rgb(212 212 216 / var(--tw-text-opacity, 1))}.text-zinc-400{--tw-text-opacity: 1;color:rgb(161 161 170 / var(--tw-text-opacity, 1))}.text-zinc-500{--tw-text-opacity: 1;color:rgb(113 113 122 / var(--tw-text-opacity, 1))}.text-zinc-600{--tw-text-opacity: 1;color:rgb(82 82 91 / var(--tw-text-opacity, 1))}.opacity-20{opacity:.2}.opacity-40{opacity:.4}.opacity-45{opacity:.45}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.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-\[0_0_10px_rgba\(139\,92\,246\,0\.3\)\]{--tw-shadow: 0 0 10px rgba(139,92,246,.3);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(139\,92\,246\,0\.4\)\]{--tw-shadow: 0 0 10px rgba(139,92,246,.4);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(168\,85\,247\,0\.3\)\]{--tw-shadow: 0 0 10px rgba(168,85,247,.3);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(236\,72\,153\,0\.3\)\]{--tw-shadow: 0 0 10px rgba(236,72,153,.3);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(236\,72\,153\,0\.4\)\]{--tw-shadow: 0 0 10px rgba(236,72,153,.4);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(59\,130\,246\,0\.3\)\]{--tw-shadow: 0 0 10px rgba(59,130,246,.3);--tw-shadow-colored: 0 0 10px 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-\[0_0_10px_rgba\(59\,130\,246\,0\.4\)\]{--tw-shadow: 0 0 10px rgba(59,130,246,.4);--tw-shadow-colored: 0 0 10px 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-\[0_0_12px_rgba\(139\,92\,246\,0\.4\)\]{--tw-shadow: 0 0 12px rgba(139,92,246,.4);--tw-shadow-colored: 0 0 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-\[0_0_12px_rgba\(236\,72\,153\,0\.4\)\]{--tw-shadow: 0 0 12px rgba(236,72,153,.4);--tw-shadow-colored: 0 0 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-\[0_0_12px_rgba\(59\,130\,246\,0\.4\)\]{--tw-shadow: 0 0 12px rgba(59,130,246,.4);--tw-shadow-colored: 0 0 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-\[0_0_15px_rgba\(139\,92\,246\,0\.5\)\]{--tw-shadow: 0 0 15px rgba(139,92,246,.5);--tw-shadow-colored: 0 0 15px 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-\[0_0_15px_rgba\(217\,119\,6\,0\.5\)\]{--tw-shadow: 0 0 15px rgba(217,119,6,.5);--tw-shadow-colored: 0 0 15px 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-\[0_0_15px_rgba\(236\,72\,153\,0\.5\)\]{--tw-shadow: 0 0 15px rgba(236,72,153,.5);--tw-shadow-colored: 0 0 15px 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-\[0_0_15px_rgba\(37\,99\,235\,0\.5\)\]{--tw-shadow: 0 0 15px rgba(37,99,235,.5);--tw-shadow-colored: 0 0 15px 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-\[0_0_15px_rgba\(79\,70\,229\,0\.5\)\]{--tw-shadow: 0 0 15px rgba(79,70,229,.5);--tw-shadow-colored: 0 0 15px 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-\[0_0_30px_rgba\(139\,92\,246\,0\.8\)\,0_0_60px_rgba\(139\,92\,246\,0\.4\)\,inset_0_0_30px_rgba\(139\,92\,246\,0\.2\)\]{--tw-shadow: 0 0 30px rgba(139,92,246,.8),0 0 60px rgba(139,92,246,.4),inset 0 0 30px rgba(139,92,246,.2);--tw-shadow-colored: 0 0 30px var(--tw-shadow-color), 0 0 60px var(--tw-shadow-color), inset 0 0 30px 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-\[0_0_30px_rgba\(236\,72\,153\,0\.8\)\,0_0_60px_rgba\(236\,72\,153\,0\.4\)\,inset_0_0_30px_rgba\(236\,72\,153\,0\.2\)\]{--tw-shadow: 0 0 30px rgba(236,72,153,.8),0 0 60px rgba(236,72,153,.4),inset 0 0 30px rgba(236,72,153,.2);--tw-shadow-colored: 0 0 30px var(--tw-shadow-color), 0 0 60px var(--tw-shadow-color), inset 0 0 30px 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-\[0_0_30px_rgba\(59\,130\,246\,0\.8\)\,0_0_60px_rgba\(59\,130\,246\,0\.4\)\,inset_0_0_30px_rgba\(59\,130\,246\,0\.2\)\]{--tw-shadow: 0 0 30px rgba(59,130,246,.8),0 0 60px rgba(59,130,246,.4),inset 0 0 30px rgba(59,130,246,.2);--tw-shadow-colored: 0 0 30px var(--tw-shadow-color), 0 0 60px var(--tw-shadow-color), inset 0 0 30px 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-\[0_0_32px_rgba\(139\,92\,246\,0\.45\)\]{--tw-shadow: 0 0 32px rgba(139,92,246,.45);--tw-shadow-colored: 0 0 32px 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-inner{--tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / .05);--tw-shadow-colored: inset 0 2px 4px 0 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-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px 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-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px 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-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;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)}.shadow-amber-500\/10{--tw-shadow-color: rgb(245 158 11 / .1);--tw-shadow: var(--tw-shadow-colored)}.shadow-black{--tw-shadow-color: #000;--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-500\/20{--tw-shadow-color: rgb(99 102 241 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-500\/25{--tw-shadow-color: rgb(99 102 241 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-500\/30{--tw-shadow-color: rgb(99 102 241 / .3);--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-500\/40{--tw-shadow-color: rgb(99 102 241 / .4);--tw-shadow: var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.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-1{--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(1px + 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-amber-400\/40{--tw-ring-color: rgb(251 191 36 / .4)}.ring-blue-400\/50{--tw-ring-color: rgb(96 165 250 / .5)}.ring-blue-400\/60{--tw-ring-color: rgb(96 165 250 / .6)}.ring-blue-400\/80{--tw-ring-color: rgb(96 165 250 / .8)}.ring-indigo-400\/30{--tw-ring-color: rgb(129 140 248 / .3)}.ring-pink-400\/25{--tw-ring-color: rgb(244 114 182 / .25)}.ring-pink-400\/50{--tw-ring-color: rgb(244 114 182 / .5)}.ring-pink-400\/60{--tw-ring-color: rgb(244 114 182 / .6)}.ring-pink-400\/80{--tw-ring-color: rgb(244 114 182 / .8)}.ring-purple-400\/40{--tw-ring-color: rgb(192 132 252 / .4)}.ring-violet-400\/50{--tw-ring-color: rgb(167 139 250 / .5)}.ring-violet-400\/60{--tw-ring-color: rgb(167 139 250 / .6)}.ring-violet-400\/80{--tw-ring-color: rgb(167 139 250 / .8)}.ring-white\/30{--tw-ring-color: rgb(255 255 255 / .3)}.blur{--tw-blur: blur(8px);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)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));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)}.drop-shadow-lg{--tw-drop-shadow: drop-shadow(0 10px 8px rgb(0 0 0 / .04)) drop-shadow(0 4px 3px rgb(0 0 0 / .1));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)}.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-md{--tw-backdrop-blur: blur(12px);-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)}.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)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.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-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;font-family:inherit}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.chord-modal-compact-scrollbar-hide{scrollbar-width:none;-ms-overflow-style:none}.chord-modal-compact-scrollbar-hide::-webkit-scrollbar{display:none}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;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\:-translate-y-1:hover{--tw-translate-y: -.25rem;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\:scale-\[1\.02\]:hover{--tw-scale-x: 1.02;--tw-scale-y: 1.02;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-amber-500\/50:hover{border-color:#f59e0b80}.hover\:border-indigo-500\/50:hover{border-color:#6366f180}.hover\:border-white\/20:hover{border-color:#fff3}.hover\:bg-amber-600:hover{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity, 1))}.hover\:bg-emerald-600:hover{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-500:hover{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-600\/30:hover{background-color:#4f46e54d}.hover\:bg-indigo-600\/50:hover{background-color:#4f46e580}.hover\:bg-rose-500\/20:hover{background-color:#f43f5e33}.hover\:bg-rose-500\/25:hover{background-color:#f43f5e40}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-zinc-500:hover{--tw-bg-opacity: 1;background-color:rgb(113 113 122 / var(--tw-bg-opacity, 1))}.hover\:bg-zinc-600:hover{--tw-bg-opacity: 1;background-color:rgb(82 82 91 / var(--tw-bg-opacity, 1))}.hover\:bg-zinc-700:hover{--tw-bg-opacity: 1;background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))}.hover\:bg-zinc-800:hover{--tw-bg-opacity: 1;background-color:rgb(39 39 42 / var(--tw-bg-opacity, 1))}.hover\:from-indigo-500:hover{--tw-gradient-from: #6366f1 var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-purple-500:hover{--tw-gradient-to: #a855f7 var(--tw-gradient-to-position)}.hover\:text-white\/70:hover{color:#ffffffb3}.hover\:text-white\/80:hover{color:#fffc}.hover\:text-zinc-200:hover{--tw-text-opacity: 1;color:rgb(228 228 231 / var(--tw-text-opacity, 1))}.hover\:text-zinc-300:hover{--tw-text-opacity: 1;color:rgb(212 212 216 / var(--tw-text-opacity, 1))}.hover\:shadow-indigo-500\/20:hover{--tw-shadow-color: rgb(99 102 241 / .2);--tw-shadow: var(--tw-shadow-colored)}.hover\:shadow-indigo-500\/50:hover{--tw-shadow-color: rgb(99 102 241 / .5);--tw-shadow: var(--tw-shadow-colored)}.hover\:shadow-indigo-500\/60:hover{--tw-shadow-color: rgb(99 102 241 / .6);--tw-shadow: var(--tw-shadow-colored)}.hover\:ring-amber-400\/60:hover{--tw-ring-color: rgb(251 191 36 / .6)}.focus\:border-indigo-500:focus{--tw-border-opacity: 1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.focus\:ring-1:focus{--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(1px + 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)}.focus\:ring-indigo-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity, 1))}.active\:scale-95:active{--tw-scale-x: .95;--tw-scale-y: .95;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))}.active\:bg-indigo-500\/20:active{background-color:#6366f133}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-20:disabled{opacity:.2}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.group:hover .group-hover\:scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;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))}@media(prefers-reduced-motion:no-preference){@keyframes cadenceEmphasis{0%{transform:scale(1) translate(0);box-shadow:0 0 0 8px #a78bfa8c,0 0 40px #6366f1b3,0 0 72px #4f46e559}12%{transform:scale(1.065) translate(-8px);box-shadow:0 0 #a78bfa00,0 0 56px #c084fcf2,0 0 100px #6366f173}24%{transform:scale(1.075) translate(8px);box-shadow:0 0 0 20px #a78bfa40,0 0 64px #818cf8d9}36%{transform:scale(1.055) translate(-6px);box-shadow:0 0 #a78bfa00,0 0 52px #6366f1bf}50%{transform:scale(1.08) translate(0);box-shadow:0 0 0 14px #c4b5fd59,0 0 72px #818cf8e6}65%{transform:scale(1.02) translate(5px);box-shadow:0 0 0 6px #a78bfa66,0 0 36px #6366f18c}to{transform:scale(1) translate(0);box-shadow:0 0 0 10px #a78bfa73,0 0 44px #6366f1a6}}.motion-safe\:animate-cadence-emphasis{animation:cadenceEmphasis 1.05s cubic-bezier(.34,1.2,.64,1) 3}}@media(prefers-reduced-motion:reduce){.motion-reduce\:ring-4{--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(4px + 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)}.motion-reduce\:ring-violet-400{--tw-ring-opacity: 1;--tw-ring-color: rgb(167 139 250 / var(--tw-ring-opacity, 1))}.motion-reduce\:ring-offset-4{--tw-ring-offset-width: 4px}.motion-reduce\:ring-offset-zinc-950{--tw-ring-offset-color: #09090b}}@media(min-width:640px){.sm\:inline{display:inline}.sm\:hidden{display:none}.sm\:max-w-md{max-width:28rem}.sm\:flex-initial{flex:0 1 auto}.sm\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-4{gap:1rem}.sm\:px-4{padding-left:1rem;padding-right:1rem}}@media(min-width:768px){.md\:order-1{order:1}.md\:order-2{order:2}.md\:col-span-2{grid-column:span 2 / span 2}.md\:col-span-3{grid-column:span 3 / span 3}.md\:col-span-9{grid-column:span 9 / span 9}.md\:mb-0{margin-bottom:0}.md\:block{display:block}.md\:inline{display:inline}.md\:flex{display:flex}.md\:hidden{display:none}.md\:h-10{height:2.5rem}.md\:h-14{height:3.5rem}.md\:h-16{height:4rem}.md\:h-24{height:6rem}.md\:h-32{height:8rem}.md\:h-52{height:13rem}.md\:h-56{height:14rem}.md\:h-6{height:1.5rem}.md\:h-7{height:1.75rem}.md\:h-\[18px\]{height:18px}.md\:w-10{width:2.5rem}.md\:w-14{width:3.5rem}.md\:w-16{width:4rem}.md\:w-24{width:6rem}.md\:w-6{width:1.5rem}.md\:w-7{width:1.75rem}.md\:w-\[18px\]{width:18px}.md\:max-w-none{max-width:none}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:gap-2{gap:.5rem}.md\:gap-3{gap:.75rem}.md\:gap-6{gap:1.5rem}.md\:gap-\[min\(1rem\,2\.5vh\)\]{gap:min(1rem,2.5vh)}.md\:rounded-3xl{border-radius:1.5rem}.md\:p-4{padding:1rem}.md\:p-6{padding:1.5rem}.md\:p-\[min\(1\.5rem\,2\.5vh\)\]{padding:min(1.5rem,2.5vh)}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}}.email-login-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.email-login-modal{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:100%;position:relative;box-shadow:0 25px 50px -12px #00000040}.email-login-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;line-height:1;color:#718096;cursor:pointer;padding:.25rem}.email-login-close:hover{color:#4a5568}.email-login-title{margin:0 0 1.5rem;font-size:1.5rem;font-weight:700;color:#1a202c}.email-login-form{display:flex;flex-direction:column;gap:1.25rem}.email-login-error{padding:.75rem 1rem;background:#fed7d7;color:#c53030;border-radius:8px;font-size:.9rem}.email-login-label{display:flex;flex-direction:column;gap:.375rem;font-size:.9rem;font-weight:500;color:#4a5568}.email-login-input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:inherit}.email-login-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.email-login-input:disabled{opacity:.7;cursor:not-allowed}.email-login-submit{margin-top:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit}.email-login-submit:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.email-login-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.email-login-switch{margin:1.25rem 0 0;font-size:.9rem;color:#718096;text-align:center}.email-login-link{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;font-family:inherit;font-size:inherit}.email-login-link:hover{text-decoration:underline}.spinner-small{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:email-login-spin .7s linear infinite}@keyframes email-login-spin{to{transform:rotate(360deg)}}.email-login-forgot-wrap{margin:-.25rem 0 0;text-align:right;font-size:.9rem}.email-login-success-msg{margin:0 0 1.25rem;line-height:1.5;font-size:.95rem;color:#4a5568;text-align:left}.landing-page{width:100%;min-height:100vh;background:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}.hero-section{min-height:90vh;display:flex;align-items:center;padding:6rem 2rem;background:linear-gradient(180deg,#fff,#f8f9ff)}.hero-container{max-width:1400px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}.hero-content{display:flex;flex-direction:column;gap:2rem}.hero-title{font-size:clamp(3.5rem,8vw,6rem);font-weight:900;line-height:1.1;letter-spacing:-.04em;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.hero-subtitle{font-size:clamp(1.25rem,2.5vw,1.75rem);line-height:1.6;color:#4a5568;font-weight:400;margin:0;max-width:90%}.hero-cta{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.cta-primary{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1.125rem 2.5rem;font-size:1.125rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px #667eea4d;width:-moz-fit-content;width:fit-content;font-family:Inter,sans-serif}.cta-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 40px #667eea66}.cta-primary:active:not(:disabled){transform:translateY(0)}.cta-primary:disabled{opacity:.7;cursor:not-allowed}.cta-reassurance{font-size:.9rem;color:#718096;margin:0;font-weight:400}.cta-email-link{background:none;border:none;color:#667eea;font-size:.95rem;font-weight:500;cursor:pointer;padding:.5rem 0;font-family:inherit}.cta-email-link:hover:not(:disabled){text-decoration:underline}.cta-email-link:disabled{opacity:.6;cursor:not-allowed}.hero-visual{display:flex;justify-content:center;align-items:center;position:relative}.device-mockup{position:relative;width:100%;max-width:600px;perspective:1000px}.device-frame{position:relative;background:linear-gradient(135deg,#1a202c,#2d3748);border-radius:24px;padding:1rem;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a inset;transform:rotateY(-5deg) rotateX(2deg);transition:transform .3s ease}.device-frame:hover{transform:rotateY(0) rotateX(0)}.device-screen{border-radius:16px;overflow:hidden;background:#000;box-shadow:0 10px 30px #00000080}.screen-image{width:100%;height:auto;display:block;border-radius:16px}.app-preview{background:#1a1a1a;color:#fff;padding:1.25rem;height:100%;min-height:450px;display:flex;flex-direction:column;gap:1.25rem;font-family:Inter,sans-serif}.preview-header{display:flex;flex-direction:column;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.preview-app-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.preview-exercise-info{display:flex;flex-direction:column;gap:.25rem}.preview-exercise-title{font-size:.95rem;font-weight:600;color:#fff}.preview-composer{font-size:.85rem;color:#a0aec0;font-style:italic}.preview-video-area{flex:1;background:#0a0a0a;border-radius:12px;display:flex;align-items:center;justify-content:center;min-height:200px;position:relative;overflow:hidden}.preview-video-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.7}.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;transition:background .3s ease}.video-overlay:hover{background:#0003}.play-icon{width:60px;height:60px;color:#fff;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.preview-timeline-section{display:flex;flex-direction:column;gap:.75rem}.preview-timeline{display:flex;flex-direction:column;gap:.5rem}.timeline-bar{position:relative;height:8px;background:#ffffff1a;border-radius:4px;overflow:visible}.timeline-progress{position:absolute;left:0;top:0;height:100%;width:50%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px}.timeline-marker{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 0 0 3px #667eea80;z-index:2}.timeline-question-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#fff6;border:2px solid rgba(255,255,255,.6);border-radius:50%;z-index:1;cursor:pointer}.timeline-question-marker.answered{background:#10b981;border-color:#10b981;box-shadow:0 0 0 2px #10b9814d}.timeline-time{display:flex;justify-content:space-between;font-size:.75rem;color:#718096}.preview-progress{text-align:center;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.progress-text{font-size:.85rem;color:#a0aec0;font-weight:500}.preview-chords{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.chords-label{font-size:.85rem;color:#a0aec0;font-weight:500;text-align:center}.chords-buttons{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.chord-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:8px;color:#a0aec0;cursor:pointer;transition:all .2s ease;min-width:60px;gap:.25rem}.chord-btn:hover{background:#667eea33;border-color:#667eea80;transform:translateY(-2px)}.chord-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.chord-degree{font-size:1rem;font-weight:700;line-height:1}.chord-inversion{font-size:.75rem;font-weight:500;opacity:.8}.preview-controls{display:flex;justify-content:center;gap:1rem;padding-top:.5rem}.control-btn{width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.control-btn:hover{background:#fff3;transform:scale(1.1)}.control-btn.play{width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 15px #667eea66}.control-btn.play:hover{box-shadow:0 6px 20px #667eea99;transform:scale(1.1)}.features-section{padding:8rem 2rem;background:#fff}.feature-block{max-width:1200px;margin:0 auto 8rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.feature-block:last-child{margin-bottom:0}.feature-right .feature-content{order:1}.feature-right .feature-image{order:2}.feature-image{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.feature-image:hover{transform:translateY(-8px);box-shadow:0 30px 80px #00000026}.feature-image img{width:100%;height:auto;display:block}.feature-image img{width:100%;height:auto;display:block;border-radius:20px;-o-object-fit:cover;object-fit:cover;min-height:300px}.feature-content{display:flex;flex-direction:column;gap:1.5rem}.feature-title{font-size:clamp(2rem,4vw,2.75rem);font-weight:800;line-height:1.2;color:#1a202c;margin:0;letter-spacing:-.02em}.feature-description{font-size:1.125rem;line-height:1.8;color:#4a5568;margin:0}.feature-block:nth-child(2n){background:#f8f9ff;padding:4rem;border-radius:24px;margin-left:-2rem;margin-right:-2rem}.cta-section{padding:8rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.cta-container{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1}.cta-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:800;color:#fff;margin:0 0 3rem;line-height:1.2;letter-spacing:-.02em}.cta-buttons{display:flex;flex-direction:column;gap:1.25rem;align-items:center}.cta-button-primary{padding:1.125rem 3rem;font-size:1.125rem;font-weight:600;color:#667eea;background:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #0003;font-family:Inter,sans-serif;width:100%;max-width:400px}.cta-button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 40px #0000004d}.cta-button-primary:disabled{opacity:.7;cursor:not-allowed}.cta-button-secondary{padding:1.125rem 3rem;font-size:1.125rem;font-weight:600;color:#fff;background:transparent;border:2px solid rgba(255,255,255,.5);border-radius:12px;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;width:100%;max-width:400px}.cta-button-secondary:hover{background:#ffffff1a;border-color:#fff;transform:translateY(-2px)}.landing-footer{padding:3rem 2rem;text-align:center;background:#1a202c;color:#a0aec0}.landing-footer p{margin:0;font-size:.9rem}.google-icon{width:20px;height:20px;flex-shrink:0}.spinner-small{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.fade-up{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.fade-up-visible{opacity:1;transform:translateY(0)}@media(max-width:1024px){.hero-container{gap:4rem}.feature-block{gap:3rem}}@media(max-width:768px){.hero-section{padding:4rem 1.5rem;min-height:auto}.hero-container{grid-template-columns:1fr;gap:3rem;text-align:center}.hero-content{align-items:center}.hero-subtitle{max-width:100%;text-align:center}.hero-cta{align-items:center}.cta-primary{width:100%;max-width:100%}.device-mockup{max-width:100%}.device-frame{transform:none}.features-section{padding:4rem 1.5rem}.feature-block{grid-template-columns:1fr;gap:2rem;margin-bottom:4rem}.feature-right .feature-content,.feature-right .feature-image{order:initial}.feature-block:nth-child(2n){padding:2rem;margin-left:-1.5rem;margin-right:-1.5rem}.feature-content{text-align:center}.cta-section{padding:4rem 1.5rem}.cta-buttons{width:100%}.cta-button-primary,.cta-button-secondary{width:100%;max-width:100%}}@media(max-width:480px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.125rem}.feature-title{font-size:1.75rem}.feature-description{font-size:1rem}.cta-title{font-size:2rem}}.formation-picker--modal .formation-picker-selected{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-bottom:.5rem;min-height:2rem}.formation-picker--modal .formation-picker-chip--selected{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border-radius:9999px;border:1px solid #6366f1;background:#4f46e5;color:#fff;font-size:.8rem;cursor:pointer;transition:background .15s ease}.formation-picker--modal .formation-picker-chip--selected:hover:not(:disabled){background:#6366f1}.formation-picker--modal .formation-picker-chip-remove{font-size:1rem;line-height:1;opacity:.9}.formation-picker--modal .formation-picker-clear{background:none;border:1px dashed #6b7280;color:#9ca3af;font-size:.75rem;padding:.25rem .5rem;border-radius:6px;cursor:pointer}.formation-picker--modal .formation-picker-clear:hover:not(:disabled){border-color:#6366f1;color:#a5b4fc}.formation-picker--modal .formation-picker-input-wrap{position:relative}.formation-picker--modal .formation-picker-input{width:100%;padding:.65rem .75rem;border-radius:8px;border:2px solid #4b5563;background:#1f2937;color:#e5e7eb;font-size:.9rem}.formation-picker--modal .formation-picker-input:focus{outline:none;border-color:#6366f1}.formation-picker--modal .formation-picker-input:disabled{opacity:.6}.formation-picker--modal .formation-picker-suggestions{position:absolute;top:100%;left:0;right:0;background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;max-height:200px;overflow-y:auto;z-index:20;list-style:none;padding:0;margin:0}.formation-picker--modal .formation-picker-suggestion{width:100%;text-align:left;padding:.5rem .75rem;background:none;border:none;color:#e0e0e0;font-size:.875rem;cursor:pointer}.formation-picker--modal .formation-picker-suggestion--active,.formation-picker--modal .formation-picker-suggestion:hover{background:#333}.formation-picker--modal .formation-picker-hint{display:block;margin-top:.35rem;font-size:.8rem;color:#9ca3af}.formation-picker--freeMode .formation-picker-selected{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.5rem}.formation-picker--freeMode .formation-picker-chip--selected{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .85rem;border-radius:20px;border:2px solid transparent;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer}.formation-picker--freeMode .formation-picker-clear{background:none;border:2px dashed #d1d5db;color:#6b7280;font-size:.8rem;padding:.4rem .65rem;border-radius:20px;cursor:pointer}.formation-picker--freeMode .formation-picker-clear:hover:not(:disabled){border-color:#667eea;color:#667eea}.formation-picker--freeMode .formation-picker-input-wrap{position:relative}.formation-picker--freeMode .formation-picker-input{width:100%;padding:.65rem .85rem;border-radius:12px;border:2px solid #e5e7eb;background:#fff;color:#111827;font-size:.875rem}.formation-picker--freeMode .formation-picker-input:focus{outline:none;border-color:#667eea}.formation-picker--freeMode .formation-picker-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e5e7eb;border-radius:12px;max-height:220px;overflow-y:auto;z-index:30;box-shadow:0 8px 24px #0000001f;list-style:none;padding:0;margin:0}.formation-picker--freeMode .formation-picker-suggestion{width:100%;text-align:left;padding:.55rem .85rem;background:none;border:none;color:#374151;font-size:.875rem;cursor:pointer}.formation-picker--freeMode .formation-picker-suggestion--active,.formation-picker--freeMode .formation-picker-suggestion:hover{background:#f3f4f6}.formation-picker--freeMode .formation-picker-hint{display:block;margin-top:.35rem;font-size:.75rem;color:#6b7280}.formation-picker--dashboard .formation-picker-selected{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;margin-bottom:.45rem}.formation-picker--dashboard .formation-picker-chip--selected{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem .75rem;border-radius:8px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer}.formation-picker--dashboard .formation-picker-clear{background:none;border:1px dashed #cbd5e1;color:#64748b;font-size:.75rem;padding:.3rem .55rem;border-radius:6px;cursor:pointer}.formation-picker--dashboard .formation-picker-clear:hover:not(:disabled){border-color:#667eea;color:#667eea}.formation-picker--dashboard .formation-picker-input-wrap{position:relative}.formation-picker--dashboard .formation-picker-input{width:100%;padding:.55rem .75rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;font-size:.8125rem}.formation-picker--dashboard .formation-picker-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.formation-picker--dashboard .formation-picker-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-height:200px;overflow-y:auto;z-index:40;box-shadow:0 4px 16px #0f172a1a;list-style:none;padding:0;margin:0}.formation-picker--dashboard .formation-picker-suggestion{width:100%;text-align:left;padding:.45rem .75rem;background:none;border:none;color:#334155;font-size:.8125rem;cursor:pointer}.formation-picker--dashboard .formation-picker-suggestion--active,.formation-picker--dashboard .formation-picker-suggestion:hover{background:#f1f5f9}.formation-picker--dashboard .formation-picker-hint{display:block;margin-top:.3rem;font-size:.72rem;color:#64748b}.formation-picker-chip:disabled,.formation-picker-input:disabled,.formation-picker-clear:disabled{opacity:.55;cursor:not-allowed}.profile-avatar-picker{margin-bottom:1.5rem}.profile-avatar-picker--modal{padding:1rem 1.25rem;background:#0003;border:1px solid #3a3a3a;border-radius:12px}.profile-avatar-picker--page{margin:0 1rem 1.25rem;padding:1rem 1.25rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px}.profile-avatar-picker-title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#e8e8e8}.profile-avatar-picker--page .profile-avatar-picker-title{color:#ffffffeb}.profile-avatar-picker-filters{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.65rem}.profile-avatar-picker-filter{padding:.35rem .75rem;font-size:.8rem;font-weight:500;color:#aaa;background:#ffffff0f;border:1px solid #444;border-radius:999px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.profile-avatar-picker-filter:hover{color:#e8e8e8;border-color:#666}.profile-avatar-picker-filter--active{color:#fff;border-color:#667eea;background:#667eea40}.profile-avatar-picker--page .profile-avatar-picker-filter{color:#ffffffa6;background:#ffffff0f;border-color:#ffffff1f}.profile-avatar-picker--page .profile-avatar-picker-filter--active{color:#fff;border-color:#667eeacc;background:#667eea4d}.profile-avatar-picker-filter-hint{margin:0 0 .5rem;font-size:.75rem;color:#888;line-height:1.35}.profile-avatar-picker--page .profile-avatar-picker-filter-hint{color:#ffffff73}.profile-avatar-picker-grid-scroll{max-height:min(240px,42vh);overflow-y:auto;overflow-x:hidden;padding-right:.35rem;margin-bottom:.35rem;scrollbar-gutter:stable}.profile-avatar-picker-grid-scroll::-webkit-scrollbar{width:6px}.profile-avatar-picker-grid-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.profile-avatar-picker-grid{display:flex;flex-wrap:wrap;gap:.65rem;align-items:flex-start}.profile-avatar-picker-tile-wrap{position:relative;flex-shrink:0}.profile-avatar-picker-tile-remove{position:absolute;top:-4px;right:-4px;z-index:2;width:22px;height:22px;padding:0;line-height:1;font-size:1rem;font-weight:700;color:#fff;background:#b42828f2;border:2px solid #1a1a1a;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #0006}.profile-avatar-picker-tile-remove:hover:not(:disabled){background:#dc2626}.profile-avatar-picker-tile-remove:disabled{opacity:.5;cursor:not-allowed}.profile-avatar-picker-tile{position:relative;width:52px;height:52px;padding:0;border:2px solid transparent;border-radius:50%;cursor:pointer;background:#2a2a2a;overflow:hidden;flex-shrink:0;transition:border-color .15s ease,transform .12s ease}.profile-avatar-picker-tile:hover:not(:disabled){border-color:#667eeaa6;transform:scale(1.04)}.profile-avatar-picker-tile:disabled{opacity:.55;cursor:not-allowed}.profile-avatar-picker-tile--selected{border-color:#667eea;box-shadow:0 0 0 2px #667eea59}.profile-avatar-picker-tile--initials{display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.profile-avatar-picker-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.profile-avatar-picker-tile-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.1rem;font-weight:700;color:#ffffff73;background:#2a2a2a;-webkit-user-select:none;-moz-user-select:none;user-select:none}.profile-avatar-picker-hint{margin:.5rem 0 0;font-size:.8rem;color:#888;line-height:1.35}.profile-avatar-picker--page .profile-avatar-picker-hint{color:#ffffff80}.profile-avatar-picker-admin{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.08)}.profile-avatar-picker-admin summary{cursor:pointer;font-size:.85rem;color:#a8a8a8;list-style-position:outside}.profile-avatar-picker-admin summary:hover{color:#ccc}.profile-avatar-picker-admin-body{margin-top:.75rem;display:flex;flex-direction:column;gap:.65rem}.profile-avatar-picker-admin-link{font-size:.85rem;color:#8b9cff;text-decoration:none}.profile-avatar-picker-admin-link:hover{text-decoration:underline}.profile-avatar-picker-admin-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.profile-avatar-picker-admin-input{flex:1;min-width:180px;padding:.45rem .6rem;border-radius:8px;border:1px solid #444;background:#1e1e1e;color:#eee;font-size:.85rem}.profile-avatar-picker-admin-add{padding:.45rem .85rem;border-radius:8px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer}.profile-avatar-picker-admin-add:disabled{opacity:.5;cursor:not-allowed}.profile-avatar-picker-admin-msg{margin:0;font-size:.8rem}.profile-avatar-picker-admin-msg--err{color:#f87171}.profile-avatar-picker-admin-msg--ok{color:#86efac}.profile-avatar-picker-admin-extra{margin:0;padding-left:1.1rem;font-size:.8rem;color:#999}.profile-avatar-picker-admin-extra li{margin:.35rem 0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.profile-avatar-picker-admin-remove{padding:.2rem .5rem;font-size:.75rem;border-radius:6px;border:1px solid #555;background:transparent;color:#ccc;cursor:pointer}.profile-avatar-picker-admin-remove:hover{border-color:#f87171;color:#f87171}.profile-avatar-picker-empty-library{margin:0 0 .65rem;font-size:.8rem;color:#a0a0a0;line-height:1.4}.profile-avatar-picker--page .profile-avatar-picker-empty-library{color:#ffffff8c}.profile-avatar-picker-admin-suggestions{margin:0}.profile-avatar-picker-admin-suggestion-list{margin:0;padding-left:1.15rem;font-size:.8rem;color:#aaa;line-height:1.5}.profile-avatar-picker-admin-suggestion-list li{margin:.25rem 0}.avatar-picker-modal-backdrop{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000a6}.avatar-picker-modal-panel{width:100%;max-width:520px;max-height:min(90vh,640px);display:flex;flex-direction:column;background:linear-gradient(135deg,#1e1e1e,#2a2a2a);border:1px solid #3a3a3a;border-radius:16px;box-shadow:0 20px 60px #0000008c;overflow:hidden}.avatar-picker-modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid #3a3a3a;flex-shrink:0}.avatar-picker-modal-header h2{margin:0;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.avatar-picker-modal-close{flex-shrink:0;width:40px;height:40px;border:none;border-radius:8px;background:transparent;color:#b0b0b0;font-size:1.75rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.avatar-picker-modal-close:hover{background:#3a3a3a;color:#fff}.avatar-picker-modal-body{overflow-y:auto;flex:1;min-height:0}.avatar-picker-modal-body .profile-avatar-picker--modal{border:none;border-radius:0;margin-bottom:0}.profile-modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.profile-modal-container{background:linear-gradient(135deg,#1e1e1e,#2a2a2a);border:1px solid #3a3a3a;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.profile-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #3a3a3a}.profile-modal-header h2{margin:0;font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-modal-close{background:none;border:none;color:#b0b0b0;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.profile-modal-close:hover{background:#3a3a3a;color:#fff}.profile-modal-loading{padding:3rem;text-align:center;color:#b0b0b0}.profile-modal-content{padding:2rem}.profile-user-info{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#667eea1a;border-radius:12px;border:1px solid rgba(102,126,234,.2);margin-bottom:2rem}.profile-avatar-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-change-avatar-btn{margin-top:.15rem;padding:.35rem .75rem;font-size:.8rem;font-weight:500;color:#c7d2fe;background:#667eea26;border:1px solid rgba(102,126,234,.45);border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.profile-change-avatar-btn:hover{background:#667eea47;border-color:#667eea;color:#eef2ff}.profile-avatar-large{width:80px;height:80px;border-radius:50%;border:3px solid #667eea;-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #667eea}.profile-avatar-initials{font-size:2rem;font-weight:700;color:#fff}.profile-avatar-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden;clip:rect(0,0,0,0)}.profile-avatar-change-btn{padding:.35rem .75rem;font-size:.8rem;font-weight:500;color:#667eea;background:#667eea26;border:1px solid rgba(102,126,234,.4);border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.profile-avatar-change-btn:hover:not(:disabled){background:#667eea40;border-color:#667eea}.profile-avatar-change-btn:disabled{opacity:.7;cursor:not-allowed}.profile-avatar-error{margin:0;font-size:.8rem;color:#f87171;max-width:180px;text-align:center}.profile-display-name-wrap{margin-bottom:.25rem}.profile-display-name-wrap .profile-display-name{margin:0 0 .25rem;font-size:1.5rem;color:#fff}.profile-display-name-edit-btn{display:inline-block;padding:.25rem .6rem;font-size:.8rem;font-weight:500;color:#a5b4fc;background:transparent;border:1px solid rgba(102,126,234,.4);border-radius:6px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.profile-display-name-edit-btn:hover{background:#667eea33;border-color:#667eea;color:#c7d2fe}.profile-display-name-edit{margin-bottom:.5rem}.profile-display-name-input{display:block;width:100%;max-width:280px;padding:.5rem .75rem;font-size:1rem;color:#fff;background:#00000040;border:1px solid rgba(102,126,234,.5);border-radius:8px;margin-bottom:.5rem}.profile-display-name-input::-moz-placeholder{color:#9ca3af}.profile-display-name-input::placeholder{color:#9ca3af}.profile-display-name-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea4d}.profile-display-name-actions{display:flex;gap:.5rem;flex-wrap:wrap}.profile-display-name-save{padding:.4rem .9rem;font-size:.85rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:opacity .2s ease}.profile-display-name-save:hover:not(:disabled){opacity:.95}.profile-display-name-save:disabled{opacity:.7;cursor:not-allowed}.profile-display-name-cancel{padding:.4rem .9rem;font-size:.85rem;font-weight:500;color:#b0b0b0;background:transparent;border:1px solid #4a4a4a;border-radius:8px;cursor:pointer;transition:background .2s ease,color .2s ease}.profile-display-name-cancel:hover:not(:disabled){background:#3a3a3a;color:#e5e5e5}.profile-display-name-error{margin:.5rem 0 0;font-size:.8rem;color:#f87171}.preview-avatar{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;border:3px solid #fbbf24}.preview-avatar-text{font-size:2.5rem}.profile-preview-badge{margin:.5rem 0 0;padding:.25rem .75rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;border-radius:12px;font-size:.75rem;font-weight:700;display:inline-block}.profile-user-info h3{margin:0 0 .5rem;font-size:1.5rem;color:#fff}.profile-role{margin:.25rem 0;color:#b0b0b0;font-size:.95rem}.profile-xp{margin:.25rem 0 0;color:#6b7280;font-size:.9375rem}.profile-xp-mode-label{font-size:.8rem;color:#9ca3af;font-style:italic;margin-right:.25rem}.profile-level-title{font-weight:600;color:#111827}.profile-xp-value{color:#6b7280;font-weight:500;font-size:1rem}.profile-stats-section{margin-bottom:2.5rem}.profile-stats-section h3{font-size:1.25rem;color:#fff;margin:0 0 1.5rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:12px;padding:1.5rem;text-align:center;transition:all .2s ease}.stat-card:hover{border-color:#667eea;transform:translateY(-2px)}.stat-value{font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:#b0b0b0}.degree-stats-list,.cadence-stats-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.degree-stat-item,.cadence-stat-item{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;padding:.75rem 1rem}.degree-stat-header,.cadence-stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.profile-stats-section .degree-roman{font-family:Cinzel,Times New Roman,serif;font-weight:600;letter-spacing:.02em}.degree-name,.cadence-name{font-size:1.1rem;font-weight:700;color:#fff}.degree-percentage,.cadence-percentage{font-size:1.1rem;font-weight:700;color:#667eea}.degree-stat-bar,.cadence-stat-bar{height:8px;background:#3a3a3a;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.degree-stat-fill,.cadence-stat-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease}.degree-stat-detail,.cadence-stat-detail{font-size:.85rem;color:#b0b0b0}.degree-stat-item--sub{padding:.75rem 1rem;margin-left:1.5rem}.degree-stat-item--sub .degree-name{font-size:1rem;font-weight:600}.profile-degree-block{display:flex;flex-direction:column;gap:.5rem}.profile-degree-card{min-width:0}.profile-degree-card--clickable{cursor:pointer;border-radius:8px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.profile-degree-card--clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:#333}.profile-degree-card--clickable .degree-stat-item{border-color:transparent}.profile-degree-by-figure{display:flex;flex-direction:column;gap:.5rem;padding-left:1.25rem}.profile-cadence-block{display:flex;flex-direction:column;gap:.5rem}.composer-stats-list{display:flex;flex-direction:column;gap:.75rem}.composer-stat-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px}.composer-name{font-size:1rem;color:#fff;font-weight:600}.composer-count{font-size:.9rem;color:#b0b0b0}.difficulty-stats-list{display:flex;flex-direction:column;gap:.75rem}.difficulty-stat-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px}.difficulty-stat-name{font-size:1rem;color:#fff;font-weight:600}.difficulty-stat-count{font-size:.9rem;color:#b0b0b0}.profile-recent-exercises{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.profile-recent-exercise-item{margin:0}.profile-recent-exercise-link{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;color:inherit;text-decoration:none;transition:border-color .2s ease,background .2s ease}.profile-recent-exercise-link:hover{border-color:#667eea;background:#667eea1a}.profile-recent-exercise-title{font-size:.95rem;color:#fff;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-recent-exercise-subtitle{font-size:.8rem;color:#9ca3af;font-style:italic;font-weight:400}.profile-recent-exercise-status{font-size:.75rem;padding:.25rem .5rem;border-radius:6px;flex-shrink:0}.profile-recent-exercise-status--published{background:#22c55e33;color:#86efac}.profile-recent-exercise-status--draft{background:#eab30833;color:#fde047}.profile-teacher-edit-section{background:#667eea0f;border:1px solid rgba(102,126,234,.2);border-radius:12px;padding:1.5rem}.profile-teacher-edit-hint{margin:0 0 1.25rem;font-size:.9rem;color:#b0b0b0;line-height:1.4}.profile-teacher-edit-fields{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.profile-teacher-edit-field label{display:block;font-size:.95rem;font-weight:600;color:#e5e7eb;margin-bottom:.75rem}.profile-teacher-edit-loading{margin:0;font-size:.9rem;color:#9ca3af}.profile-teacher-select{width:100%;max-width:100%;padding:.6rem .75rem;font-size:.9375rem;color:#e5e7eb;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;margin-bottom:.75rem;cursor:pointer}.profile-teacher-select:hover,.profile-teacher-select:focus{border-color:#667eea;outline:none}.profile-teacher-chips{display:flex;flex-wrap:wrap;gap:.5rem}.profile-teacher-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .6rem;font-size:.875rem;background:#667eea33;border:1px solid rgba(102,126,234,.4);border-radius:8px;color:#e5e7eb}.profile-teacher-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;padding:0;margin:0;background:#ffffff26;border:none;border-radius:4px;color:#e5e7eb;font-size:1rem;line-height:1;cursor:pointer}.profile-teacher-chip-remove:hover{background:#ef444466;color:#fff}.profile-teacher-listed-toggle{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid rgba(102,126,234,.2)}.profile-teacher-checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem;font-weight:600;color:#e5e7eb}.profile-teacher-checkbox-label input{width:1.2rem;height:1.2rem;accent-color:#667eea;cursor:pointer}.profile-teacher-listed-hint{margin:.5rem 0 0 1.95rem;font-size:.85rem}.profile-pending-banner{margin-bottom:1rem}.profile-pending-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:#eab30826;border:1px solid rgba(234,179,8,.4);border-radius:12px}.profile-pending-banner-text{font-size:.95rem;font-weight:600;color:#fde047}.profile-pending-banner-btn{padding:.5rem 1rem;background:#eab3084d;border:1px solid rgba(234,179,8,.5);border-radius:8px;color:#fef08a;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s ease,border-color .2s ease}.profile-pending-banner-btn:hover{background:#eab30866;border-color:#fde047}.profile-quick-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.profile-quick-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;color:#e5e7eb;font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:border-color .2s ease,background .2s ease}.profile-quick-link:hover{border-color:#667eea;background:#667eea1a;color:#fff}.profile-quick-link:focus-visible{outline:2px solid #667eea;outline-offset:2px}.spinner{width:40px;height:40px;border:4px solid #3a3a3a;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@media(max-width:768px){.profile-modal-container{max-height:95vh}.profile-modal-header{padding:1rem 1.5rem}.profile-modal-content{padding:1.5rem}.profile-user-info{flex-direction:column;text-align:center}.stats-grid,.degree-stats-list,.cadence-stats-list,.profile-teacher-edit-fields{grid-template-columns:1fr}}.edit-tags-modal-backdrop{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:editTagsFadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes editTagsFadeIn{0%{opacity:0}to{opacity:1}}.edit-tags-modal-container{background:linear-gradient(135deg,#1e1e1e,#2a2a2a);border-radius:12px;border:2px solid #3a3a3a;box-shadow:0 20px 60px #000c;width:90%;max-width:480px;animation:editTagsSlideUp .3s ease-out}@keyframes editTagsSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.edit-tags-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #3a3a3a}.edit-tags-modal-header h2{margin:0;color:#fff;font-size:1.35rem;font-weight:700}.edit-tags-modal-close{background:transparent;border:none;color:#b0b0b0;font-size:2rem;cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1;padding:0}.edit-tags-modal-close:hover:not(:disabled){background:#333;color:#fff}.edit-tags-modal-close:disabled{opacity:.5;cursor:not-allowed}.edit-tags-modal-subtitle{margin:0;padding:.75rem 1.5rem 0;color:#888;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-tags-modal-form{padding:1.25rem 1.5rem 1.5rem}.edit-tags-modal-chips{display:flex;flex-wrap:wrap;gap:.5rem;min-height:2.5rem;margin-bottom:1rem}.edit-tags-modal-chip{display:inline-flex;align-items:center;gap:.25rem;background:#2a2a2a;border:1px solid #4a4a4a;border-radius:6px;padding:.4rem .5rem;font-size:.85rem;color:#e0e0e0}.edit-tags-modal-chip-remove{background:none;border:none;color:#888;cursor:pointer;padding:0 .15rem;font-size:1.1rem;line-height:1;border-radius:2px;transition:color .15s,background .15s}.edit-tags-modal-chip-remove:hover:not(:disabled){color:#fff;background:#555}.edit-tags-modal-chip-remove:disabled{opacity:.5;cursor:not-allowed}.edit-tags-modal-add{position:relative;display:flex;gap:.5rem;margin-bottom:1rem}.edit-tags-modal-input{flex:1;min-width:0;background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;font-family:inherit;transition:border-color .2s}.edit-tags-modal-input:focus{outline:none;border-color:#667eea}.edit-tags-modal-input:disabled{opacity:.5;cursor:not-allowed}.edit-tags-modal-input::-moz-placeholder{color:#666}.edit-tags-modal-input::placeholder{color:#666}.edit-tags-modal-add-btn{padding:.75rem 1rem;background:#3a3a3a;border:2px solid #4a4a4a;border-radius:8px;color:#e0e0e0;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.edit-tags-modal-add-btn:hover:not(:disabled){background:#4a4a4a;border-color:#667eea;color:#fff}.edit-tags-modal-add-btn:disabled{opacity:.5;cursor:not-allowed}.edit-tags-modal-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;max-height:180px;overflow-y:auto;z-index:10;display:flex;flex-direction:column}.edit-tags-modal-suggestion{padding:.5rem .75rem;text-align:left;background:none;border:none;color:#e0e0e0;font-size:.9rem;cursor:pointer;transition:background .15s}.edit-tags-modal-suggestion:hover{background:#333}.edit-tags-modal-error{padding:.5rem .75rem;background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:6px;color:#fca5a5;font-size:.85rem;margin-bottom:1rem}.edit-tags-modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}.edit-tags-modal-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.edit-tags-modal-btn:disabled{opacity:.5;cursor:not-allowed}.edit-tags-modal-btn.cancel{background:#3a3a3a;color:#b0b0b0;border:2px solid #4a4a4a}.edit-tags-modal-btn.cancel:hover:not(:disabled){background:#4a4a4a;color:#fff}.edit-tags-modal-btn.save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:2px solid #667eea}.edit-tags-modal-btn.save:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.assign-to-class-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.assign-to-class-modal-container{background:#fff;color:#111827;color-scheme:light;border-radius:12px;box-shadow:0 4px 20px #00000026;width:100%;max-width:420px;padding:1.5rem}.assign-to-class-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.assign-to-class-modal-header h2{margin:0;font-size:1.25rem;color:#111827}.assign-to-class-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;line-height:1}.assign-to-class-modal-close:hover{color:#111}.assign-to-class-modal-exercise{font-size:.9rem;color:#6b7280;margin:0 0 1.25rem}.assign-to-class-modal-form label{display:block;margin-bottom:1rem;font-size:.9rem;font-weight:500;color:#111827}.assign-to-class-modal-form label .required{color:#dc2626}.assign-to-class-modal-form select,.assign-to-class-modal-form input[type=text],.assign-to-class-modal-form input[type=date],.assign-to-class-modal-form textarea{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;background:#fff;color:#111827;border:1px solid #d1d5db;border-radius:6px;font-size:1rem}.assign-to-class-modal-form select option{background:#fff;color:#111827}.assign-to-class-modal-form input::-moz-placeholder,.assign-to-class-modal-form textarea::-moz-placeholder{color:#6b7280}.assign-to-class-modal-form input::placeholder,.assign-to-class-modal-form textarea::placeholder{color:#6b7280}.assign-to-class-modal-hint{font-size:.85rem;color:#6b7280;margin:-.5rem 0 .75rem}.assign-to-class-modal-existing{font-size:.85rem;color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;padding:.65rem .75rem;margin:-.35rem 0 .75rem}.assign-to-class-modal-existing p{margin:0}.assign-to-class-modal-existing-truncate{margin:.5rem 0 0!important;font-size:.8rem;color:#78350f}.assign-to-class-modal-error{color:#dc2626;font-size:.9rem;margin:0 0 .75rem}.assign-to-class-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.assign-to-class-modal-actions button{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer}.assign-to-class-modal-actions button[type=button]{background:transparent;border:1px solid #d1d5db;color:#374151}.assign-to-class-modal-actions button[type=submit]{background:#667eea;border:none;color:#fff}.assign-to-class-modal-actions button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.exercise-stats-overlay{position:fixed;inset:0;background:#0f172a8c;z-index:1500;display:flex;align-items:center;justify-content:center;padding:1rem}.exercise-stats-modal{position:relative;width:min(980px,100%);max-height:90vh;overflow:auto;background:#fff;color:#111827;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 24px 60px #0f172a47}.exercise-stats-close{position:absolute;top:.75rem;right:.75rem;border:none;background:#f3f4f6;color:#374151;border-radius:8px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.exercise-stats-close:hover{background:#e5e7eb}.exercise-stats-header{padding:1.25rem 1.25rem .75rem;border-bottom:1px solid #f3f4f6}.exercise-stats-title-row{display:flex;align-items:center;gap:.5rem;color:#1f2937}.exercise-stats-title-row h3{margin:0;font-size:1.125rem}.exercise-stats-subtitle{margin:.45rem 0 0;color:#6b7280;font-size:.95rem}.exercise-stats-loading{min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem}.exercise-stats-loading p{margin:0;color:#4b5563}.exercise-stats-spinner{width:34px;height:34px;border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:exercise-stats-spin .85s linear infinite}@keyframes exercise-stats-spin{to{transform:rotate(360deg)}}.exercise-stats-error{margin:1rem 1.25rem;padding:.75rem;border-radius:10px;background:#fee2e2;color:#991b1b}.exercise-stats-content{padding:1rem 1.25rem 1.25rem;display:grid;gap:1rem}.exercise-stats-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem}.exercise-stats-kpi{border:1px solid #e5e7eb;border-radius:12px;padding:.7rem .8rem;background:#fafafa}.exercise-stats-kpi-label{display:block;color:#6b7280;font-size:.78rem;margin-bottom:.25rem}.exercise-stats-kpi strong{color:#111827;font-size:1rem}.exercise-stats-sample-note{margin:0;color:#6b7280;font-size:.85rem}.exercise-stats-section h4{margin:0 0 .5rem;color:#111827;font-size:.97rem}.exercise-stats-errors-hint{margin:0 0 .65rem;font-size:.8rem;line-height:1.45;color:#6b7280}.exercise-stats-errors-hint em{font-style:normal;font-weight:600;color:#4b5563}.exercise-stats-chart{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;align-items:end;min-height:160px;border:1px solid #e5e7eb;border-radius:12px;background:linear-gradient(180deg,#f8fafc,#fff 70%);padding:.75rem}.exercise-stats-chart-col{border:none;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:0;color:#374151}.exercise-stats-chart-col:focus-visible{outline:2px solid #6366f1;outline-offset:2px;border-radius:8px}.exercise-stats-chart-bar-wrap{width:100%;height:110px;display:flex;align-items:flex-end;justify-content:center;background:repeating-linear-gradient(to top,rgba(148,163,184,.16),rgba(148,163,184,.16) 1px,transparent 1px,transparent 22px);border-radius:8px}.exercise-stats-chart-bar{width:min(64px,70%);border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#8b5cf6,#6366f1);transition:transform .15s ease,filter .15s ease}.exercise-stats-chart-col.is-active .exercise-stats-chart-bar,.exercise-stats-chart-col:hover .exercise-stats-chart-bar{transform:translateY(-2px);filter:brightness(1.05)}.exercise-stats-chart-label{font-size:.8rem;font-weight:600}.exercise-stats-chart-tooltip{margin:.55rem 0 0;font-size:.85rem;color:#4b5563}.exercise-stats-errors{list-style:none;margin:0;padding:0;display:grid;gap:.45rem}.exercise-stats-errors li{display:flex;justify-content:space-between;gap:.75rem;border:1px solid #e5e7eb;border-radius:10px;padding:.55rem .65rem;background:#fff}.exercise-stats-errors strong{color:#111827}.exercise-stats-errors li>span{color:#374151;font-weight:600;white-space:nowrap}.exercise-stats-errors p{margin:.2rem 0 0;color:#4b5563}.exercise-stats-empty{margin:0;color:#6b7280}.exercise-stats-table-wrap{overflow-x:auto}.exercise-stats-table{width:100%;border-collapse:collapse;font-size:.85rem}.exercise-stats-table th,.exercise-stats-table td{text-align:left;padding:.5rem;border-bottom:1px solid #f3f4f6}.exercise-stats-table th{color:#6b7280;font-weight:600}.dashboard-container{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;overflow-x:visible}.dashboard-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d}.dashboard-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0;letter-spacing:-.5px}.dashboard-header-right{position:relative;display:flex;align-items:center;gap:.75rem}.dashboard-header-student-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#667eea;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:8px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.dashboard-header-student-btn:hover{background:#667eea33;color:#5a67d8;border-color:#667eea80}.dashboard-user-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%;transition:transform .2s ease}.dashboard-user-avatar-btn:hover{transform:scale(1.05)}.dashboard-user-avatar{width:44px;height:44px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #e5e7eb;transition:border-color .2s ease}.dashboard-user-avatar-btn:hover .dashboard-user-avatar{border-color:#667eea}.dashboard-user-avatar-placeholder{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:600;border:2px solid #e5e7eb}.dashboard-user-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;min-width:220px;overflow:hidden;z-index:1001;animation:slideDown .2s ease-out}.dashboard-user-menu-header{padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.dashboard-user-menu-name{font-size:.9375rem;font-weight:600;color:#111827;margin-bottom:.25rem}.dashboard-user-menu-role{font-size:.8125rem;color:#6b7280;text-transform:capitalize}.dashboard-user-menu-divider{height:1px;background:#e5e7eb;margin:.5rem 0}.dashboard-user-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.9375rem;color:#374151;transition:background-color .2s ease}.dashboard-user-menu-item:hover{background:#f9fafb}.dashboard-user-menu-item svg{flex-shrink:0;color:#6b7280}.dashboard-user-menu-badge{margin-left:auto;background:#dc2626;color:#fff;font-size:.75rem;font-weight:600;min-width:1.25rem;height:1.25rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 .35rem}.dashboard-user-menu-item-danger{color:#dc2626}.dashboard-user-menu-item-danger:hover{background:#fef2f2}.dashboard-user-menu-item-danger svg{color:#dc2626}.dashboard-content{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.dashboard-loading p{color:#6b7280;font-size:.9375rem}.dashboard-empty{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.dashboard-empty-icon{font-size:4rem;margin-bottom:1rem}.dashboard-empty h2{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.dashboard-empty p{color:#6b7280;margin:0 0 2rem}.dashboard-signin-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea40}.dashboard-signin-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea59}.dashboard-signin-email-link{display:block;margin-top:1rem;background:none;border:none;color:#667eea;font-size:.9375rem;font-weight:500;cursor:pointer;padding:.5rem 0;font-family:inherit}.dashboard-signin-email-link:hover{text-decoration:underline}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;min-width:0}.dashboard-card{background:#fff;border-radius:14px;overflow:visible;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #00000014;border:1px solid #f3f4f6;display:flex;flex-direction:column;position:relative;min-width:0}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f;border-color:#e5e7eb}.dashboard-card:has(.dashboard-hover-tooltip){transform:none}.dashboard-card--menu-open{z-index:50}.dashboard-card-thumbnail{position:relative;width:100%;padding-top:50%;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden;flex-shrink:0;border-radius:14px 14px 0 0}.dashboard-card-index-badge{position:absolute;top:.5rem;left:.5rem;z-index:2;display:flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .35rem;border-radius:50%;font-size:.75rem;font-weight:700;color:#fff;background:#000000a6;box-shadow:0 1px 3px #00000040;pointer-events:none}.dashboard-card-homework-badge{position:absolute;bottom:.45rem;left:.45rem;z-index:2;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .45rem;border-radius:4px;color:#78350f;background:#fef3c7;border:1px solid #f59e0b;box-shadow:0 1px 3px #0003;pointer-events:none}.dashboard-card--homework-marked{box-shadow:0 0 0 2px #f59e0b8c}.dashboard-homework-filter-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:.35rem}.dashboard-homework-class-select{display:block;width:100%;margin-bottom:.5rem;padding:.45rem .6rem;font-size:.9rem;border:1px solid var(--border, #d1d5db);border-radius:8px;background:var(--bg, #fff);color:var(--text-primary, #111827)}.dashboard-homework-filter-hint{font-size:.78rem;color:var(--text-secondary, #6b7280);margin:0 0 .5rem}.dashboard-homework-filter-hint--warn{color:#92400e}.dashboard-homework-restrict-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;font-weight:400;color:var(--text-primary, #374151);cursor:pointer;margin:0}.dashboard-homework-restrict-label input{margin-top:.2rem;flex-shrink:0}.dashboard-card-thumbnail-img{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.dashboard-card-thumbnail-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3;background:linear-gradient(135deg,#667eea,#764ba2)}.dashboard-card-thumbnail-actions{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;gap:.35rem}.dashboard-card-preview-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:#00000073;color:#fffffff2;cursor:pointer;transition:background .2s ease,color .2s ease}.dashboard-card-preview-btn:hover{background:#0009;color:#fff}.dashboard-card-stats-btn{background:#4f46e5b3}.dashboard-card-stats-btn:hover{background:#4f46e5e0}.dashboard-card-preview-icon{flex-shrink:0}.dashboard-card-status-badge{padding:.25rem .5rem;border-radius:12px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #00000026}.dashboard-card-status-badge.published{background:#d1fae5f2;color:#065f46}.dashboard-card-status-badge.draft{background:#fef3c7f2;color:#92400e}.dashboard-card-body{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:0}.dashboard-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;position:relative}.dashboard-card-title{font-size:.9375rem;font-weight:700;color:#111827;margin:0;line-height:1.35;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-width:0}.dashboard-card-menu-btn{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:8px;color:#6b7280;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.dashboard-card-menu-btn:hover{background:#f3f4f6;color:#374151}.dashboard-card-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;min-width:160px;overflow:hidden;z-index:100;animation:slideDown .2s ease-out;border:1px solid #e5e7eb}.dashboard-card-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.9375rem;color:#374151;transition:background-color .2s ease}.dashboard-card-menu-item:hover:not(:disabled){background:#f9fafb}.dashboard-card-menu-item:disabled{opacity:.5;cursor:not-allowed}.dashboard-card-menu-item svg{flex-shrink:0;color:#6b7280}.dashboard-card-menu-item-danger{color:#dc2626}.dashboard-card-menu-item-danger:hover:not(:disabled){background:#fef2f2}.dashboard-card-menu-item-danger svg{color:#dc2626}.dashboard-card-subtitle{font-size:.75rem;color:#9ca3af;font-style:italic;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-card-composer{font-size:.8125rem;color:#6b7280;margin:0;font-weight:500}.dashboard-card-context-links{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;margin-top:-.25rem}.dashboard-card-context-book-row{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:.25rem}.dashboard-card-context-icon{flex-shrink:0;color:#6366f1;opacity:.9;display:inline-flex;align-items:center;justify-content:center}.dashboard-card-composer-link,.dashboard-card-context-link{background:none;border:none;padding:.15rem .35rem;margin:0 -.35rem;font-size:.8125rem;color:#6366f1;cursor:pointer;text-decoration:none;border-radius:4px;transition:color .15s ease,background-color .15s ease}.dashboard-card-composer-link:hover,.dashboard-card-composer-link:focus-visible,.dashboard-card-context-link:hover,.dashboard-card-context-link:focus-visible{color:#4f46e5;background-color:#6366f114;outline:none}.dashboard-card-author{font-size:.8125rem;color:#9ca3af;margin:.25rem 0 0;font-style:italic}.dashboard-filter-tabs{display:flex;gap:0;padding:0 1rem;background:#fff;border-bottom:1px solid #e5e7eb;min-width:0}.dashboard-filter-tab{padding:.75rem 1.25rem;font-size:.9375rem;font-weight:500;color:#6b7280;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:color .2s,border-color .2s}.dashboard-filter-tab:hover{color:#374151}.dashboard-filter-tab.active{color:#667eea;border-bottom-color:#667eea}.dashboard-filter-tabs-separator{width:1px;background:#e5e7eb;margin:.5rem .75rem;align-self:stretch}.dashboard-horizons-segmented{display:flex;align-items:center;margin:auto 0;border:1.5px solid #e5e7eb;border-radius:9999px;overflow:hidden;background:#f9fafb}.dashboard-horizons-seg{display:flex;align-items:center;gap:.3rem;padding:.4rem .75rem;font-size:.75rem;font-weight:500;color:#9ca3af;background:transparent;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;line-height:1;position:relative}.dashboard-horizons-seg+.dashboard-horizons-seg:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:#e5e7eb;transition:opacity .2s}.dashboard-horizons-seg:hover{color:#6366f1;background:#f5f3ff}.dashboard-horizons-seg.active{color:#fff;background:#6366f1;box-shadow:0 1px 4px #6366f140}.dashboard-horizons-seg.active+.dashboard-horizons-seg:before,.dashboard-horizons-seg:has(+.dashboard-horizons-seg.active):before{opacity:0}.dashboard-horizons-seg.active:before{opacity:0}.dashboard-horizons-seg.horizons.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 1px 6px #6366f14d}.dashboard-horizons-seg svg{flex-shrink:0;opacity:.6;transition:opacity .2s}.dashboard-horizons-seg:hover svg{opacity:.9}.dashboard-horizons-seg.active svg{opacity:1;stroke:#fff}.dashboard-live-draft-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 2rem;background:#eef2ff;border-bottom:1px solid #c7d2fe;color:#3730a3;font-size:.875rem}.dashboard-live-draft-bar button{border:1px solid #a5b4fc;background:#fff;color:#4338ca;border-radius:8px;padding:.35rem .65rem;font-weight:600;cursor:pointer}.dashboard-live-draft-toast{margin:.5rem 2rem 0;padding:.5rem .75rem;border-radius:8px;background:#e0e7ff;border:1px solid #c7d2fe;color:#3730a3;font-size:.875rem}.dashboard-search-row{display:flex;gap:1rem;align-items:center;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb}.dashboard-search-input-wrapper{flex:1;position:relative;display:flex;align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s}.dashboard-search-input-wrapper:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.dashboard-search-icon{color:#6b7280;margin-right:.75rem;flex-shrink:0}.dashboard-search-input{flex:1;background:transparent;border:none;outline:none;font-size:.9375rem;color:#111827;font-family:inherit}.dashboard-search-input::-moz-placeholder{color:#9ca3af}.dashboard-search-input::placeholder{color:#9ca3af}.dashboard-search-clear{background:none;border:none;color:#6b7280;cursor:pointer;padding:.25rem;margin-left:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s,color .2s}.dashboard-search-clear:hover{background:#e5e7eb;color:#374151}.dashboard-api-usage{margin:0 2rem 1rem;padding:1rem 1.25rem;background:#fff;border:1px solid #d1d5db;border-radius:12px;font-size:.9375rem;color:#111827}.dashboard-api-usage-loading,.dashboard-api-usage-unavailable{margin:0;color:#4b5563}.dashboard-api-usage-content{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.5rem;color:#111827}.dashboard-api-usage-row{display:flex;align-items:center;gap:.35rem;color:#111827}.dashboard-api-usage-row strong{color:#111827}.dashboard-api-usage-exercises{margin:0;color:#374151}.dashboard-api-usage-exercises strong{color:#111827}.dashboard-api-usage-refresh{padding:.4rem .9rem;font-size:.875rem;font-weight:500;color:#374151;background:#e5e7eb;border:1px solid #d1d5db;border-radius:8px;cursor:pointer}.dashboard-api-usage-refresh:hover:not(:disabled){background:#d1d5db;color:#111827;border-color:#9ca3af}.dashboard-api-usage-refresh:disabled{opacity:.6;cursor:not-allowed}.dashboard-filter-btn{display:none;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#374151;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.dashboard-filter-btn:hover{border-color:#667eea;background:#f9fafb}.dashboard-filter-badge{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.75rem;font-weight:700;padding:.125rem .375rem;border-radius:10px;min-width:18px;text-align:center}.dashboard-refresh-tags-btn{display:inline-flex}.dashboard-refresh-tags-btn:disabled{opacity:.8;cursor:wait}.dashboard-refresh-tags-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:dashboard-spin .8s linear infinite}@keyframes dashboard-spin{to{transform:rotate(360deg)}}.dashboard-refresh-tags-message{margin-top:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.875rem}.dashboard-refresh-tags-message--success{background:#d1fae5;color:#065f46}.dashboard-refresh-tags-message--error{background:#fee2e2;color:#991b1b}.dashboard-content-with-filters{display:grid;grid-template-columns:320px 1fr;gap:2rem;max-width:1600px;margin:0 auto;padding:2rem;align-items:start;min-width:0}.dashboard-filters{position:sticky;top:1rem;background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb;max-height:calc(100vh - 2rem);overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.dashboard-filters::-webkit-scrollbar{width:6px}.dashboard-filters::-webkit-scrollbar-track{background:transparent}.dashboard-filters::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dashboard-filters::-webkit-scrollbar-thumb:hover{background:#9ca3af}.dashboard-filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.dashboard-filters-header h3{font-size:1.125rem;font-weight:700;color:#111827;margin:0}.dashboard-filters-header-actions{display:flex;align-items:center;gap:.5rem}.dashboard-tag-match-segmented{display:flex;align-items:center;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#f9fafb}.dashboard-tag-match-seg{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;background:transparent;color:#6b7280;font-size:.72rem;font-weight:700;letter-spacing:.03em;line-height:1;padding:.3rem .55rem;cursor:pointer;transition:background .2s,color .2s}.dashboard-tag-match-seg+.dashboard-tag-match-seg{border-left:1px solid #e5e7eb}.dashboard-tag-match-seg:hover{background:#f3f4f6;color:#4b5563}.dashboard-tag-match-seg.active{background:#6366f1;color:#fff}.dashboard-clear-filters{background:none;border:none;color:#667eea;font-size:.875rem;font-weight:600;cursor:pointer;padding:.25rem .5rem;border-radius:8px;font-family:inherit}.dashboard-clear-filters:hover{background:#667eea1a}.dashboard-filter-block{margin-bottom:1.25rem}.dashboard-filter-block:last-child{margin-bottom:0}.dashboard-filter-block-title{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .5rem}.dashboard-statut-chips{display:flex;flex-wrap:wrap;gap:.5rem}.dashboard-statut-chip{padding:.5rem .75rem;font-size:.8125rem;font-weight:500;border:1px solid #e5e7eb;background:#fff;border-radius:10px;color:#6b7280;cursor:pointer;transition:all .2s;font-family:inherit}.dashboard-statut-chip:hover{border-color:#667eea;color:#667eea}.dashboard-statut-chip.active{background:#667eea26;border-color:#667eea;color:#667eea}.dashboard-chips-container{display:flex;flex-wrap:wrap;gap:.5rem}.dashboard-chip{padding:.5rem .75rem;font-size:.8125rem;font-weight:500;border:1px solid #e5e7eb;background:#fff;border-radius:10px;color:#6b7280;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.dashboard-chip:hover{border-color:#667eea;color:#667eea}.dashboard-chip.active{background:#667eea26;border-color:#667eea;color:#667eea}.dashboard-chip-load-more{border-style:dashed;color:#6b7280;font-style:italic}.dashboard-chip-load-more:hover{color:#667eea;border-color:#667eea}.dashboard-difficulty-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.dashboard-difficulty-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border:1px solid #e5e7eb;background:#fff;border-radius:10px;cursor:pointer;transition:all .2s;font-family:inherit}.dashboard-difficulty-card:hover{border-color:#667eea}.dashboard-difficulty-card.active{background:#667eea1f;border-color:#667eea}.dashboard-difficulty-icon{font-size:1.25rem}.dashboard-difficulty-label{font-size:.75rem;font-weight:500;color:#374151}.dashboard-filter-block-tags{margin-bottom:.75rem}.dashboard-filter-accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.875rem;font-weight:600;color:#374151;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;border-radius:8px;transition:background .2s}.dashboard-filter-accordion-header:hover{background:#f3f4f6}.dashboard-filter-accordion-icon{font-size:.75rem;color:#6b7280}.dashboard-filter-tag-checkboxes{padding-left:.5rem;margin-top:.25rem;margin-bottom:.5rem;display:flex;flex-direction:column;gap:.35rem;max-height:220px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.dashboard-filter-tag-checkboxes::-webkit-scrollbar{width:5px}.dashboard-filter-tag-checkboxes::-webkit-scrollbar-track{background:transparent}.dashboard-filter-tag-checkboxes::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dashboard-filter-tag-checkboxes::-webkit-scrollbar-thumb:hover{background:#9ca3af}.dashboard-filter-tag-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#374151;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.dashboard-filter-tag-checkbox input[type=checkbox]{width:1rem;height:1rem;accent-color:#667eea;flex-shrink:0}.dashboard-results{min-width:0;max-width:100%;overflow:visible}.dashboard-results-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.dashboard-results-count{font-size:.9375rem;color:#6b7280;margin:0}.dashboard-results-range{color:#9ca3af;font-weight:400}.dashboard-pagination{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;padding:.75rem 0}.dashboard-pagination-status{font-size:.875rem;color:#6b7280;min-width:7rem;text-align:center}.dashboard-pagination-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-family:inherit;transition:border-color .2s ease,color .2s ease,background .2s ease}.dashboard-pagination-btn:hover:not(:disabled){border-color:#667eea;color:#5a67d8;background:#667eea0f}.dashboard-pagination-btn:disabled{opacity:.45;cursor:not-allowed}.dashboard-sort{display:flex;align-items:center;gap:.5rem}.dashboard-sort-label{font-size:.875rem;color:#6b7280;font-weight:500;margin:0}.dashboard-sort-select{font-size:.875rem;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.375rem .75rem;cursor:pointer;min-width:10rem}.dashboard-sort-select:hover{border-color:#667eea}.dashboard-sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.dashboard-sort--drawer{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.dashboard-empty-cta{display:inline-block;padding:.75rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .2s,box-shadow .2s}.dashboard-empty-cta:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.dashboard-filter-drawer-overlay{position:fixed;inset:0;background:#0006;z-index:1100;animation:dashboard-fadeIn .2s ease-out}.dashboard-filter-drawer{position:fixed;top:0;right:0;width:min(320px,100vw);height:100vh;background:#fff;box-shadow:-4px 0 20px #00000026;z-index:1101;display:flex;flex-direction:column;animation:dashboard-slideIn .25s ease-out}.dashboard-filter-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.dashboard-filter-drawer-header h3{font-size:1.125rem;font-weight:700;color:#111827;margin:0}.dashboard-filter-drawer-close{background:none;border:none;padding:.5rem;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s,color .2s}.dashboard-filter-drawer-close:hover{background:#f3f4f6;color:#374151}.dashboard-filter-drawer-content{flex:1;overflow-y:auto;padding:1rem 1.25rem;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.dashboard-filter-drawer-content::-webkit-scrollbar{width:6px}.dashboard-filter-drawer-content::-webkit-scrollbar-track{background:transparent}.dashboard-filter-drawer-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dashboard-filter-drawer-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.dashboard-filter-drawer-footer{padding:1rem 1.25rem;border-top:1px solid #e5e7eb}@keyframes dashboard-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes dashboard-slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.dashboard-card-pills-zone{position:relative;margin-top:.25rem}.dashboard-card-pills-row{display:flex;align-items:center;gap:.375rem;flex-wrap:nowrap;min-width:0;max-width:100%}.dashboard-card-pill{padding:.25rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;line-height:1.3;border:1px solid transparent;transition:transform .15s ease}.dashboard-card-pill:hover{transform:translateY(-1px)}.dashboard-card-pill-clickable{cursor:pointer}.dashboard-card-pill-clickable:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.dashboard-card-pill.active{box-shadow:inset 0 0 0 2px #4f46e559}.dashboard-card-pill--more{flex-shrink:0;padding:.3125rem .625rem;font-size:.6875rem;color:#4f46e5;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1px solid rgba(99,102,241,.25)}.dashboard-card-pill--difficulty{text-transform:capitalize}.dashboard-card-pill--difficulty.facile{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#10b9814d}.dashboard-card-pill--difficulty.intermédiaire{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#f59e0b4d}.dashboard-card-pill--difficulty.difficile{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#9a3412;border-color:#ea580c4d}.dashboard-card-pill--difficulty.expert{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#991b1b;border-color:#ef44444d}.dashboard-card-pill--notion[data-notion=cadences]{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3;border-color:#6366f140}.dashboard-card-pill--notion[data-notion=renversements]{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#5b21b6;border-color:#8b5cf640}.dashboard-card-pill--notion[data-notion="7e"],.dashboard-card-pill--notion[data-notion=accords-de-7e]{background:linear-gradient(135deg,#ccfbf1,#99f6e4);color:#0f766e;border-color:#14b8a640}.dashboard-card-pill--notion[data-notion=couleurs]{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#9a3412;border-color:#ea580c40}.dashboard-card-pill--notion[data-notion=structure]{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#334155;border-color:#64748b40}.dashboard-card-pill--notion[data-notion=baroque],.dashboard-card-pill--notion[data-notion=classique],.dashboard-card-pill--notion[data-notion=romantique],.dashboard-card-pill--notion[data-notion=moderne]{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#9d174d;border-color:#be185d40}.dashboard-card-pill--notion:not([data-notion=cadences]):not([data-notion=renversements]):not([data-notion="7e"]):not([data-notion=accords-de-7e]):not([data-notion=couleurs]):not([data-notion=structure]):not([data-notion=baroque]):not([data-notion=classique]):not([data-notion=romantique]):not([data-notion=moderne]){background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border-color:#94a3b84d}.dashboard-hover-tooltip{position:absolute;left:0;bottom:100%;padding-bottom:.375rem;min-width:220px;max-width:300px;z-index:1000;pointer-events:auto}.dashboard-hover-tooltip-inner{background:#1e293bfa;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f1f5f9;border-radius:12px;box-shadow:0 10px 40px #00000040,0 0 0 1px #ffffff0f;overflow:hidden}.dashboard-hover-tooltip-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.1)}.dashboard-hover-tooltip-status{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.2rem .5rem;border-radius:6px}.dashboard-hover-tooltip-status.published{background:#10b98140;color:#6ee7b7}.dashboard-hover-tooltip-status.draft{background:#f59e0b40;color:#fcd34d}.dashboard-hover-tooltip-date{font-size:.6875rem;color:#94a3b8}.dashboard-hover-tooltip-meta{display:flex;flex-direction:column;gap:.2rem;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.1);font-size:.75rem;color:#cbd5e1}.dashboard-hover-tooltip-subtitle{font-style:italic;color:#94a3b8}.dashboard-hover-tooltip-markers{font-weight:500}.dashboard-hover-tooltip-pills{display:flex;flex-wrap:wrap;gap:.375rem;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.1)}.dashboard-hover-tooltip-pills .dashboard-card-pill--difficulty{font-size:.6875rem}.dashboard-hover-tooltip-pills .dashboard-card-pill--difficulty.facile{background:#10b9814d;color:#a7f3d0;border-color:#10b98133}.dashboard-hover-tooltip-pills .dashboard-card-pill--difficulty.intermédiaire{background:#f59e0b4d;color:#fde68a;border-color:#f59e0b33}.dashboard-hover-tooltip-pills .dashboard-card-pill--difficulty.difficile{background:#ea580c4d;color:#fed7aa;border-color:#ea580c33}.dashboard-hover-tooltip-pills .dashboard-card-pill--difficulty.expert{background:#ef44444d;color:#fecaca;border-color:#ef444433}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=cadences]{background:#6366f159;color:#e0e7ff;border-color:#ffffff26}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=renversements]{background:#8b5cf659;color:#ede9fe;border-color:#ffffff26}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion="7e"],.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=accords-de-7e]{background:#14b8a659;color:#ccfbf1;border-color:#ffffff26}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=couleurs]{background:#ea580c59;color:#ffedd5;border-color:#ffffff26}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=structure]{background:#64748b59;color:#e2e8f0;border-color:#ffffff26}.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=baroque],.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=classique],.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=romantique],.dashboard-hover-tooltip-pills .dashboard-card-pill--notion[data-notion=moderne]{background:#be185d59;color:#fce7f3;border-color:#ffffff26}.dashboard-hover-tooltip-tags{padding:.5rem .75rem}.dashboard-hover-tooltip-tags-label{display:block;font-size:.6875rem;font-weight:600;color:#94a3b8;margin-bottom:.375rem;text-transform:uppercase;letter-spacing:.3px}.dashboard-hover-tooltip-tags-list{display:flex;flex-wrap:wrap;gap:.3rem;max-height:120px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.dashboard-hover-tooltip-tags-list::-webkit-scrollbar{display:none}.dashboard-hover-tooltip-tag{-moz-appearance:none;appearance:none;-webkit-appearance:none;font-family:inherit;line-height:1.2;cursor:pointer;padding:.2rem .5rem;background:#ffffff1a;color:#e2e8f0;border-radius:6px;font-size:.625rem;font-weight:500;white-space:nowrap;border:1px solid rgba(255,255,255,.08)}.dashboard-hover-tooltip-tag:hover{background:#ffffff2e}.dashboard-hover-tooltip-tag.active{background:#6366f159;border-color:#a5b4fc8c;color:#eef2ff}.dashboard-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;margin-top:auto;min-width:0;border-top:1px solid #f3f4f6}.dashboard-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.dashboard-card-meta-item{font-size:.8125rem;color:#6b7280;font-weight:500}.dashboard-card-date{font-size:.8125rem;color:#9ca3af;font-weight:500}.dashboard-fab{position:fixed;bottom:2rem;right:2rem;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #667eea66;transition:all .3s ease;z-index:999}.dashboard-fab:hover{transform:scale(1.1);box-shadow:0 12px 32px #667eea80}.dashboard-fab:active{transform:scale(.95)}.dashboard-fab svg{stroke:#fff}@media(max-width:1024px){.dashboard-content-with-filters{grid-template-columns:280px 1fr;gap:1.5rem;padding:1.5rem}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.dashboard-content{padding:1.5rem}}@media(max-width:768px){.dashboard-header{padding:1rem;min-width:0}.dashboard-title{font-size:1.25rem}.dashboard-search-row{padding:1rem;flex-wrap:wrap;min-width:0}.dashboard-live-draft-bar{padding:.65rem 1rem;flex-wrap:wrap}.dashboard-live-draft-toast{margin-left:1rem;margin-right:1rem}.dashboard-search-input-wrapper{min-width:0}.dashboard-filter-btn{display:flex}.dashboard-content-with-filters{grid-template-columns:1fr;padding:1rem;min-width:0}.dashboard-filters{display:none}.dashboard-difficulty-cards{grid-template-columns:repeat(4,1fr)}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;min-width:0}.dashboard-card{min-width:0;max-width:100%}.dashboard-content{padding:1rem}.dashboard-fab{bottom:1.5rem;right:1.5rem;width:56px;height:56px}.dashboard-fab svg{width:20px;height:20px}}@media(max-width:560px){.dashboard-grid{grid-template-columns:1fr}}@media(max-width:480px){.dashboard-header{padding:.875rem .75rem}.dashboard-title{font-size:1.125rem}.dashboard-filter-tabs{padding:0 .75rem;flex-wrap:wrap}.dashboard-filter-tabs-separator{display:none}.dashboard-horizons-segmented{margin:.375rem 0}.dashboard-horizons-seg{font-size:.6875rem;padding:.3rem .5rem}.dashboard-tag-match-seg{font-size:.68rem;padding:.28rem .46rem}.dashboard-search-row{padding:.75rem}.dashboard-live-draft-bar{padding:.65rem .75rem}.dashboard-live-draft-toast{margin-left:.75rem;margin-right:.75rem}.dashboard-content-with-filters{padding:.75rem}.dashboard-user-avatar,.dashboard-user-avatar-placeholder{width:40px;height:40px}.dashboard-fab{bottom:1rem;right:1rem;width:52px;height:52px}}.exercise-card{--exercise-card-bg: #ffffff;background:var(--exercise-card-bg);border-radius:20px;overflow:visible;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #00000014;border:1px solid #f3f4f6;display:flex;flex-direction:column;position:relative;min-width:0}.exercise-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f;border-color:#e5e7eb}.exercise-card:focus-visible{outline:2px solid #667eea;outline-offset:2px}.exercise-card-badge-top{position:absolute;top:.5rem;right:.5rem;z-index:2;padding:.25rem .5rem;border-radius:8px;font-size:.6875rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;box-shadow:0 1px 3px #0000001f;pointer-events:none}.exercise-card-badge-top--done{background:#d1fae5;color:#059669;border:1px solid rgba(5,150,105,.35)}.exercise-card-thumbnail{position:relative;width:100%;padding-top:56.25%;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}.exercise-card-index-badge{position:absolute;top:.5rem;left:.5rem;z-index:2;display:flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .35rem;border-radius:50%;font-size:.75rem;font-weight:700;color:#fff;background:#000000a6;box-shadow:0 1px 3px #00000040;pointer-events:none}.exercise-card-thumbnail-img{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.exercise-card-thumbnail-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3;background:linear-gradient(135deg,#667eea,#764ba2)}.exercise-card-body{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;flex:1;min-width:0}.exercise-card-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0;line-height:1.4;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.exercise-card-subtitle{font-size:.8125rem;color:#9ca3af;font-style:italic;margin:0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.exercise-card-composer{font-size:.875rem;color:#6b7280;margin:0;font-weight:500}.exercise-card-composer--link{background:none;border:none;padding:.15rem .35rem;margin:0 -.35rem;font:inherit;color:#6366f1;cursor:pointer;text-align:left;text-decoration:none;border-radius:4px;transition:color .15s ease,background-color .15s ease,text-decoration-color .15s ease}.exercise-card-composer--link:hover,.exercise-card-composer--link:focus-visible{color:#4f46e5;background-color:#6366f114;outline:none}.exercise-card-context-links{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;margin-top:-.25rem}.exercise-card-context-book-row{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:.25rem}.exercise-card-context-icon{flex-shrink:0;color:#6366f1;opacity:.9;display:inline-flex;align-items:center;justify-content:center}.exercise-card-context-link{background:none;border:none;padding:.15rem .35rem;margin:0 -.35rem;font-size:.75rem;color:#6366f1;cursor:pointer;text-decoration:none;border-radius:4px;transition:color .15s ease,background-color .15s ease,text-decoration-color .15s ease}.exercise-card-context-link:hover,.exercise-card-context-link:focus-visible{color:#4f46e5;background-color:#6366f114;outline:none}.exercise-card-footer{display:flex;align-items:center;padding-top:.75rem;margin-top:auto;border-top:1px solid #f3f4f6;min-width:0}.exercise-card-pills-wrapper{position:relative;display:flex;align-items:center;width:100%;min-width:0}.exercise-card-pills{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.exercise-card-pills--visible{flex-wrap:nowrap;min-width:0;max-width:100%;flex-shrink:1}.exercise-card-pill--more{flex-shrink:0;padding:.3125rem .625rem;border-radius:10px;font-size:.6875rem;font-weight:600;color:#4f46e5;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1px solid rgba(99,102,241,.25);margin-left:.125rem}.exercise-card-pills--scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;width:100%;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch}.exercise-card-pills--scroll::-webkit-scrollbar{display:none}.exercise-card-pill--notion{padding:.3125rem .625rem;border-radius:10px;font-size:.6875rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;line-height:1.3;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease}.exercise-card-pill--notion:hover{transform:translateY(-1px)}.exercise-card-pill-clickable{cursor:pointer}.exercise-card-pill-clickable:hover{filter:brightness(1.05)}.exercise-card-pill--notion[data-notion=cadences]{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3;border-color:#6366f140}.exercise-card-pill--notion[data-notion=renversements]{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#5b21b6;border-color:#8b5cf640}.exercise-card-pill--notion[data-notion="7e"],.exercise-card-pill--notion[data-notion=accords-de-7e]{background:linear-gradient(135deg,#ccfbf1,#99f6e4);color:#0f766e;border-color:#14b8a640}.exercise-card-pill--notion[data-notion=couleurs]{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#9a3412;border-color:#ea580c40}.exercise-card-pill--notion[data-notion=structure]{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#334155;border-color:#64748b40}.exercise-card-pill--notion[data-notion=baroque],.exercise-card-pill--notion[data-notion=classique],.exercise-card-pill--notion[data-notion=romantique],.exercise-card-pill--notion[data-notion=moderne]{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#9d174d;border-color:#be185d40}.exercise-card-pill--notion[data-notion=majeur]{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border-color:#3b82f640}.exercise-card-pill--notion[data-notion=mineur]{background:linear-gradient(135deg,#e9d5ff,#ddd6fe);color:#5b21b6;border-color:#8b5cf640}.exercise-card-pill--notion:not([data-notion=cadences]):not([data-notion=renversements]):not([data-notion="7e"]):not([data-notion=accords-de-7e]):not([data-notion=couleurs]):not([data-notion=structure]):not([data-notion=baroque]):not([data-notion=classique]):not([data-notion=romantique]):not([data-notion=moderne]):not([data-notion=majeur]):not([data-notion=mineur]){background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border-color:#94a3b84d}.exercise-card-pills-tooltip{position:absolute;left:0;bottom:100%;margin-bottom:.375rem;padding:.5rem .75rem;background:#1e293bfa;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f1f5f9;border-radius:12px;box-shadow:0 10px 40px #0003,0 0 0 1px #ffffff0f;display:flex;flex-wrap:wrap;gap:.375rem;max-width:280px;z-index:10;pointer-events:auto}.exercise-card-pills-tooltip .exercise-card-difficulty{flex-shrink:0}.exercise-card-pills-tooltip .exercise-card-pill--notion{font-size:.6875rem;border-color:#ffffff26}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=cadences]{background:#6366f159;color:#e0e7ff}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=renversements]{background:#8b5cf659;color:#ede9fe}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion="7e"],.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=accords-de-7e]{background:#14b8a659;color:#ccfbf1}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=couleurs]{background:#ea580c59;color:#ffedd5}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=structure]{background:#64748b59;color:#e2e8f0}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=baroque],.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=classique],.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=romantique],.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=moderne]{background:#be185d59;color:#fce7f3}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=majeur]{background:#3b82f659;color:#dbeafe}.exercise-card-pills-tooltip .exercise-card-pill--notion[data-notion=mineur]{background:#8b5cf659;color:#ede9fe}.exercise-card-difficulty{padding:.3125rem .625rem;border-radius:10px;font-size:.75rem;font-weight:600;letter-spacing:.02em;text-transform:capitalize;border:1px solid transparent;box-shadow:0 1px 2px #0000000a;transition:transform .15s ease,box-shadow .15s ease}.exercise-card-difficulty:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000000f}.exercise-card-difficulty.facile{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#10b9814d}.exercise-card-difficulty.intermédiaire{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#f59e0b4d}.exercise-card-difficulty.difficile{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#9a3412;border-color:#ea580c4d}.exercise-card-difficulty.expert{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#991b1b;border-color:#ef44444d}.exercise-card--mini .exercise-card-body{padding:.75rem;gap:.5rem}.exercise-card--mini .exercise-card-title{font-size:1rem;-webkit-line-clamp:2}.exercise-card--mini .exercise-card-subtitle{font-size:.75rem}.exercise-card--mini .exercise-card-composer{font-size:.8125rem}.exercise-card--mini .exercise-card-footer{padding-top:.5rem;min-width:0}.exercise-card--mini .exercise-card-pills--scroll,.exercise-card--mini .exercise-card-pills-wrapper{min-width:0}.exercise-card--mini .exercise-card-pills--visible{min-width:0;width:100%;max-width:100%;flex-shrink:1}.exercise-card--mini .exercise-card-pill--notion,.exercise-card--mini .exercise-card-difficulty,.exercise-card--mini .exercise-card-pill--recommended{padding:.25rem .5rem;font-size:.625rem}.exercise-card-pill--recommended{padding:.3125rem .625rem;border-radius:10px;font-size:.6875rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;line-height:1.3;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid rgba(255,255,255,.2)}.exercise-card-pill--recommended-priority{background:linear-gradient(135deg,#059669,#047857);color:#fff;border-color:#fff3}.free-mode-container{width:100%;max-width:1400px;margin:0 auto;padding:1.5rem 1.25rem}.free-mode-search-bar{margin-bottom:2rem;display:flex;gap:1rem;align-items:center}.free-mode-search-input-wrapper{flex:1;position:relative;display:flex;align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:.875rem 1.25rem;transition:all .2s ease}.free-mode-search-input-wrapper:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.free-mode-search-icon{color:#6b7280;margin-right:.75rem;flex-shrink:0}.free-mode-search-input{flex:1;background:transparent;border:none;outline:none;color:#111827;font-size:1rem;font-weight:400;font-family:inherit}.free-mode-search-input::-moz-placeholder{color:#9ca3af}.free-mode-search-input::placeholder{color:#9ca3af}.free-mode-search-clear{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:.25rem;margin-left:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;flex-shrink:0}.free-mode-search-clear:hover{background:#f3f4f6;color:#374151}.free-mode-filter-btn{display:none;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:16px;color:#374151;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.free-mode-filter-btn:hover{border-color:#667eea;background:#f9fafb}.free-mode-filter-badge{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.75rem;font-weight:700;padding:.125rem .375rem;border-radius:10px;min-width:20px;text-align:center}.free-mode-horizons-segmented{display:flex;align-items:center;border:1.5px solid #e5e7eb;border-radius:9999px;overflow:hidden;background:#f9fafb;flex-shrink:0}.free-mode-horizons-seg{display:flex;align-items:center;gap:.3rem;padding:.4rem .75rem;font-size:.75rem;font-weight:500;color:#9ca3af;background:transparent;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;line-height:1;position:relative}.free-mode-horizons-seg+.free-mode-horizons-seg:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:#e5e7eb;transition:opacity .2s}.free-mode-horizons-seg:hover{color:#6366f1;background:#f5f3ff}.free-mode-horizons-seg.active{color:#fff;background:#6366f1;box-shadow:0 1px 4px #6366f140}.free-mode-horizons-seg.active+.free-mode-horizons-seg:before,.free-mode-horizons-seg:has(+.free-mode-horizons-seg.active):before{opacity:0}.free-mode-horizons-seg.active:before{opacity:0}.free-mode-horizons-seg.horizons.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 1px 6px #6366f14d}.free-mode-horizons-seg svg{flex-shrink:0;opacity:.6;transition:opacity .2s}.free-mode-horizons-seg:hover svg{opacity:.9}.free-mode-horizons-seg.active svg{opacity:1;stroke:#fff}.free-mode-input-mode-control{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;flex-shrink:0}.free-mode-input-mode-label-row{display:flex;align-items:center;gap:.35rem}.free-mode-input-mode-label{font-size:.72rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.free-mode-input-mode-segmented{display:flex;align-items:center;border:1.5px solid #e5e7eb;border-radius:9999px;overflow:hidden;background:#f9fafb;flex-shrink:0}.free-mode-input-mode-seg{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.4rem .75rem;font-size:.75rem;font-weight:600;color:#6b7280;background:transparent;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;line-height:1;position:relative}.free-mode-input-mode-seg+.free-mode-input-mode-seg:before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:#e5e7eb;transition:opacity .2s}.free-mode-input-mode-seg:hover{color:#6366f1;background:#f5f3ff}.free-mode-input-mode-seg.active{color:#fff;background:#6366f1;box-shadow:0 1px 4px #6366f140}.free-mode-input-mode-seg.active+.free-mode-input-mode-seg:before,.free-mode-input-mode-seg:has(+.free-mode-input-mode-seg.active):before{opacity:0}.free-mode-input-mode-seg.active:before{opacity:0}.free-mode-content{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}@media(min-width:1400px){.free-mode-content{grid-template-columns:380px 1fr;max-width:1600px;margin:0 auto}}.free-mode-filters{width:350px;flex-shrink:0;background:#fff;border-radius:20px;padding:0;box-shadow:0 2px 8px #00000014;border:1px solid #f3f4f6;height:calc(100vh - 2rem);max-height:calc(100vh - 2rem);position:sticky;top:1rem;overflow:hidden;display:flex;flex-direction:column}.free-mode-filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #e5e7eb;position:relative;z-index:2;background:#fff}.free-mode-filters-header h3{font-size:1.125rem;font-weight:700;color:#111827;margin:0}.free-mode-clear-filters{background:none;border:none;color:#667eea;font-size:.875rem;font-weight:600;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:background-color .2s ease}.free-mode-clear-filters:hover{background:#f3f4f6}.free-mode-filters-scroll-content{flex:1;overflow-y:auto;overscroll-behavior-y:auto;padding:1rem 1.5rem;scrollbar-width:thin;scrollbar-color:#cfd6e6 transparent}.free-mode-filters-scroll-content::-webkit-scrollbar{width:8px}.free-mode-filters-scroll-content::-webkit-scrollbar-track{background:transparent}.free-mode-filters-scroll-content::-webkit-scrollbar-thumb{background:#cfd6e6;border-radius:999px;border:2px solid transparent;background-clip:content-box}.free-mode-filters-scroll-content:hover::-webkit-scrollbar-thumb{background:#b8c2d9;background-clip:content-box}.free-mode-filters-footer{position:relative;z-index:2;background:#fff;border-top:1px solid #e5e7eb;padding:.875rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem}.free-mode-filters-footer-count{font-size:.8125rem;color:#6b7280;font-weight:600}.free-mode-filter-block{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.free-mode-filter-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.free-mode-filter-block-title{font-size:.8125rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}.free-mode-filter-block-quick .free-mode-filter-block-title{color:#667eea}.free-mode-accordion{margin-bottom:.9rem;border:1px solid #eceff4;border-radius:14px;background:#fff;box-shadow:0 1px 2px #0f172a0a;transition:border-color .2s ease,box-shadow .2s ease}.free-mode-accordion.free-mode-filter-block{margin-bottom:.9rem;padding-bottom:0;border-bottom:none}.free-mode-accordion[open]{border-color:#e3e8f2;box-shadow:0 4px 14px #0f172a0f}.free-mode-accordion-summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.9rem 1rem}.free-mode-accordion-summary::-webkit-details-marker{display:none}.free-mode-accordion-summary .free-mode-filter-block-title{margin:0}.free-mode-accordion-chevron{width:.55rem;height:.55rem;border-right:2px solid #9aa3b2;border-bottom:2px solid #9aa3b2;transform:rotate(45deg);transition:transform .2s ease,border-color .2s ease;flex-shrink:0}.free-mode-accordion[open] .free-mode-accordion-chevron{transform:rotate(225deg);border-color:#6366f1}.free-mode-accordion-content{padding:.15rem 1rem 1rem}.free-mode-notion-chips{display:flex;flex-wrap:wrap;gap:.5rem}.free-mode-notion-chip{padding:.5rem .875rem;background:#f3f4f6;border:2px solid transparent;border-radius:14px;font-size:.8125rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap}.free-mode-notion-chip:hover{background:#e5e7eb;border-color:#d1d5db}.free-mode-notion-chip-active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.free-mode-filter-block-statut{margin-bottom:1.25rem}.free-mode-statut-chips{display:flex;flex-wrap:wrap;gap:.5rem}.free-mode-statut-chip{padding:.5rem .875rem;background:#f3f4f6;border:2px solid transparent;border-radius:14px;font-size:.8125rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease}.free-mode-statut-chip:hover{background:#e5e7eb;border-color:#d1d5db}.free-mode-statut-chip-active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.free-mode-filter-group{margin-bottom:2rem}.free-mode-filter-group:last-child{margin-bottom:0}.free-mode-filter-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.free-mode-filter-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.free-mode-filter-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.free-mode-filter-section-title{font-size:.8125rem;font-weight:700;color:#111827;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.free-mode-filter-subsection{margin-bottom:1rem}.free-mode-filter-subsection:last-child{margin-bottom:0}.free-mode-filter-subsection-label{display:block;font-size:.8125rem;font-weight:600;color:#6b7280;margin-bottom:.5rem}.free-mode-chips-container{display:flex;flex-wrap:wrap;gap:.5rem;overflow-x:hidden!important;overflow-y:visible}.free-mode-chip{padding:.625rem 1rem;background:#f3f4f6;border:2px solid transparent;border-radius:20px;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap}.free-mode-chip:hover{background:#e5e7eb}.free-mode-chip-active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.free-mode-chip-load-more,.free-mode-tag-chip-load-more{border-style:dashed;color:#6b7280;font-style:italic}.free-mode-chip-load-more:hover,.free-mode-tag-chip-load-more:hover{color:#667eea;border-color:#667eea}.free-mode-difficulty-cards{display:flex;flex-wrap:wrap;gap:.75rem}.free-mode-difficulty-card{flex:1 1 calc(50% - .375rem);min-width:0;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;cursor:pointer;transition:all .2s ease}.free-mode-difficulty-card:hover{border-color:#d1d5db;transform:translateY(-2px)}.free-mode-difficulty-card-active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.free-mode-difficulty-icon{font-size:1.5rem}.free-mode-difficulty-label{font-size:.75rem;font-weight:600;color:#374151;text-transform:capitalize}.free-mode-difficulty-card-active .free-mode-difficulty-label{color:#667eea}.free-mode-tags-container{display:flex;flex-wrap:wrap;gap:.5rem;max-height:none;overflow:visible!important;scrollbar-width:none!important;-ms-overflow-style:none!important;padding-right:0}.free-mode-tags-container::-webkit-scrollbar{display:none!important;width:0!important;height:0!important;background:transparent!important}.free-mode-tags-container::-webkit-scrollbar-track{display:none!important;background:transparent!important}.free-mode-tags-container::-webkit-scrollbar-thumb{display:none!important;background:transparent!important}.free-mode-tag-chip{padding:.5rem .75rem;background:#f3f4f6;border:2px solid transparent;border-radius:16px;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:normal;word-break:break-word;line-height:1.4}.free-mode-tag-chip:hover{background:#e5e7eb}.free-mode-tag-chip-active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.free-mode-tags-more{font-size:.75rem;color:#6b7280;margin:0;width:100%;text-align:center;padding:.5rem}.free-mode-results{flex:1;min-width:0;overflow-x:hidden;padding-right:1.25rem}.free-mode-applied-filters{margin-bottom:1rem;padding:.875rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:14px}.free-mode-applied-filters-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.625rem}.free-mode-applied-filters-header p{margin:0;font-size:.875rem;color:#374151;font-weight:600}.free-mode-applied-filters-clear{border:none;background:transparent;color:#6366f1;font-size:.8125rem;font-weight:600;padding:.25rem .5rem;border-radius:8px;cursor:pointer}.free-mode-applied-filters-clear:hover{background:#eef2ff}.free-mode-applied-filters-list{display:flex;flex-wrap:wrap;gap:.5rem}.free-mode-applied-filter-chip{border:1px solid #dbe2ff;background:#f8faff;color:#374151;border-radius:9999px;padding:.4rem .65rem;display:inline-flex;align-items:center;gap:.45rem;cursor:pointer;font-size:.8125rem;line-height:1}.free-mode-applied-filter-chip:hover{background:#eef2ff}.free-mode-results-header{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem}.free-mode-results-count{font-size:.9375rem;color:#6b7280;margin:0;font-weight:500}.free-mode-sort{display:flex;align-items:center;gap:.5rem}.free-mode-sort-label{font-size:.875rem;color:#6b7280;font-weight:500;margin:0}.free-mode-sort-select{font-size:.875rem;color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.375rem .75rem;cursor:pointer;min-width:10rem}.free-mode-sort-select:hover{border-color:#667eea}.free-mode-sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.free-mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.free-mode-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.free-mode-loading .spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.free-mode-loading p{color:#6b7280;font-size:.9375rem}.free-mode-empty{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.free-mode-empty-icon{font-size:4rem;margin-bottom:1rem}.free-mode-empty-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.free-mode-empty-text{color:#6b7280;margin:0 0 1.5rem;line-height:1.6}.free-mode-empty-cta{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.free-mode-empty-cta:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.free-mode-empty-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.free-mode-empty-cta-secondary{background:#eef2ff;color:#374151;box-shadow:none}.free-mode-empty-cta-secondary:hover{box-shadow:none;background:#e0e7ff}.free-mode-filter-btn:focus-visible,.free-mode-clear-filters:focus-visible,.free-mode-statut-chip:focus-visible,.free-mode-notion-chip:focus-visible,.free-mode-chip:focus-visible,.free-mode-tag-chip:focus-visible,.free-mode-difficulty-card:focus-visible,.free-mode-accordion-summary:focus-visible,.free-mode-applied-filters-clear:focus-visible,.free-mode-applied-filter-chip:focus-visible,.free-mode-empty-cta:focus-visible,.free-mode-filter-drawer-close:focus-visible,.free-mode-filter-drawer-apply:focus-visible{outline:2px solid #667eea;outline-offset:2px}.free-mode-filter-drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-out}.free-mode-filter-drawer{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:400px;background:#fff;z-index:1001;display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000026;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.free-mode-filter-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.free-mode-filter-drawer-header h3{font-size:1.25rem;font-weight:700;color:#111827;margin:0}.free-mode-filter-drawer-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.free-mode-filter-drawer-close:hover{background:#f3f4f6;color:#374151}.free-mode-filter-drawer-content{flex:1;overflow-y:auto;padding:1.5rem}.free-mode-filter-drawer-footer{padding:1.5rem;border-top:1px solid #e5e7eb}.free-mode-filter-drawer-apply{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.free-mode-filter-drawer-apply:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}@media(max-width:767px){.free-mode-container{padding:1rem;max-width:100%}.free-mode-search-bar{flex-direction:column;gap:.75rem;min-width:0}.free-mode-filter-btn{display:flex;width:100%;justify-content:center}.free-mode-horizons-segmented,.free-mode-input-mode-segmented{width:100%;justify-content:center}.free-mode-input-mode-control{width:100%;align-items:stretch}.free-mode-horizons-seg,.free-mode-input-mode-seg{flex:1;justify-content:center;font-size:.6875rem;padding:.35rem .5rem}.free-mode-content{display:flex;flex-direction:column;gap:0;min-width:0;max-width:100%}.free-mode-filters{display:none}.free-mode-results{max-width:100%;min-width:0}.free-mode-latest-grid,.free-mode-grid{min-width:0}.free-mode-grid{grid-template-columns:1fr;gap:1rem}.free-mode-latest-grid{grid-template-columns:minmax(0,1fr)}.free-mode-grid .exercise-card,.free-mode-latest-grid .exercise-card{min-width:0}.free-mode-results-header{margin-bottom:1rem}}@media(min-width:768px){.free-mode-container{padding:2rem 1.5rem}.free-mode-difficulty-cards{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px){.free-mode-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.campaign-map{padding:0 0 1.5rem;max-width:100%;margin:0 auto;background:transparent;border-radius:0;min-height:0}.campaign-map-loading{display:flex;justify-content:center;align-items:center;min-height:280px;background:#f8fafc;border-radius:16px}.campaign-map-header{text-align:center;margin-bottom:.75rem;padding:0 .5rem}.campaign-map-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.campaign-map-subtitle{font-size:.8rem;color:#475569}.campaign-parcours-scroll{width:100%;border-radius:16px;padding:2px}.campaign-parcours-list{display:flex;flex-direction:column;gap:1.5rem;padding:.25rem 0 2rem}.campaign-stage-section{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:#f8fafc;border-radius:16px;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f}.campaign-stage-section:not(:first-child){margin-top:1.5rem}.campaign-stage-title-wrap{position:relative;padding-left:.75rem;margin-bottom:.75rem}.campaign-stage-title-wrap:before{content:"";position:absolute;left:0;top:.15em;bottom:.15em;width:4px;border-radius:2px}.campaign-stage-title-wrap.campaign-stage-1:before{background:#0d9488}.campaign-stage-title-wrap.campaign-stage-2:before{background:#6366f1}.campaign-stage-title-wrap.campaign-stage-3:before{background:#db2777}.campaign-stage-title-wrap.campaign-stage-4:before{background:#d97706}.campaign-stage-title{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0;letter-spacing:.02em}.campaign-parcours-empty{text-align:center;padding:2rem 1rem;color:#64748b;font-size:.95rem;background:#f1f5f9;border-radius:16px;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f}.campaign-node-card{display:block;width:100%;min-height:140px;border:none;border-radius:16px;cursor:pointer;text-align:left;position:relative;overflow:hidden;box-shadow:0 2px 4px #0000000a,0 8px 24px #00000014,inset 0 1px #ffffff1a;transition:transform .2s ease,box-shadow .2s ease;padding:0;font-family:inherit}.campaign-node-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000000f,0 12px 28px #0000001f,inset 0 1px #ffffff1a}.campaign-node-card:active{transform:translateY(0)}.campaign-node-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#00000059,#0000000d 60%);pointer-events:none;border-radius:inherit}.campaign-node-card-inner{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:1.25rem 1.5rem;min-height:140px}.campaign-node-label{font-size:1.5rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:.02em;margin-bottom:.25rem}.campaign-node-subtitle{font-size:1rem;font-weight:500;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.3);line-height:1.3}.campaign-node-badge{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:50%;background:#fffffff2;display:flex;align-items:center;justify-content:center;color:#16a34a}.campaign-node-badge svg{width:18px;height:18px}.campaign-node-card.campaign-node-active{box-shadow:0 0 0 3px #5b21b6,0 8px 24px #5b21b640}.campaign-node-card.campaign-node-active:hover{box-shadow:0 0 0 3px #6d28d9,0 12px 28px #5b21b64d}.campaign-node-card.campaign-node-cadence.campaign-node-active{box-shadow:0 0 0 3px #d97706,0 8px 24px #d9770640}.campaign-node-card.campaign-node-loading{pointer-events:none;opacity:.85}.campaign-card-illustration-foundation{background:linear-gradient(135deg,#57534e,#44403c,#292524)}.campaign-card-illustration-path{background:linear-gradient(135deg,#78716c,#57534e,#3f3f46)}.campaign-card-illustration-home{background:linear-gradient(135deg,#b45309,#92400e,#78350f)}.campaign-card-illustration-trinity{background:linear-gradient(135deg,#4b5563,#374151,#1f2937)}.campaign-card-illustration-calm{background:linear-gradient(135deg,#0d9488,#0f766e,#115e59)}.campaign-card-illustration-landmark{background:linear-gradient(135deg,#6366f1,#4f46e5,#4338ca)}.campaign-card-illustration-steps{background:linear-gradient(135deg,#64748b,#475569,#334155)}.campaign-card-illustration-road{background:linear-gradient(135deg,#7c3aed,#6d28d9,#5b21b6)}.campaign-card-illustration-nuance{background:linear-gradient(135deg,#a855f7,#9333ea,#7e22ce)}.campaign-card-illustration-color{background:linear-gradient(135deg,#ec4899,#db2777,#be185d)}.campaign-card-illustration-virtuosity{background:linear-gradient(135deg,#f59e0b,#d97706,#b45309)}.campaign-card-illustration-detour{background:linear-gradient(135deg,#8b5cf6,#7c3aed,#6d28d9)}.campaign-card-illustration-suspense{background:linear-gradient(135deg,#64748b,#475569 60%,#334155)}.campaign-card-illustration-napoli{background:linear-gradient(135deg,#0ea5e9,#0284c7,#0369a1)}.campaign-card-illustration-dominant{background:linear-gradient(135deg,#dc2626,#b91c1c,#991b1b)}.campaign-card-illustration-secondary{background:linear-gradient(135deg,#ea580c,#c2410c,#9a3412)}.campaign-card-illustration-summit{background:linear-gradient(135deg,#1e3a5f,#0f172a 60%,#020617)}.campaign-card-illustration-default{background:linear-gradient(135deg,#5b21b6,#4c1d95,#3b0764)}.campaign-modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.campaign-modal{background:#fff;border-radius:16px;padding:1.5rem 2rem;max-width:420px;width:100%;box-shadow:0 8px 16px #00000014,0 24px 48px #0000001f;position:relative}.campaign-modal-close{position:absolute;top:.75rem;right:1rem;background:none;border:none;font-size:1.5rem;line-height:1;color:#64748b;cursor:pointer;padding:.25rem}.campaign-modal-close:hover{color:#1e293b}.campaign-modal-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.campaign-modal-description{font-size:.9rem;color:#475569;line-height:1.5;margin:0 0 1rem}.campaign-modal-stats{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.85rem;color:#64748b;margin-bottom:1rem}.campaign-modal-locked{font-size:.9rem;color:#64748b;margin:0 0 1rem}.campaign-modal-actions{display:flex;flex-direction:column;gap:.75rem}.campaign-modal-btn{display:inline-block;padding:.6rem 1rem;border-radius:10px;font-size:.9rem;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;border:none;transition:background .2s ease,color .2s ease}.campaign-modal-btn-primary{background:#5b21b6;color:#fff;box-shadow:0 2px 8px #5b21b659}.campaign-modal-btn-primary:hover:not(:disabled){background:#6d28d9;box-shadow:0 4px 12px #5b21b666}.campaign-modal-btn-primary:disabled{opacity:.7;cursor:not-allowed}.campaign-modal-btn-codex{background:#e2e8f0;color:#475569}.campaign-modal-btn-codex:hover{background:#cbd5e1;color:#1e293b}@media(max-width:768px){.campaign-map-header{margin-bottom:.6rem}.campaign-map-title{font-size:1.15rem}.campaign-stage-section{padding:1rem 1rem 1.25rem}.campaign-stage-section:not(:first-child){margin-top:1.25rem}.campaign-stage-title{font-size:1.05rem}.campaign-node-card{min-height:120px}.campaign-node-card-inner{min-height:120px;padding:1rem 1.25rem}.campaign-node-label{font-size:1.35rem}.campaign-node-subtitle{font-size:.9rem}.campaign-node-badge{width:28px;height:28px;top:.75rem;right:.75rem}.campaign-node-badge svg{width:16px;height:16px}}.parcours-node-page{min-height:100%;background-color:#f8fafc;border-radius:16px;padding:1rem 0 2rem;position:relative}.parcours-node-page-inner{position:relative;z-index:1;max-width:640px;margin:0 auto;padding:0 1rem}.parcours-node-back{display:inline-flex;align-items:center;gap:.25rem;margin-bottom:1.25rem;padding:.4rem .75rem;background:transparent;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;color:#475569;cursor:pointer;transition:background .2s ease,color .2s ease}.parcours-node-back:hover{background:#f1f5f9;color:#1e293b}.parcours-node-header{margin-bottom:1.5rem}.parcours-node-title{font-size:1.35rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;line-height:1.3}.parcours-node-objective{font-size:.95rem;color:#475569;line-height:1.5;margin:0 0 .75rem}.parcours-node-stats{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.85rem;color:#64748b}.parcours-node-section-title{font-size:1rem;font-weight:600;color:#334155;margin:0 0 .75rem}.parcours-node-actions{margin-bottom:1.5rem}.parcours-node-btn-random{display:inline-block;padding:.65rem 1.25rem;border-radius:10px;font-size:.95rem;font-weight:600;background:#5b21b6;color:#fff;border:none;cursor:pointer;transition:background .2s ease,transform .1s ease}.parcours-node-btn-random:hover:not(:disabled){background:#6d28d9}.parcours-node-btn-random:disabled{opacity:.8;cursor:not-allowed}.parcours-node-all-done-msg{font-size:.9rem;color:#64748b;margin:.75rem 0 0;max-width:480px}.parcours-node-list{margin-bottom:1.5rem}.parcours-node-loading{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#64748b}.parcours-node-empty{font-size:.9rem;color:#64748b;margin:0}.parcours-node-exercise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.parcours-node-exercise-grid .exercise-card{min-width:0}.parcours-node-exercise-grid .exercise-card-pill--recommended{background:#d1fae5;color:#059669}.parcours-node-codex{padding-top:1rem;border-top:1px solid #e2e8f0}.parcours-node-btn-codex{display:inline-block;padding:.55rem 1rem;border-radius:10px;font-size:.9rem;font-weight:600;background:transparent;color:#5b21b6;border:2px solid #5b21b6;cursor:pointer;transition:background .2s ease,color .2s ease}.parcours-node-btn-codex:hover{background:#5b21b6;color:#fff}.parcours-node-page .spinner-small{display:inline-block;width:18px;height:18px;border:2px solid #cbd5e1;border-top-color:#5b21b6;border-radius:50%;animation:parcours-node-spin .7s linear infinite}@keyframes parcours-node-spin{to{transform:rotate(360deg)}}.skills-radar-container{width:100%;position:relative;padding:1.5rem 0;background:linear-gradient(135deg,#8b5cf608,#667eea05);border-radius:16px;transition:all .3s ease;overflow:visible}.skills-radar-container:hover{background:linear-gradient(135deg,#8b5cf60d,#667eea0a)}.skills-radar-empty{text-align:center;padding:3rem 1rem;color:#6b7280;font-size:.875rem;background:#f9fafb;border-radius:12px;border:1px dashed #e5e7eb}.skills-radar-tooltip{background:#111827f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:.75rem 1rem;box-shadow:0 10px 25px #00000026,0 4px 10px #0000001a;border:1px solid rgba(255,255,255,.1);min-width:120px}.skills-radar-tooltip-label{color:#fff;font-size:.875rem;font-weight:600;margin:0 0 .25rem;text-transform:capitalize;letter-spacing:.3px}.skills-radar-tooltip-value{color:#a78bfa;font-size:1.125rem;font-weight:700;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.skills-radar-container :global(.recharts-radar){animation:fadeInRadar 1s cubic-bezier(.4,0,.2,1)}@keyframes fadeInRadar{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.skills-radar-container :global(.skills-radar-grid){opacity:.6}.skills-radar-container :global(.skills-radar-angle-axis .recharts-polar-angle-axis-tick text){transition:all .3s cubic-bezier(.4,0,.2,1);text-shadow:0 1px 2px rgba(255,255,255,.8)}.skills-radar-container :global(.skills-radar-angle-axis .recharts-polar-angle-axis-tick:hover text){fill:#8b5cf6;transform:scale(1.15);text-shadow:0 2px 4px rgba(139,92,246,.3)}.skills-radar-container :global(.skills-radar-radius-axis .recharts-polar-radius-axis-tick text){transition:all .2s ease;transform:translateY(-5px)}.skills-radar-container :global(.skills-radar-radius-axis .recharts-polar-radius-axis-tick:last-child text){opacity:0;pointer-events:none}.skills-radar-container :global(.skills-radar-radius-axis .recharts-polar-radius-axis-tick:hover text){fill:#8b5cf6;font-weight:700}.skills-radar-container :global(.skills-radar-dot){transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 6px rgba(139,92,246,.5)) drop-shadow(0 0 8px rgba(255,255,255,.8))}.skills-radar-container :global(.skills-radar-dot:hover){transform:scale(1.4);filter:drop-shadow(0 4px 12px rgba(139,92,246,.7)) drop-shadow(0 0 12px rgba(255,255,255,1));stroke-width:5}.skills-radar-container :global(.skills-radar-active-dot){animation:pulseDot 2s ease-in-out infinite}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.skills-radar-container :global(.recharts-radar-polygon){filter:url(#radarGlow);transition:all .3s ease}.skills-radar-container:hover :global(.recharts-radar-polygon){filter:url(#radarGlow) brightness(1.05)}@media(max-width:768px){.skills-radar-container :global(.skills-radar-angle-axis .recharts-polar-angle-axis-tick text){font-size:12px}.skills-radar-container :global(.skills-radar-dot){r:5}}.activity-heatmap{width:100%}.heatmap-container{overflow:hidden;padding:1rem 0;width:100%}.heatmap-grid{display:flex;gap:3px;width:100%}.heatmap-week{display:flex;flex-direction:column;gap:3px}.heatmap-square{width:12px;height:12px;border-radius:2px;cursor:pointer;transition:all .2s ease;border:1px solid #9ca3af;box-sizing:border-box;background-color:#fff}.heatmap-square:hover{border-color:#9ca3af;transform:scale(1.2);z-index:1;position:relative}.heatmap-today{border:2px solid #667eea!important}.heatmap-selected{border:2px solid #fbbf24!important;transform:scale(1.3)}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:1rem;font-size:.75rem;color:#6b7280}.heatmap-legend-squares{display:flex;gap:3px}.heatmap-legend-square{width:12px;height:12px;border-radius:2px;border:1px solid #d1d5db;box-sizing:border-box}.heatmap-legend-label{font-size:.75rem;color:#6b7280}@media(max-width:480px){.heatmap-square,.heatmap-legend-square{width:10px;height:10px}}.performance-details .degree-roman{font-family:Cinzel,Times New Roman,serif;font-weight:600;letter-spacing:.02em}.performance-stat-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem 1rem}.performance-stat-item--sub{padding:.6rem .75rem;margin-left:1rem;font-size:.9375rem}.performance-stat-item--sub .performance-stat-name{font-size:.9375rem;font-weight:600}.performance-degree-block{display:flex;flex-direction:column;gap:.5rem}.performance-degree-card{min-width:0}.performance-degree-card--clickable{cursor:pointer;border-radius:8px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.performance-degree-card--clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;background:#f3f4f6}.performance-degree-card--clickable .performance-stat-item{border-color:transparent}.performance-degree-by-figure{display:flex;flex-direction:column;gap:.5rem;padding-left:1.25rem}.performance-degrees-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.performance-cadence-block{display:flex;flex-direction:column;gap:.5rem}.performance-functions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.performance-function-gauge{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.performance-function-gauge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.performance-function-gauge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.performance-function-name{font-size:1.125rem;font-weight:700}.performance-function-percentage{font-size:1.25rem;font-weight:700}.performance-function-gauge-bar{height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:.75rem}.performance-function-gauge-fill{height:100%;transition:width .5s ease;border-radius:6px;box-shadow:0 2px 4px #0000001a}.performance-function-gauge-detail{font-size:.8125rem;color:#6b7280;line-height:1.5}.performance-stat-detail{display:flex;flex-direction:column;gap:.25rem}.performance-stat-breakdown{font-size:.8125rem;color:#6b7280}.performance-stat-average{font-size:.75rem;color:#9ca3af;font-style:italic}@media(max-width:640px){.performance-degrees-grid{grid-template-columns:1fr}}@media(max-width:480px){.performance-category-header{padding:.875rem 1.25rem}.performance-category-content{padding:0 1.25rem 1.25rem}.performance-functions-grid{grid-template-columns:1fr}.performance-stat-item{padding:.6rem .75rem}}.weekly-objectives{width:100%}.objectives-loading{display:flex;justify-content:center;align-items:center;padding:2rem}.objectives-empty{text-align:center;padding:2rem 1rem;color:#6b7280}.objectives-empty-emoji{font-size:3rem;margin-bottom:1rem}.objectives-empty-text{font-size:.875rem;margin:0}.objectives-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.objectives-unlocked-message{font-size:.8125rem;color:#059669;margin:0 0 .75rem;font-style:italic}.objectives-list{display:flex;flex-direction:column;gap:1rem}.objective-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1.25rem;transition:all .3s ease}.objective-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.objective-completed{border-color:#10b981;background:linear-gradient(135deg,#10b9810d,#0596690d)}.objective-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.objective-info{flex:1}.objective-name{font-size:1rem;font-weight:700;color:#111827;margin:0 0 .25rem}.objective-description{font-size:.875rem;color:#6b7280;margin:0}.objective-check{width:32px;height:32px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;flex-shrink:0}.objective-progress{width:100%}.objective-progress-bar{height:8px;background:#e5e7eb;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.objective-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .5s ease}.objective-completed .objective-progress-fill{background:linear-gradient(90deg,#10b981,#059669)}.objective-progress-text{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.objective-current{font-weight:700;color:#111827}.objective-separator{color:#9ca3af}.objective-target{color:#6b7280}.objective-reward{margin-left:auto;padding:.25rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:.75rem;font-weight:600}.objective-completed .objective-reward{background:linear-gradient(135deg,#10b981,#059669)}@media(max-width:768px){.objective-card{padding:1rem}.objective-name{font-size:.9375rem}.objective-description{font-size:.8125rem}}.trend-indicators{width:100%}.trend-indicators--bourse .trend-indicators-title{margin-bottom:1.25rem}.trend-indicators-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.trend-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.trend-kpi-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1rem;transition:all .2s ease;box-shadow:0 1px 3px #0000000f}.trend-kpi-card:hover{box-shadow:0 4px 12px #00000014}.trend-kpi-up{border-color:#10b981;background:linear-gradient(135deg,#10b9810f,#0596690a)}.trend-kpi-down{border-color:#ef4444;background:linear-gradient(135deg,#ef44440f,#dc26260a)}.trend-kpi-stable{border-color:#e5e7eb}.trend-kpi-label{font-size:.7rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.trend-kpi-value-wrap{display:flex;align-items:center;gap:.35rem}.trend-kpi-icon{flex-shrink:0}.trend-kpi-up .trend-kpi-value,.trend-kpi-up .trend-kpi-icon{color:#059669}.trend-kpi-down .trend-kpi-value,.trend-kpi-down .trend-kpi-icon{color:#dc2626}.trend-kpi-stable .trend-kpi-value,.trend-kpi-icon-stable{color:#6b7280}.trend-kpi-value{font-size:1.5rem;font-weight:800;color:#111827;line-height:1.2}.trend-kpi-raw{font-size:.75rem;margin-top:.35rem;color:#6b7280}.trend-kpi-current{font-weight:600;color:#111827}.trend-kpi-vs,.trend-kpi-previous{color:#9ca3af}.trend-kpi-count{font-size:.7rem;color:#9ca3af;margin-top:.2rem}.trend-kpi-value--best{font-size:1.125rem}.trend-kpi-encouragement{margin:.5rem 0 0;font-size:.8125rem;font-weight:600;color:#059669;line-height:1.3}.trend-pedagogical-section{margin-bottom:1.5rem}.trend-pedagogical-title{font-size:.8125rem;font-weight:600;color:#6b7280;margin:0 0 .75rem}.trend-pedagogical-grid{margin-bottom:0}.trend-pedago-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1rem}.trend-pedago-label{font-size:.7rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.trend-pedago-bars{display:flex;flex-direction:column;gap:.5rem}.trend-pedago-row{display:grid;grid-template-columns:6.5rem 1fr auto;align-items:center;gap:.5rem;font-size:.8125rem}.trend-pedago-row-label{min-width:0;color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trend-pedago-bar-wrap{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.trend-pedago-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.trend-pedago-row-value{font-weight:700;color:#111827;min-width:2.5rem;text-align:right}.trend-pedago-summary{display:flex;flex-direction:column;gap:.35rem}.degree-roman{font-family:Cinzel,Times New Roman,serif;font-weight:600;letter-spacing:.02em}.trend-pedago-line{margin:0;font-size:.8125rem;color:#374151;overflow-wrap:break-word;word-break:break-word}.trend-pedago-strong{color:#059669;font-weight:600}.trend-pedago-weak{color:#6b7280}.trend-pedago-empty{margin:0;font-size:.8125rem;color:#9ca3af}.trend-chart-section{margin-bottom:1.5rem}.trend-chart-title{font-size:.8125rem;font-weight:600;color:#6b7280;margin:0 0 .5rem}.trend-chart-wrap{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;padding:.5rem}.trend-chart-tooltip{background:#111827;color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:.8125rem;display:flex;flex-direction:column;gap:.15rem}.trend-chart-tooltip-date{color:#9ca3af}.trend-chart-tooltip-value{font-weight:700;font-size:1rem}.trend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.trend-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.trend-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.trend-up{border-color:#10b981;background:linear-gradient(135deg,#10b9810d,#0596690d)}.trend-down{border-color:#ef4444;background:linear-gradient(135deg,#ef44440d,#dc26260d)}.trend-stable{border-color:#e5e7eb}.trend-icon{font-size:2rem;line-height:1;flex-shrink:0}.trend-content{flex:1;min-width:0}.trend-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem;font-weight:500}.trend-value{font-size:1.25rem;font-weight:700;color:#111827}.trend-up .trend-value{color:#10b981}.trend-down .trend-value{color:#ef4444}.trend-stable .trend-value{color:#6b7280}.trend-raw{font-size:.7rem;color:#6b7280;margin-top:.25rem}.trend-raw-current{font-weight:600;color:#111827}.trend-raw-vs{color:#9ca3af}.trend-raw-previous{font-weight:500}.trend-count{font-size:.7rem;color:#9ca3af;margin-top:.125rem}.trend-details-wrap{margin-top:1rem;border-top:1px solid #e5e7eb;padding-top:1rem}.trend-details-toggle{background:none;border:none;font-size:.875rem;color:#4b5563;cursor:pointer;text-decoration:underline;padding:0}.trend-details-toggle:hover{color:#111827}.trend-details{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:12px}.trend-detail-block{margin-bottom:1rem}.trend-detail-block:last-child{margin-bottom:0}.trend-detail-title{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .25rem}.trend-detail-value{font-size:.875rem;color:#374151;margin:0}.trend-weeks-table{display:flex;flex-direction:column;gap:.25rem}.trend-week-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;font-size:.875rem}.trend-week-label{color:#6b7280}.trend-week-value{font-weight:600;color:#111827}.trend-week-count{color:#9ca3af}@media(max-width:900px){.trend-indicators,.trend-pedagogical-section{max-width:100%;overflow-x:hidden}.trend-pedagogical-grid{grid-template-columns:1fr;min-width:0}.trend-pedago-card{min-width:0}.trend-pedago-row{min-width:0;grid-template-columns:6.5rem minmax(0,1fr) auto}.trend-pedago-row-label{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trend-pedago-bar-wrap{min-width:0}.trend-pedago-row-value{min-width:2rem;flex-shrink:0}.trend-pedago-summary{gap:.5rem}.trend-pedago-line{line-height:1.45}}@media(max-width:768px){.trend-indicators,.trend-pedagogical-section{max-width:100%;overflow-x:hidden}.trend-pedagogical-grid{grid-template-columns:1fr;min-width:0}.trend-pedago-card{min-width:0}.trend-pedago-row{min-width:0;grid-template-columns:6.5rem minmax(0,1fr) auto}.trend-pedago-row-label{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trend-pedago-bar-wrap{min-width:0}.trend-pedago-row-value{min-width:2rem;flex-shrink:0}.trend-pedago-summary{gap:.5rem}.trend-pedago-line{line-height:1.45}.trend-kpi-card{min-width:0;overflow:hidden}.trend-kpi-value-wrap{min-width:0}.trend-kpi-value--best{font-size:1rem;overflow-wrap:break-word;word-break:break-word}.trend-kpi-raw{overflow-wrap:break-word;word-break:break-word}.trend-kpi-grid{grid-template-columns:1fr;gap:.75rem}.trend-kpi-value{font-size:1.25rem}.trend-chart-wrap{padding:.25rem}.trend-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.trend-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.trend-icon{font-size:1.5rem}.trend-value{font-size:1.125rem}}.milestone-celebration{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:none;animation:milestoneAppear .5s ease-out}.milestone-celebration--level .milestone-celebration-content{border-width:3px;border-color:#fbbf2499;box-shadow:0 20px 60px #0000004d,0 0 0 1px #fbbf2433}.milestone-celebration--level .milestone-emoji-large{animation:milestoneBounce .6s ease-out,milestonePulse 1.2s ease-out .3s 1}@keyframes milestonePulse{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.08)}}.milestone-celebration-content{background:#111827f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:24px;padding:2rem 3rem;box-shadow:0 20px 60px #0000004d;border:2px solid rgba(139,92,246,.5);text-align:center;min-width:280px}.milestone-emoji-large{font-size:4rem;line-height:1;margin-bottom:1rem;animation:milestoneBounce .6s ease-out;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.milestone-message{font-size:1.25rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}@keyframes milestoneAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes milestoneBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media(max-width:768px){.milestone-celebration-content{padding:1.5rem 2rem;min-width:240px}.milestone-emoji-large{font-size:3rem}.milestone-message{font-size:1.125rem}}.period-comparison{width:100%}.comparison-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.comparison-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1.25rem;transition:all .3s ease}.comparison-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.comparison-metric{font-size:.9375rem;font-weight:700;color:#111827;margin:0}.comparison-change{font-size:.875rem;font-weight:700;padding:.25rem .5rem;border-radius:8px}.comparison-up{color:#10b981;background:#10b9811a}.comparison-down{color:#ef4444;background:#ef44441a}.comparison-stable{color:#6b7280;background:#6b72801a}.comparison-values{display:flex;align-items:center;justify-content:space-between;gap:1rem}.comparison-period{flex:1;text-align:center}.comparison-period-label{font-size:.75rem;color:#6b7280;margin-bottom:.5rem;font-weight:500}.comparison-period-value{font-size:1.5rem;font-weight:700;color:#111827}.comparison-vs{font-size:.875rem;color:#9ca3af;font-weight:600;flex-shrink:0}@media(max-width:768px){.comparison-grid{grid-template-columns:1fr}.comparison-card{padding:1rem}.comparison-values{flex-direction:column;gap:.75rem}.comparison-vs{transform:rotate(90deg)}}.exercise-suggestions{width:100%}.suggestions-loading{display:flex;justify-content:center;align-items:center;padding:2rem}.suggestions-empty{text-align:center;padding:2rem 1rem;color:#6b7280}.suggestions-empty-emoji{font-size:3rem;margin-bottom:1rem}.suggestions-empty-text{font-size:.875rem;margin:0}.suggestions-empty-hint{font-size:.8125rem;color:#9ca3af;margin:.5rem 0 1rem}.suggestions-cta-row{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.suggestion-button-secondary{background:#e5e7eb;color:#374151}.suggestion-button-secondary:hover{box-shadow:0 2px 8px #0000001a}.suggestions-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.suggestions-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.suggestions-list .exercise-card{min-width:0}.suggestion-button{padding:.625rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex-shrink:0}.suggestion-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.suggestion-button:active{transform:scale(.98)}@media(max-width:768px){.suggestions-list{grid-template-columns:1fr}.suggestions-cta-row .suggestion-button{width:100%}}.weekly-stats{width:100%}.weekly-stats-empty{text-align:center;padding:2rem 1rem;color:#6b7280}.weekly-stats-empty-emoji{font-size:3rem;margin-bottom:1rem}.weekly-stats-empty-text{font-size:.875rem;margin:0}.weekly-stats-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.weekly-stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.weekly-stat-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1rem;text-align:center;transition:all .3s ease}.weekly-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.weekly-stat-value{font-size:1.75rem;font-weight:700;color:#111827;margin-bottom:.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.weekly-stat-label{font-size:.75rem;color:#6b7280;font-weight:500}.weekly-stats-chart{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1.5rem}.weekly-stats-tooltip{background:#111827f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:.75rem 1rem;box-shadow:0 10px 25px #00000026;border:1px solid rgba(255,255,255,.1);min-width:120px}.weekly-stats-tooltip-label{color:#fff;font-size:.875rem;font-weight:600;margin:0 0 .25rem}.weekly-stats-tooltip-value{color:#a78bfa;font-size:1rem;font-weight:700;margin:0 0 .25rem}.weekly-stats-tooltip-score{color:#9ca3af;font-size:.75rem;margin:0}@media(max-width:768px){.weekly-stats-summary{grid-template-columns:repeat(3,1fr);gap:.75rem}.weekly-stat-card{padding:.75rem}.weekly-stat-value{font-size:1.5rem}.weekly-stats-chart{padding:1rem}}.achievements-dashboard{width:100%}.achievements-loading{display:flex;justify-content:center;align-items:center;padding:2rem}.achievements-header{margin-bottom:1.5rem}.achievements-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.achievements-progress{display:flex;align-items:center;gap:1rem}.achievements-progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:10px;overflow:hidden}.achievements-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .5s ease}.achievements-progress-text{font-size:.875rem;font-weight:600;color:#6b7280;white-space:nowrap}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.achievement-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:1rem;text-align:center;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;position:relative;min-height:140px}.achievement-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.achievement-unlocked{border-color:#8b5cf6;background:linear-gradient(135deg,#8b5cf60d,#667eea0d)}.achievement-locked{opacity:.7}.achievement-emoji{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.achievement-emoji-locked{opacity:.5;filter:grayscale(.5)}.achievement-name{font-size:.8125rem;font-weight:700;color:#111827;line-height:1.3}.achievement-locked .achievement-name{color:#6b7280}.achievement-progress-mini{width:100%;margin-top:auto}.achievement-progress-bar-mini{height:4px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.25rem}.achievement-progress-fill-mini{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.achievement-progress-text-mini{font-size:.65rem;color:#6b7280;font-weight:600}.achievement-date{font-size:.7rem;color:#9ca3af;margin-top:auto;padding-top:.5rem}.achievement-unlocks{margin-top:.25rem}.achievement-unlocks-label{font-size:.65rem;color:#6b7280;font-style:italic;display:block}.achievement-staged-popover{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:.5rem .6rem;background:#fff;border:2px solid #8b5cf6;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:20;min-width:calc(100% + 8px);max-height:min(50vh,280px);overflow-y:auto;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s ease}.achievement-card-staged:hover{z-index:30}.achievement-card-staged:hover .achievement-staged-popover{opacity:1;visibility:visible;pointer-events:auto}.achievement-staged-popover .achievement-progress-mini{width:100%;margin-top:.35rem}.achievement-staged-popover .achievement-stages-dots{margin-top:0}.achievement-stages-dots{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center}.achievement-stage-dot{font-size:.6rem;font-weight:700;padding:.15rem .35rem;border-radius:6px;background:#e5e7eb;color:#9ca3af;min-width:1.5rem;text-align:center}.achievement-stage-dot-unlocked{background:#8b5cf6;color:#fff}.achievements-modal-stages{margin-top:1rem}.achievements-modal-stages-title{font-size:.8125rem;font-weight:600;color:#6b7280;margin:0 0 .5rem}.achievements-modal-stages-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.achievements-modal-stage-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-radius:10px;font-size:.9rem}.achievements-modal-stage-unlocked{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3)}.achievements-modal-stage-locked{background:#f3f4f6;border:1px solid #e5e7eb;color:#9ca3af}.achievements-modal-stage-value{font-weight:700;color:#111827}.achievements-modal-stage-locked .achievements-modal-stage-value{color:#6b7280}.achievements-modal-stage-status{font-size:.75rem;font-weight:600}.achievements-modal-stage-unlocked .achievements-modal-stage-status{color:#059669}.achievements-modal-stage-locked .achievements-modal-stage-status{color:#9ca3af}.achievements-block{margin-bottom:1.5rem}.achievements-block-title{font-size:.9375rem;font-weight:600;color:#6b7280;margin:0 0 .75rem}.achievements-rest-unlocked-section{margin-top:1rem;border-top:1px solid #e5e7eb;padding-top:1rem}.achievements-grid-rest-unlocked{margin-top:0;padding-top:.75rem}.achievements-empty-hint{margin-top:1rem;font-size:.9rem;color:#6b7280;text-align:center}.achievements-locked-section{margin-top:1.5rem;border-top:1px solid #e5e7eb;padding-top:1rem}.achievements-locked-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem .75rem;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;color:#6b7280;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s ease}.achievements-locked-toggle:hover{border-color:#8b5cf6;color:#6d28d9;background:#8b5cf60f}.achievements-locked-toggle[aria-expanded=true]{border-color:#8b5cf6;border-bottom-left-radius:0;border-bottom-right-radius:0}.achievements-grid-locked{margin-top:0;padding:1rem;border:2px solid #e5e7eb;border-top:none;border-radius:0 0 12px 12px;background:#f9fafb}.achievements-modal-overlay{position:fixed;inset:0;z-index:1001;display:flex;align-items:center;justify-content:center;padding:1rem;background:#00000080;animation:achievements-modal-overlay-in .2s ease-out;overflow-y:auto;-webkit-overflow-scrolling:touch}@keyframes achievements-modal-overlay-in{0%{opacity:0}to{opacity:1}}.achievements-modal{position:relative;max-width:360px;width:100%;padding:1.5rem;border-radius:16px;box-shadow:0 20px 40px #00000040;animation:achievements-modal-in .3s ease-out;cursor:pointer;max-height:calc(100vh - 2rem);overflow-y:auto;margin:auto}@keyframes achievements-modal-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.achievements-modal-unlocked{background:#fffffffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid #8b5cf6;box-shadow:0 0 0 1px #8b5cf626}.achievements-modal-locked{background:#fff;border:2px solid #e5e7eb}.achievements-modal-close{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;border:none;background:#0000000f;color:#6b7280;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.achievements-modal-close:hover{background:#0000001a;color:#111827}.achievements-modal-emoji{font-size:3rem;text-align:center;margin-bottom:.75rem;line-height:1}.achievements-modal-locked .achievements-modal-emoji{filter:grayscale(.5);opacity:.8}.achievements-modal-name{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 .5rem;text-align:center;line-height:1.3}.achievements-modal-description{font-size:.9375rem;color:#374151;margin:0 0 .75rem;line-height:1.5;font-weight:500}.achievements-modal-progress{font-size:.9rem;font-weight:600;color:#6d28d9;margin:0 0 .5rem}.achievements-modal-date{font-size:.875rem;color:#4b5563;margin:0 0 .25rem}.achievements-modal-unlocks{font-size:.875rem;color:#4b5563;font-style:italic;margin:0;font-weight:500}.achievements-modal-horizons-cta{display:block;margin-top:1rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0ea5e94d}.achievements-modal-horizons-cta:hover{box-shadow:0 4px 12px #0ea5e966;transform:translateY(-1px)}.achievements-modal-horizons-cta:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px}@media(max-width:768px){.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.achievement-card{padding:.75rem;min-height:120px}.achievement-emoji{font-size:2rem}.achievement-name{font-size:.75rem}.achievement-staged-popover{left:50%;max-width:min(280px,100vw);max-height:min(45vh,260px)}.achievements-modal-overlay{padding:.5rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom));padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right))}.achievements-modal{max-height:calc(100vh - 1rem - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 80px);max-height:calc(100dvh - 1rem - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 80px)}}.attempt-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.attempt-detail-modal{background:#fff;color:#111827;border-radius:16px;max-width:560px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026;position:relative}.attempt-detail-close{position:absolute;top:1rem;right:1rem;background:none;border:none;padding:.25rem;cursor:pointer;color:#6b7280;border-radius:8px;display:flex;align-items:center;justify-content:center}.attempt-detail-close:hover{background:#f3f4f6;color:#111827}.attempt-detail-modal .attempt-detail-title{margin:1.25rem 1rem 0;font-size:1.25rem;font-weight:700;color:#111827}.attempt-detail-exercise{margin:.25rem 1rem 0;font-size:.9rem;color:#6b7280}.attempt-detail-summary{margin:1rem 1rem 0;padding:.75rem 1rem;background:#f9fafb;border-radius:12px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.attempt-detail-score{font-weight:700;font-size:1.1rem;color:#111827}.attempt-detail-counts{font-size:.9rem;color:#6b7280}.attempt-detail-correct{color:#059669;margin-right:.5rem}.attempt-detail-partial{color:#d97706;margin-right:.5rem}.attempt-detail-incorrect{color:#dc2626;margin-right:.25rem}.attempt-detail-total{color:#6b7280}.attempt-detail-list{margin:1rem;padding-bottom:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.attempt-detail-row{padding:.75rem 1rem;border-radius:12px;border:1px solid #e5e7eb;background:#fafafa}.attempt-detail-row-correct{border-color:#a7f3d0;background:#ecfdf5}.attempt-detail-row-partial{border-color:#fde68a;background:#fffbeb}.attempt-detail-row-incorrect{border-color:#fecaca;background:#fef2f2}.attempt-detail-row .attempt-detail-num{font-weight:600;font-size:.8rem;color:#6b7280;margin-right:.5rem}.attempt-detail-user,.attempt-detail-correct-answer{font-family:inherit;font-size:.95rem;color:#111827}.attempt-detail-arrow{margin:0 .35rem;color:#9ca3af;font-size:.9rem}.attempt-detail-status{display:inline-block;margin-left:.5rem;font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:6px}.attempt-detail-status-correct{background:#059669;color:#fff}.attempt-detail-status-partial{background:#d97706;color:#fff}.attempt-detail-status-incorrect{background:#dc2626;color:#fff}.attempt-detail-feedback{margin:.5rem 0 0;font-size:.85rem;color:#6b7280;line-height:1.35}.request-establishment-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000}.request-establishment-modal-container{background:#fff;border-radius:12px;max-width:420px;width:90%;padding:0;box-shadow:0 20px 40px #00000026}.request-establishment-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.request-establishment-modal-header h2{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.request-establishment-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0 .25rem;line-height:1}.request-establishment-modal-close:hover{color:#111827}.request-establishment-modal-info{padding:1rem 1.25rem;margin:0;font-size:.875rem;color:#6b7280;line-height:1.5}.request-establishment-modal-form{padding:0 1.25rem 1.25rem}.request-establishment-modal-form label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.request-establishment-modal-form input{width:100%;padding:.5rem .75rem;font-size:1rem;border:1px solid #d1d5db;border-radius:8px;margin-bottom:.75rem;box-sizing:border-box}.request-establishment-modal-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.request-establishment-modal-error{margin:0 0 .75rem;font-size:.875rem;color:#dc2626}.request-establishment-modal-success{padding:1.25rem;margin:0;font-size:.9375rem;color:#059669;text-align:center}.request-establishment-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.request-establishment-modal-actions button{padding:.5rem 1rem;font-size:.9375rem;border-radius:8px;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#374151}.request-establishment-modal-actions button:hover:not(:disabled){background:#f3f4f6}.request-establishment-modal-actions button[type=submit]{background:#667eea;border-color:#667eea;color:#fff}.request-establishment-modal-actions button[type=submit]:hover:not(:disabled){background:#5a67d8}.request-establishment-modal-actions button:disabled{opacity:.6;cursor:not-allowed}.daily-learning-block{background:#fff;border-radius:24px;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.daily-learning-block-content{display:flex;flex-direction:column;gap:1rem}.daily-learning-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;color:#6b7280;font-size:.875rem;font-weight:500}.daily-learning-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:daily-learning-spin .8s linear infinite}@keyframes daily-learning-spin{to{transform:rotate(360deg)}}.daily-learning-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:0 0 .35rem}.daily-learning-next{margin:0}.daily-learning-node{display:flex;flex-direction:column;gap:.15rem}.daily-learning-node-label{font-size:1.125rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.daily-learning-node-subtitle{font-size:.875rem;color:#6b7280;font-weight:500}.daily-learning-node-fallback{font-size:.875rem;color:#6b7280;margin:0}.daily-learning-tip{padding-top:.75rem;border-top:1px solid #e5e7eb;margin:0}.daily-learning-tip-heading{margin-bottom:.35rem}.daily-learning-tip-text{font-size:.9375rem;line-height:1.5;color:#374151;margin:0}.daily-learning-tip-reason{font-size:.8125rem;line-height:1.4;color:#6b7280;margin:.35rem 0 0;font-style:italic}.daily-learning-horizons-cta{display:inline-block;margin-top:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #0ea5e94d}.daily-learning-horizons-cta:hover{box-shadow:0 4px 10px #0ea5e966;transform:translateY(-1px)}.daily-learning-horizons-cta:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px}.daily-learning-cta-wrap{padding-top:.25rem}.daily-learning-cta{width:100%;padding:.625rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d}.daily-learning-cta:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.daily-learning-cta:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media(min-width:768px){.daily-learning-block{padding:1.25rem 1.5rem}.daily-learning-block-content{display:grid;grid-template-columns:1fr 1.5fr auto;grid-template-rows:auto auto;gap:0 1.5rem;align-items:start}.daily-learning-next{grid-row:1 / 3}.daily-learning-tip{grid-column:2;border-top:none;padding-top:0;border-left:1px solid #e5e7eb;padding-left:1.25rem}.daily-learning-cta-wrap{grid-column:3;grid-row:1 / 3;padding-top:0;align-self:center}.daily-learning-cta{width:auto;min-width:180px;white-space:nowrap}}@media(max-width:480px){.daily-learning-block{padding:1rem}.daily-learning-tip-text{font-size:.875rem}}.codex-placeholder{display:flex;justify-content:center;padding:24px 12px}.codex-placeholder-card{width:min(720px,100%);padding:28px 24px;border:1px solid var(--student-border, #e5e7eb);border-radius:16px;background:var(--student-card, #fff);box-shadow:0 6px 22px #0000000d;text-align:center}.codex-placeholder-kicker{margin:0 0 8px;font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#6b7280}.codex-placeholder-title{margin:0;font-size:1.55rem;color:#111827}.codex-placeholder-text{margin:12px 0 0;color:#4b5563;line-height:1.55}.codex-notation{min-height:80px;overflow-x:auto;padding:.75rem 0}.codex-notation svg{max-width:100%;height:auto}.piano-keyboard{width:100%;max-width:420px;margin:0 auto}.piano-keyboard-svg{width:100%;height:auto;display:block}.piano-key{transition:fill .15s ease}.piano-white{fill:#f8fafc;stroke:#cbd5e1;stroke-width:1}.piano-white.piano-key--highlighted{fill:#93c5fd;stroke:#3b82f6}.piano-black{fill:#334155;stroke:#1e293b;stroke-width:1}.piano-black.piano-key--highlighted{fill:#3b82f6;stroke:#2563eb}.codex-audio-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:#3b82f6;border:none;border-radius:10px;cursor:pointer;transition:background .15s}.codex-audio-btn:hover:not(:disabled){background:#2563eb}.codex-audio-btn:disabled{opacity:.6;cursor:not-allowed}.codex-audio-btn--playing{background:#dc2626}.codex-audio-btn--playing:hover:not(:disabled){background:#b91c1c}.codex-audio-label{line-height:1}.codex-example-block{margin-top:1.25rem;padding:1rem 1.25rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.codex-example-title{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:#334155;margin-bottom:.75rem}.codex-example-notation,.codex-example-keyboard{margin-bottom:1rem}.codex-example-keyboard-label{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:500;color:#64748b;margin-bottom:.5rem}.codex-example-audio{margin-top:.75rem}@media(max-width:640px){.codex-example-block{padding:.875rem 1rem}.codex-example-title{font-size:.9rem}}.codex-view{padding:0 0 1.5rem;max-width:100%;margin:0 auto;min-height:0}.codex-view--list{padding-bottom:2rem}.codex-header{text-align:center;margin-bottom:1rem;padding:0 .5rem}.codex-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.codex-subtitle{font-size:.8rem;color:#475569}.codex-tabs{display:flex;gap:.25rem;margin-bottom:1rem;padding:0 .25rem}.codex-tab{flex:1;max-width:12rem;padding:.6rem 1rem;font-size:.9rem;font-weight:500;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.codex-tab:hover{color:#334155;background:#e2e8f0;border-color:#cbd5e1}.codex-tab--active{color:#1e40af;background:#fff;border-color:#3b82f6;box-shadow:0 1px 2px #3b82f626}.codex-tab:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.codex-list{display:flex;flex-direction:column;gap:1.5rem}.codex-category{background:#f8fafc;border-radius:16px;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000a}.codex-category-title{font-size:.95rem;font-weight:600;color:#475569;margin-bottom:.75rem;padding-left:.25rem}.codex-entry-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.codex-entry-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:background .15s,border-color .15s}.codex-entry-card:hover{background:#f1f5f9;border-color:#cbd5e1}.codex-entry-card:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.codex-entry-title{font-size:.95rem;font-weight:600;color:#1e293b;margin-bottom:.25rem}.codex-entry-desc{font-size:.8rem;color:#64748b;line-height:1.35}.codex-view--detail{padding-bottom:2rem}.codex-back{margin-bottom:1rem;padding:.5rem 0;background:none;border:none;font-size:.9rem;color:#3b82f6;cursor:pointer;text-decoration:none}.codex-back:hover{text-decoration:underline}.codex-back:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.codex-detail{background:#f8fafc;border-radius:16px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0000000a}.codex-detail-illustration{margin:-.25rem -.5rem 1rem;border-radius:12px;overflow:hidden;background:#e2e8f0}.codex-detail-img{width:100%;height:auto;aspect-ratio:8 / 5;-o-object-fit:cover;object-fit:cover;display:block}.codex-detail-title{font-size:1.2rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.codex-detail-desc{font-size:.9rem;color:#64748b;margin-bottom:1rem;font-style:italic}.codex-detail-content{margin-bottom:1.5rem}.codex-detail-content p{font-size:.95rem;line-height:1.6;color:#334155;margin-bottom:.75rem}.codex-detail-content p:last-child{margin-bottom:0}.codex-detail-content strong{font-weight:600;color:#1e293b}.codex-toc{margin:1rem 0 1.25rem;padding:1rem 1.25rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.codex-toc-title{font-size:.85rem;font-weight:600;color:#475569;margin-bottom:.5rem}.codex-toc-list{list-style:none;margin:0;padding:0}.codex-toc-list li{margin-bottom:.35rem}.codex-toc-link{font-size:.9rem;color:#3b82f6;text-decoration:none}.codex-toc-link:hover{text-decoration:underline}.codex-toc-link:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.codex-detail-section{margin-top:1.25rem;scroll-margin-top:.5rem}.codex-detail-section-title{font-size:1rem;font-weight:600;color:#334155;margin-bottom:.5rem}.codex-detail-section-content p{margin-bottom:.75rem}.codex-detail-section-content p:last-child{margin-bottom:0}.codex-detail-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid #e2e8f0}.codex-nav-btn{max-width:50%;padding:.5rem .75rem;background:none;border:1px solid #e2e8f0;border-radius:10px;font-size:.85rem;color:#3b82f6;cursor:pointer;text-align:center;transition:background .15s,border-color .15s}.codex-nav-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.codex-nav-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.codex-nav-next{margin-left:auto}.codex-detail-examples{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}.codex-examples-title{font-size:.95rem;font-weight:600;color:#475569;margin-bottom:.75rem}.codex-detail-links{border-top:1px solid #e2e8f0;padding-top:1rem;display:flex;flex-direction:column;gap:1rem}.codex-detail-block h4{font-size:.85rem;font-weight:600;color:#475569;margin-bottom:.5rem}.codex-node-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.codex-node-btn{display:inline-block;text-align:left;padding:.4rem 0;background:none;border:none;font-size:.9rem;color:#3b82f6;cursor:pointer;text-decoration:none}.codex-node-btn:hover{text-decoration:underline}.codex-node-stage{color:#64748b;font-weight:400}.codex-detail-hint{font-size:.8rem;color:#64748b;margin-bottom:.5rem}.codex-pratiquer-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:#3b82f6;border:none;border-radius:10px;cursor:pointer}.codex-pratiquer-btn:hover{background:#2563eb}.codex-pratiquer-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media(max-width:640px){.codex-detail{padding:1rem 1.25rem}.codex-detail-illustration{margin-left:-1rem;margin-right:-1rem;border-radius:0}.codex-detail-nav{flex-direction:column;align-items:stretch}.codex-nav-btn{max-width:none}}.horizons-map{padding:0 0 1.5rem;max-width:100%;margin:0 auto;background:transparent;border-radius:0}.horizons-map-header{text-align:center;margin-bottom:1rem;padding:0 .5rem}.horizons-map-header-with-back{text-align:left;position:relative;padding-left:0}.horizons-map-header-with-back:not(.horizons-map-header-back-hidden) .horizons-map-title,.horizons-map-header-with-back:not(.horizons-map-header-back-hidden) .horizons-map-subtitle{padding-left:4.5rem}.horizons-map-back{position:absolute;left:0;top:0;background:transparent;border:none;color:var(--text-secondary, #64748b);font-size:.9rem;cursor:pointer;padding:.25rem 0}.horizons-map-back:hover{color:var(--text-primary, #1e293b)}.horizons-map-title{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.horizons-map-subtitle{font-size:.8rem;color:var(--text-secondary, #475569)}.horizons-map-empty{text-align:center;padding:2rem 1rem;color:var(--text-secondary, #64748b);font-size:.95rem;background:var(--surface, #f1f5f9);border-radius:16px;box-shadow:0 1px 3px #0000000a}.horizons-map-empty-title{font-weight:700;color:var(--text-primary, #1e293b);margin-bottom:.5rem}.horizons-map-empty-text{margin-bottom:1rem}.horizons-map-empty-cta{padding:.6rem 1.2rem;border-radius:12px;border:none;background:var(--accent, #6366f1);color:#fff;font-weight:600;cursor:pointer}.horizons-map-empty-cta:hover{filter:brightness(1.05)}.horizons-map-empty-inline{padding:1.5rem}.horizons-map-cards{display:flex;flex-direction:column;gap:1rem}.horizons-style-card{display:block;width:100%;min-height:100px;border:none;border-radius:16px;cursor:pointer;text-align:left;position:relative;overflow:hidden;box-shadow:0 2px 4px #00000014;transition:transform .2s ease,box-shadow .2s ease;padding:0;font-family:inherit}.horizons-style-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#00000059,#0000000d 60%);pointer-events:none;border-radius:inherit}.horizons-style-card-inner{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:1.25rem 1.5rem;min-height:100px}.horizons-style-card-label{font-size:1.35rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);margin-bottom:.2rem}.horizons-style-card-subtitle{font-size:.9rem;font-weight:500;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.3)}.horizons-style-card-lock{position:absolute;top:.75rem;right:.75rem;font-size:1.25rem;opacity:.9}.horizons-style-card-unlocked:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.horizons-style-card-unlocked:active{transform:translateY(0)}.horizons-style-card-locked{cursor:not-allowed;opacity:.85;filter:saturate(.7)}.horizons-map-actions{margin-bottom:1rem}.horizons-map-random-btn{width:100%;padding:.75rem 1rem;border-radius:12px;border:none;background:var(--accent, #6366f1);color:#fff;font-weight:600;cursor:pointer}.horizons-map-random-btn:hover:not(:disabled){filter:brightness(1.05)}.horizons-map-random-btn:disabled{opacity:.6;cursor:not-allowed}.horizons-map-formation-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem}.horizons-map-formation-label{font-size:.875rem;font-weight:600;color:var(--text-secondary, #475569)}.horizons-map-formation-chips{display:flex;flex-wrap:wrap;gap:.4rem}.horizons-map-formation-chip{padding:.35rem .75rem;border-radius:9999px;border:1px solid var(--border, #e2e8f0);background:var(--surface, #f8fafc);color:var(--text-primary, #1e293b);font-size:.8rem;cursor:pointer;transition:background .15s ease,border-color .15s ease}.horizons-map-formation-chip:hover{background:var(--surface-hover, #f1f5f9);border-color:var(--border-hover, #cbd5e1)}.horizons-map-formation-chip-active{background:var(--accent, #6366f1);border-color:var(--accent, #6366f1);color:#fff}.horizons-map-formation-chip-active:hover{filter:brightness(1.05)}.horizons-map-loading{display:flex;justify-content:center;align-items:center;min-height:160px}.horizons-map-exercise-list{display:flex;flex-direction:column;gap:.75rem}.spinner-small{width:32px;height:32px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--accent, #6366f1);border-radius:50%;animation:horizons-spin .8s linear infinite}@keyframes horizons-spin{to{transform:rotate(360deg)}}.student-dashboard{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;padding-bottom:80px}.student-horizons-page{padding-bottom:0}.student-horizons-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px));min-height:56px;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e5e7eb}.student-horizons-back{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .5rem;border:none;background:transparent;color:#64748b;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:8px}.student-horizons-back:hover{background:#f1f5f9;color:#1e293b}.student-horizons-back svg{flex-shrink:0}.student-horizons-title{margin:0;font-size:1.2rem;font-weight:700;color:#1e293b}.student-horizons-main{padding:1rem 1.25rem 1.5rem;overflow-y:auto}.preview-banner{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;font-weight:600;box-shadow:0 2px 8px #fbbf244d;position:sticky;top:0;z-index:200}.preview-banner-content{display:flex;align-items:center;gap:.75rem;font-size:.875rem;flex-wrap:wrap}.preview-scenario-label{display:inline-flex;align-items:center;gap:.5rem;font-weight:600}.preview-scenario-select{padding:.35rem .6rem;border-radius:6px;border:1px solid rgba(120,53,15,.4);background:#fffffff2;color:#78350f;font-size:.8rem;font-weight:600;cursor:pointer;min-width:160px}.preview-scenario-select:hover,.preview-scenario-select:focus{border-color:#78350f;outline:none}.preview-back-btn{padding:.5rem 1rem;background:#78350f;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.preview-back-btn:hover{background:#92400e;transform:translateY(-1px)}.horizons-panel-overlay{position:fixed;inset:0;background:#00000080;z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:1rem;overflow-y:auto}.horizons-panel{background:#fff;border-radius:20px;box-shadow:0 12px 48px #0003;width:100%;max-width:640px;min-height:60vh;display:flex;flex-direction:column}.horizons-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.horizons-panel-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.horizons-panel-close{width:40px;height:40px;border:none;background:transparent;color:#64748b;font-size:1.75rem;line-height:1;cursor:pointer;border-radius:10px}.horizons-panel-close:hover{background:#f1f5f9;color:#1e293b}.horizons-panel-content{padding:1rem 1.25rem 1.5rem;overflow-y:auto;flex:1}.student-header{position:sticky;top:0;background:#fffffffa;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid #e5e7eb;padding:.75rem 1.25rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px));min-height:56px;display:flex;align-items:center;z-index:100;box-shadow:0 1px 3px #0000000d;transition:border-color .2s ease,box-shadow .2s ease}.student-header--campaign{border-bottom-color:#a78bfa;box-shadow:0 2px 8px #a78bfa1f}.student-header--free-mode{border-bottom-color:#34d399;box-shadow:0 2px 8px #34d3991f}.student-header--progress{border-bottom-color:#60a5fa;box-shadow:0 2px 8px #60a5fa1f}.student-header--profile{border-bottom-color:#f472b6;box-shadow:0 2px 8px #f472b61f}.student-header--home{border-bottom-color:#e5e7eb}.student-header--codex{border-bottom-color:#94a3b8;box-shadow:0 2px 8px #64748b1a}.student-header--horizons .student-header-left{flex-shrink:0}.student-header-back{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .5rem;border:none;background:transparent;color:#64748b;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:8px}.student-header-back:hover{background:#f1f5f9;color:#1e293b}.student-header-back svg{flex-shrink:0}.student-header-center--title-only{flex:1;min-width:0;justify-content:center}.student-header-page-title{margin:0;font-size:1.2rem;font-weight:700;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-header--debutant .student-header-pill--level{background:#f1f5f9;color:#64748b}.student-header--regulier .student-header-pill--level{background:#e0e7ff;color:#4338ca}.student-header--assidu .student-header-pill--level{background:#ddd6fe;color:#5b21b6}.student-header-tier-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em;margin:.125rem 0 0}.student-header-content{width:100%;max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:.75rem 1rem;flex-wrap:wrap}.student-header-left{display:flex;align-items:center;gap:.5rem;min-width:0}.student-header-brand{font-size:1.125rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;flex-shrink:0;border:none;cursor:pointer;padding:0}.student-header-brand:hover{opacity:.9}.student-header-guest-badge{font-size:.6875rem;font-weight:600;color:#b45309;padding:.2rem .45rem;background:#fef3c7;border-radius:6px;white-space:nowrap}.student-header-center{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex-shrink:0}.student-header-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;background:#f1f5f9;border-radius:999px;font-size:.8125rem;font-weight:600;color:#475569}.student-header-pill--level{position:relative;overflow:hidden;padding-right:.5rem}.student-header-xp-bar-wrap{position:absolute;bottom:0;left:0;right:0;height:3px;background:#00000014;border-radius:0 0 999px 999px;overflow:hidden}.student-header-xp-bar{display:block;height:100%;background:currentColor;opacity:.5;border-radius:0 0 999px 999px;transition:width .3s ease}.student-header-pill-icon{font-size:1rem}.student-header-pill--streak-animate .student-header-pill-icon--flame{animation:student-streak-pulse 1.2s ease-out 1}@keyframes student-streak-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.9}to{transform:scale(1);opacity:1}}.student-header-pill--streak-mid{background:#fef3c7;color:#b45309}.student-header-pill--streak-high{background:#fde68a;color:#92400e}.student-header-streak-record{font-weight:500;opacity:.88;font-size:.92em}.level-up-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:level-up-fadeIn .25s ease-out}@keyframes level-up-fadeIn{0%{opacity:0}to{opacity:1}}.level-up-modal{background:#fff;border-radius:16px;padding:1.5rem 2rem;max-width:320px;text-align:center;box-shadow:0 20px 40px #00000026;animation:level-up-scaleIn .3s ease-out}@keyframes level-up-scaleIn{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.level-up-modal-icon{font-size:2.5rem;margin-bottom:.5rem;line-height:1}.level-up-modal-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .25rem}.level-up-modal-text{font-size:.9375rem;color:#6b7280;margin:0 0 1.25rem}.level-up-modal-close{padding:.5rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.level-up-modal-close:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.student-header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.student-header-cta{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d}.student-header-cta:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.student-header-cta:focus-visible{outline:2px solid #667eea;outline-offset:2px}.student-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%;transition:transform .2s ease}.student-avatar-btn:hover{transform:scale(1.05)}.student-avatar-btn:focus-visible{outline:2px solid #667eea;outline-offset:2px}.student-avatar,.student-avatar-placeholder{width:44px;height:44px;border-radius:50%;border:2px solid #e5e7eb}.student-avatar{-o-object-fit:cover;object-fit:cover}.student-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:600}.student-main{max-width:1200px;margin:0 auto;padding:1.5rem 1.25rem}.student-content{display:flex;flex-direction:column;gap:1.5rem}.latest-exercises-section{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.latest-exercises-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 1rem}.latest-exercises-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;color:#6b7280;font-size:.9375rem}.latest-exercises-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:1rem}.latest-exercises-cta-row{display:flex;flex-wrap:wrap;gap:.75rem;width:100%}.latest-exercises-cta{display:block;flex:1 1 auto;min-width:140px;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.latest-exercises-cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.latest-exercises-cta-secondary{background:transparent;color:#667eea;border:2px solid #667eea}.latest-exercises-cta-secondary:hover{background:#667eea14;box-shadow:0 2px 8px #667eea33}.student-devoirs-section{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.student-devoirs-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 1rem}.student-devoirs-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem;color:#6b7280;font-size:.9375rem}.student-devoirs-empty{color:#6b7280;font-size:.9375rem;margin:0}.student-devoirs-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.student-devoirs-filter-chip{padding:.45rem .75rem;background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe;border-radius:999px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease}.student-devoirs-filter-chip:hover{background:#e0e7ff;border-color:#a5b4fc}.student-devoirs-filter-chip.is-active{background:#4f46e5;border-color:#4338ca;color:#fff;box-shadow:0 0 0 2px #4f46e533}.student-devoirs-filter-chip-secondary{background:#f8fafc;color:#475569;border-color:#cbd5e1}.student-devoirs-filter-chip-secondary:hover{background:#f1f5f9;border-color:#94a3b8}.student-devoirs-filter-chip-secondary.is-active{background:#334155;border-color:#1e293b;color:#fff;box-shadow:0 0 0 2px #33415533}.student-devoirs-filter-summary{margin:0 0 .75rem;color:#64748b;font-size:.8125rem;font-weight:500}.student-devoirs-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.student-devoirs-item{margin:0}.student-devoirs-card{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;padding:.75rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;text-align:left;font-size:.9375rem;transition:background .2s,border-color .2s}.student-devoirs-card:hover{background:#f3f4f6;border-color:#667eea}.student-devoirs-card-title{font-weight:600;color:#111827;flex:1;min-width:0}.student-devoirs-card-due{color:#6b7280;font-size:.875rem}.student-devoirs-card-status{font-size:.8125rem;font-weight:500;padding:.2rem .5rem;border-radius:6px}.student-devoirs-card-status.done{background:#d1fae5;color:#065f46}.student-devoirs-card-status.todo{background:#fef3c7;color:#92400e}.campaign-tab-content{padding-top:0}.campaign-subtabs{display:flex;gap:.5rem;padding:.5rem 0 .75rem;margin-bottom:.25rem}.campaign-subtab{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#6b7280;background:#f3f4f6;border:1.5px solid transparent;border-radius:9999px;cursor:pointer;transition:all .2s ease;white-space:nowrap;line-height:1.2}.campaign-subtab svg{flex-shrink:0;opacity:.5;transition:opacity .2s}.campaign-subtab:hover{color:#374151;background:#e5e7eb}.campaign-subtab.active{color:#667eea;background:#eef2ff;border-color:#c7d2fe}.campaign-subtab.active svg{opacity:1;stroke:#667eea}.campaign-tab-guest{text-align:center;padding:2rem;background:#fff;border-radius:20px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.campaign-tab-guest p{margin:0 0 1rem;color:#6b7280;font-size:1rem}.campaign-map-wrap{width:100%}@media(min-width:900px){.campaign-map-wrap{width:100vw;margin-left:calc(-50vw + 50%);padding-left:1.5rem;padding-right:1.5rem;box-sizing:border-box}}.training-section{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.section-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem;letter-spacing:-.5px}.section-subtitle{font-size:.9375rem;color:#6b7280;margin:0 0 1.5rem}.filters-container{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.75rem}.filter-label{font-size:.875rem;font-weight:600;color:#374151}.chips-container{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:none;-ms-overflow-style:none}.chips-container::-webkit-scrollbar{display:none}.chip{padding:.625rem 1rem;background:#f3f4f6;border:2px solid transparent;border-radius:20px;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.chip:hover{background:#e5e7eb}.chip-active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.chip-more{background:#e5e7eb;color:#6b7280}.difficulty-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.difficulty-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;cursor:pointer;transition:all .2s ease}.difficulty-card:hover{border-color:#d1d5db;transform:translateY(-2px)}.difficulty-card-active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.difficulty-icon{font-size:1.5rem}.difficulty-label{font-size:.75rem;font-weight:600;color:#374151;text-transform:capitalize}.difficulty-card-active .difficulty-label{color:#667eea}.chord-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.chord-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;cursor:pointer;transition:all .2s ease;text-align:left}.chord-card:hover{border-color:#d1d5db;transform:translateY(-2px)}.chord-card-active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.chord-icon{font-size:1.5rem;flex-shrink:0}.chord-label{font-size:.875rem;font-weight:600;color:#374151}.chord-card-active .chord-label{color:#667eea}.training-cta{width:100%;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #667eea66;display:flex;align-items:center;justify-content:center;gap:.75rem}.training-cta:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #667eea80}.training-cta:active:not(:disabled){transform:translateY(0)}.training-cta:disabled{opacity:.7;cursor:not-allowed}.training-cta svg{flex-shrink:0}.code-section{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.code-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 .25rem}.code-subtitle{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.code-form{display:flex;flex-direction:column;gap:.75rem}.code-input-wrapper{display:flex;align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;padding:.75rem 1rem;transition:all .2s ease}.code-input-wrapper:focus-within{border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.code-input{flex:1;background:none;border:none;font-size:1rem;font-family:Courier New,monospace;color:#111827;outline:none;letter-spacing:1px}.code-input::-moz-placeholder{color:#9ca3af;letter-spacing:0}.code-input::placeholder{color:#9ca3af;letter-spacing:0}.code-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:.625rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #667eea59}.code-submit-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.code-error{color:#ef4444;font-size:.875rem;font-weight:500;margin:0}.progression-section{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.progress-chart-section,.progress-section-card{margin-bottom:2rem;background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.progress-section-card:last-child{margin-bottom:0}.progress-section-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 1rem}.progress-section-desc{font-size:.9rem;color:#6b7280;margin:0 0 .5rem}.progress-section-meta{font-size:.85rem;color:#9ca3af;margin:0 0 .75rem}.progress-section-cta{padding:.5rem 1rem;border-radius:12px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;cursor:pointer}.progress-section-cta:hover{filter:brightness(1.05)}.loading-state{text-align:center;padding:3rem 1rem;color:#6b7280}.loading-state .spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.empty-state{text-align:center;padding:3rem 1rem}.empty-illustration{font-size:4rem;margin-bottom:1rem}.empty-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 .5rem}.empty-text{font-size:.9375rem;color:#6b7280;margin:0 0 1.5rem;line-height:1.6}.empty-cta{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.empty-cta:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.attempts-list{display:flex;flex-direction:column;gap:1rem}.attempt-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:20px;padding:1.25rem;transition:all .2s ease}.attempt-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.attempt-card-clickable{cursor:pointer}.attempt-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.attempt-info{flex:1}.attempt-title{font-size:1rem;font-weight:700;color:#111827;margin:0 0 .25rem}.attempt-date{font-size:.8125rem;color:#6b7280;margin:0}.attempt-score{font-size:1.5rem;font-weight:700;padding:.5rem 1rem;border-radius:16px;white-space:nowrap}.attempt-score-high{color:#10b981;background:#10b9811a}.attempt-score-medium{color:#f59e0b;background:#f59e0b1a}.attempt-score-low{color:#ef4444;background:#ef44441a}.attempt-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid #e5e7eb}.attempt-stats{font-size:.875rem;color:#6b7280;font-weight:500}.attempt-xp{font-size:.875rem;color:#10b981;font-weight:700}.attempts-list--compact{gap:.5rem}.attempt-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.625rem .75rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;transition:border-color .2s ease,box-shadow .2s ease}.attempt-row:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.attempt-row-clickable{cursor:pointer}.attempt-row-clickable:focus-visible{outline:2px solid #667eea;outline-offset:2px}.attempt-row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.attempt-row-title{font-size:.9375rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attempt-row-meta{font-size:.8125rem;color:#6b7280}.attempt-row-xp{color:#10b981;font-weight:600}.attempt-row-score{flex-shrink:0;font-size:1rem;font-weight:700;padding:.25rem .5rem;border-radius:8px;white-space:nowrap}.attempt-row-score.attempt-score-high{color:#10b981;background:#10b9811a}.attempt-row-score.attempt-score-medium{color:#f59e0b;background:#f59e0b1a}.attempt-row-score.attempt-score-low{color:#ef4444;background:#ef44441a}.progress-history-see-more{display:block;width:100%;margin-top:.75rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#667eea;background:transparent;border:1px solid rgba(102,126,234,.4);border-radius:12px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.progress-history-see-more:hover{background:#667eea14;border-color:#667eea}.profile-section{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.guest-connect-card{text-align:center;padding:2rem 1rem}.guest-illustration{font-size:4rem;margin-bottom:1rem}.guest-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .75rem}.guest-text{font-size:.9375rem;color:#6b7280;margin:0 0 1.5rem;line-height:1.6}.guest-connect-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d;margin-bottom:.75rem}.guest-connect-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.guest-exit-btn{width:100%;padding:.875rem 1.5rem;background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;border-radius:16px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.guest-exit-btn:hover{background:#e5e7eb;color:#374151}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-header{text-align:center}.profile-avatar,.profile-avatar-placeholder{width:80px;height:80px;border-radius:50%;margin:0 auto 1rem;border:4px solid #e5e7eb}.profile-avatar{-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.profile-name{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .25rem}.profile-role{font-size:.9375rem;color:#6b7280;margin:0}.profile-stats-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.profile-stats-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.profile-logout-btn{width:100%;padding:.875rem 1.5rem;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:16px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.profile-logout-btn:hover{background:#fee2e2;border-color:#fca5a5}.profile-logout-btn svg{flex-shrink:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;align-items:center;padding:.5rem 0;z-index:1000;box-shadow:0 -2px 8px #0000000d}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;background:none;border:none;color:#9ca3af;cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:500;flex:1}.nav-item svg{flex-shrink:0}.nav-item:hover,.nav-item-active{color:#667eea}.nav-item-active svg{stroke-width:2.5}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(min-width:768px){.student-main{padding:2rem 1.5rem}.student-content{gap:2rem}.difficulty-cards,.chord-cards{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.student-header-content{flex-wrap:wrap;gap:.5rem}.student-header-left{min-width:0}.student-header-right,.student-header-center{flex-shrink:0}.student-header-cta{font-size:.85rem;padding:.45rem .85rem}}@media(max-width:480px){.student-header{padding:.625rem 1rem;padding-top:calc(.625rem + env(safe-area-inset-top,0px));min-height:52px}.student-header-left{flex-wrap:wrap;gap:.5rem;min-width:0}.student-header-brand{font-size:1rem}.student-header-pill{padding:.3rem .5rem;font-size:.75rem}.student-header-cta{font-size:.8125rem;padding:.4rem .75rem}.student-main{padding:1.25rem 1rem}.difficulty-cards{grid-template-columns:repeat(2,1fr)}.chord-cards{grid-template-columns:1fr}.nav-item span{font-size:.6875rem}}.profile-page{gap:2rem}.profile-top-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.profile-back-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;color:#475569;cursor:pointer;transition:background .2s ease,color .2s ease;box-shadow:0 1px 2px #0000000a}.profile-back-btn:hover{background:#f8fafc;color:#1e293b}.profile-back-btn:focus-visible{outline:2px solid #667eea;outline-offset:2px}.profile-top-bar-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0;letter-spacing:-.02em}.profile-loading{text-align:center;padding:3rem 1rem;color:#6b7280}.profile-loading .spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.profile-header-section{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.profile-header-gamification{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.profile-avatar-container{flex-shrink:0}.profile-page-avatar,.profile-page-avatar-placeholder{width:100px;height:100px;border-radius:50%;border:4px solid #e5e7eb;box-shadow:0 4px 12px #0000001a}.profile-page-avatar{-o-object-fit:cover;object-fit:cover}.profile-page-avatar-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700}.profile-header-info{flex:1}.profile-page-name{font-size:1.75rem;font-weight:700;color:#111827;margin:0 0 .75rem;letter-spacing:-.5px}.profile-header-stats{display:flex;gap:2rem;flex-wrap:wrap;padding:1rem 0;margin-top:.5rem;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.profile-stat-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem 1rem;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb;min-width:80px}.profile-stat-label{font-size:.875rem;color:#6b7280;font-weight:500;display:flex;align-items:center;gap:.5rem}.streak-label{display:flex;align-items:center;gap:.5rem}.streak-icon{font-size:1.125rem}.profile-stat-value{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-big-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.big-stat-card{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.2);border-radius:16px;padding:1.5rem;text-align:center;transition:all .2s ease}.big-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.big-stat-value{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.big-stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.profile-inline-avatar-edit{display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-page-change-avatar-btn{font-size:.85rem;font-weight:600;color:#fff;background:#6366f159;border:1px solid rgba(99,102,241,.65);border-radius:8px;cursor:pointer;padding:.4rem .85rem;transition:background .2s,border-color .2s}.profile-page-change-avatar-btn:hover{background:#6366f180;border-color:#818cf8}.profile-inline-avatar-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden;clip:rect(0,0,0,0)}.profile-inline-avatar-btn{font-size:.85rem;font-weight:500;color:#6366f1;background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;text-decoration:underline;text-underline-offset:2px}.profile-inline-avatar-btn:hover:not(:disabled){color:#4f46e5}.profile-inline-avatar-btn:disabled{opacity:.7;cursor:not-allowed}.profile-inline-avatar-error{margin:0;font-size:.8rem;color:#dc2626;text-align:center}.profile-inline-name-edit{margin-bottom:.25rem}.profile-inline-name-edit .profile-page-name{margin:0 0 .25rem}.profile-inline-name-edit-btn{font-size:.85rem;font-weight:500;color:#6366f1;background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;text-decoration:underline;text-underline-offset:2px}.profile-inline-name-edit-btn:hover{color:#4f46e5}.profile-inline-name-input{display:block;width:100%;max-width:260px;padding:.5rem .75rem;font-size:1rem;color:#111827;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:.5rem}.profile-inline-name-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.profile-inline-name-actions{display:flex;gap:.5rem;flex-wrap:wrap}.profile-inline-name-save{padding:.35rem .75rem;font-size:.85rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;cursor:pointer}.profile-inline-name-save:hover:not(:disabled){opacity:.95}.profile-inline-name-save:disabled{opacity:.7;cursor:not-allowed}.profile-inline-name-cancel{padding:.35rem .75rem;font-size:.85rem;font-weight:500;color:#6b7280;background:transparent;border:1px solid #d1d5db;border-radius:8px;cursor:pointer}.profile-inline-name-cancel:hover:not(:disabled){background:#f3f4f6;color:#374151}.profile-inline-name-error{margin:.5rem 0 0;font-size:.8rem;color:#dc2626}.profile-section-card{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 1px 3px #0000000a,0 6px 16px #0000000f;border:1px solid rgba(0,0,0,.06)}.profile-section-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 1.5rem;letter-spacing:-.5px}.profile-establishment-section .profile-section-title{margin-bottom:.5rem}.profile-establishment-hint{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.profile-establishment-fields{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-establishment-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.375rem}.profile-establishment-field select{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;color-scheme:light}.profile-establishment-field select option{background:#fff;color:#111827}.profile-establishment-field select:focus{outline:none;border-color:#667eea}.profile-establishment-request-links{margin:1rem 0 0;font-size:.875rem;color:#6b7280}.profile-establishment-request-link{background:none;border:none;padding:0;font-size:inherit;color:#667eea;cursor:pointer;text-decoration:underline}.profile-establishment-request-link:hover{color:#5a67d8}.profile-teacher-class-section .profile-section-title{margin-bottom:.5rem}.profile-teacher-class-hint,.profile-teacher-class-joined{font-size:.875rem;color:#6b7280;margin:0 0 .75rem}.profile-teacher-class-joined strong{color:#111827}.profile-teacher-class-join-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.profile-teacher-class-code-input{flex:1;min-width:140px;padding:.5rem .75rem;font-size:1rem;border:1px solid #d1d5db;border-radius:8px;letter-spacing:.05em}.profile-teacher-class-code-input:focus{outline:none;border-color:#667eea}.profile-teacher-class-join-btn{padding:.5rem 1rem;font-size:.9375rem;font-weight:500;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer}.profile-teacher-class-join-btn:hover:not(:disabled){filter:brightness(1.05)}.profile-teacher-class-join-btn:disabled{opacity:.6;cursor:not-allowed}.profile-teacher-class-leave{padding:.4rem .8rem;font-size:.875rem;background:transparent;color:#6b7280;border:1px solid #d1d5db;border-radius:8px;cursor:pointer}.profile-teacher-class-leave:hover:not(:disabled){color:#dc2626;border-color:#dc2626}.profile-teacher-class-leave:disabled{opacity:.6;cursor:not-allowed}.profile-teacher-class-error{font-size:.875rem;color:#dc2626;margin:.5rem 0 0}@media(max-width:600px){.profile-establishment-fields{grid-template-columns:1fr}}.tactical-analysis{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.tactical-card{border-radius:16px;padding:1.5rem;display:flex;gap:1rem;transition:all .2s ease}.tactical-card-strong{background:linear-gradient(135deg,#10b9811a,#0596691a);border:2px solid rgba(16,185,129,.3)}.tactical-card-weak{background:linear-gradient(135deg,#ef44441a,#dc26261a);border:2px solid rgba(239,68,68,.3)}.tactical-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tactical-card-icon{font-size:2.5rem;flex-shrink:0}.tactical-card-content{flex:1}.tactical-card-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 .75rem}.tactical-card-item .degree-roman{font-family:Cinzel,Times New Roman,serif;font-weight:600;letter-spacing:.02em}.tactical-card-item{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .5rem}.tactical-card-percentage{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.tactical-card-action{padding:.625rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #667eea4d}.tactical-card-action:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.performance-details{display:flex;flex-direction:column;gap:1rem}.performance-category{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.performance-category-header{width:100%;padding:1rem 1.5rem;background:none;border:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s ease;text-align:left}.performance-category-header:hover{background:#f3f4f6}.performance-category-title{font-size:1rem;font-weight:700;color:#111827}.performance-category-icon{font-size:.875rem;color:#6b7280}.performance-category-content{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.performance-stat-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.performance-stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.performance-stat-name{font-size:1rem;font-weight:700;color:#111827}.performance-stat-percentage{font-size:1rem;font-weight:700}.performance-stat-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.performance-stat-fill{height:100%;transition:width .3s ease;border-radius:4px}.performance-stat-detail{font-size:.8125rem;color:#6b7280}.performance-empty{text-align:center;padding:2rem 1rem;color:#6b7280;font-size:.875rem}@media(max-width:768px){.profile-header-gamification{flex-direction:column;text-align:center}.profile-header-stats{justify-content:center}.profile-big-stats,.tactical-analysis{grid-template-columns:1fr}.profile-section-card{padding:1.5rem}.profile-page-name{font-size:1.5rem}.profile-page-avatar,.profile-page-avatar-placeholder{width:80px;height:80px}}@media(max-width:480px){.profile-header-section{padding:1.5rem}.profile-section-card{padding:1.25rem}.profile-section-title{font-size:1.25rem}}.student-detail-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000}.student-detail-modal-container{background:#fff;border-radius:12px;max-width:560px;width:90%;max-height:90vh;overflow:auto;box-shadow:0 20px 40px #00000026}.student-detail-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.student-detail-modal-header h2{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.student-detail-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0 .25rem;line-height:1}.student-detail-modal-close:hover{color:#111827}.student-detail-modal-loading{padding:2rem;text-align:center;color:#6b7280}.student-detail-modal-loading .spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.student-detail-modal-content{padding:1.25rem}.student-detail-info h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#111827}.student-detail-meta{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;font-size:.875rem;color:#6b7280;margin:0 0 1rem}.student-detail-stats-row{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.875rem;color:#374151;margin-bottom:1rem}.student-detail-performance{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.student-catalogue-page{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.student-catalogue-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem}.student-catalogue-back{background:none;border:none;color:#667eea;font-size:.9375rem;cursor:pointer;padding:0;margin-bottom:.5rem}.student-catalogue-back:hover{text-decoration:underline}.student-catalogue-title{margin:0;font-size:1.5rem;font-weight:700;color:#111827}.student-catalogue-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb}.student-catalogue-filter-scope{display:flex;gap:0;margin-right:.5rem}.student-catalogue-scope-tab{padding:.5rem 1rem;font-size:.9375rem;font-weight:500;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer}.student-catalogue-scope-tab:first-of-type{border-radius:8px 0 0 8px;border-right:none}.student-catalogue-scope-tab:last-of-type{border-radius:0 8px 8px 0}.student-catalogue-scope-tab:hover{background:#f9fafb}.student-catalogue-scope-tab.active{background:#667eea;border-color:#667eea;color:#fff}.student-catalogue-filters label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:500;color:#374151}.student-catalogue-filters select{padding:.5rem .75rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;min-width:200px;background:#fff;color:#111827;color-scheme:light}.student-catalogue-filters select option{background:#fff;color:#111827}.student-catalogue-pending{padding:1rem 2rem;background:#fffbeb;border-bottom:1px solid #fcd34d}.student-catalogue-pending h2{margin:0 0 .75rem;font-size:1.125rem;font-weight:600;color:#92400e}.student-catalogue-pending h3{margin:.5rem 0 .25rem;font-size:1rem;font-weight:600;color:#b45309}.student-catalogue-pending-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:.75rem}.student-catalogue-pending-select-all{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:#374151;cursor:pointer}.student-catalogue-pending-toolbar button{padding:.375rem .75rem;font-size:.875rem;border-radius:6px;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#374151}.student-catalogue-pending-toolbar button:hover:not(:disabled){background:#f3f4f6}.student-catalogue-pending-toolbar button.danger{color:#dc2626;border-color:#fca5a5}.student-catalogue-pending-toolbar button.danger:hover:not(:disabled){background:#fef2f2}.student-catalogue-pending-block ul{list-style:none;margin:0;padding:0}.student-catalogue-pending-checkbox{flex-shrink:0;margin:0;cursor:pointer}.student-catalogue-pending-item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.student-catalogue-pending-value{font-size:.9375rem;color:#374151;min-width:120px}.student-catalogue-pending-input{flex:1;min-width:180px;padding:.375rem .5rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:6px}.student-catalogue-pending-actions{display:flex;gap:.5rem}.student-catalogue-pending-actions button{padding:.375rem .75rem;font-size:.875rem;border-radius:6px;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#374151}.student-catalogue-pending-actions button:hover:not(:disabled){background:#f3f4f6}.student-catalogue-pending-actions button:first-child{background:#667eea;border-color:#667eea;color:#fff}.student-catalogue-pending-actions button.danger{color:#dc2626;border-color:#fca5a5}.student-catalogue-pending-actions button.danger:hover:not(:disabled){background:#fef2f2}.student-catalogue-list{padding:1.5rem 2rem}.student-catalogue-loading,.student-catalogue-loading-small{text-align:center;color:#6b7280;padding:2rem}.student-catalogue-loading .spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:student-catalogue-spin .8s linear infinite;margin:0 auto 1rem}@keyframes student-catalogue-spin{to{transform:rotate(360deg)}}.student-catalogue-empty{text-align:center;color:#6b7280;padding:2rem}.student-catalogue-table-wrap{overflow-x:auto;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.student-catalogue-table{width:100%;border-collapse:collapse}.student-catalogue-table th,.student-catalogue-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}.student-catalogue-table th{font-size:.8125rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.student-catalogue-table td{font-size:.9375rem;color:#374151}.student-catalogue-row{cursor:pointer;transition:background .15s}.student-catalogue-row:hover{background:#f9fafb}.student-catalogue-pagination{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.student-catalogue-pagination button{padding:.5rem 1rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;cursor:pointer}.student-catalogue-pagination button:hover:not(:disabled){background:#f3f4f6}.student-catalogue-pagination button:disabled{opacity:.5;cursor:not-allowed}.teacher-detail-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000}.teacher-detail-modal-container{background:#fff;border-radius:12px;max-width:480px;width:90%;box-shadow:0 20px 40px #00000026}.teacher-detail-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.teacher-detail-modal-header h2{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.teacher-detail-modal-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0 .25rem;line-height:1}.teacher-detail-modal-close:hover{color:#111827}.teacher-detail-modal-content{padding:1.25rem}.teacher-detail-modal-content h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#111827}.teacher-detail-email{font-size:.9375rem;color:#6b7280;margin:0 0 1rem}.teacher-detail-mailto{display:inline-block;padding:.5rem 1rem;font-size:.9375rem;background:#667eea;color:#fff;border-radius:8px;text-decoration:none;border:none;cursor:pointer}.teacher-detail-mailto:hover{background:#5a67d8}.teacher-detail-contact-block{margin-top:1rem;margin-bottom:1rem}.teacher-detail-contact-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.teacher-detail-copy-email{padding:.5rem 1rem;font-size:.9375rem;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;cursor:pointer}.teacher-detail-copy-email:hover{background:#e5e7eb}.teacher-detail-block{margin-bottom:1rem}.teacher-detail-label{display:block;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.teacher-detail-badges{display:flex;flex-wrap:wrap;gap:.5rem}.teacher-detail-badge{display:inline-block;padding:.35rem .75rem;font-size:.875rem;background:#f3f4f6;color:#374151;border-radius:8px}.teacher-catalogue-page{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.teacher-catalogue-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 2rem}.teacher-catalogue-back{background:none;border:none;color:#667eea;font-size:.9375rem;cursor:pointer;padding:0;margin-bottom:.5rem}.teacher-catalogue-back:hover{text-decoration:underline}.teacher-catalogue-title{margin:0;font-size:1.5rem;font-weight:700;color:#111827}.teacher-catalogue-list{padding:1.5rem 2rem}.teacher-catalogue-loading{text-align:center;color:#6b7280;padding:2rem}.teacher-catalogue-loading .spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:teacher-catalogue-spin .8s linear infinite;margin:0 auto 1rem}@keyframes teacher-catalogue-spin{to{transform:rotate(360deg)}}.teacher-catalogue-empty{text-align:center;color:#6b7280;padding:2rem}.teacher-catalogue-table-wrap{overflow-x:auto;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.teacher-catalogue-table{width:100%;border-collapse:collapse}.teacher-catalogue-table th,.teacher-catalogue-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}.teacher-catalogue-table th{font-size:.8125rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.teacher-catalogue-table td{font-size:.9375rem;color:#374151}.teacher-catalogue-row{cursor:pointer;transition:background .15s}.teacher-catalogue-row:hover{background:#f9fafb}.teacher-catalogue-cell-list{max-width:200px;font-size:.875rem;color:#6b7280}.teacher-catalogue-cell-contact{white-space:nowrap}.teacher-catalogue-contact-link{display:inline-block;padding:.35rem .75rem;font-size:.875rem;background:#667eea;color:#fff;border-radius:6px;text-decoration:none}.teacher-catalogue-contact-link:hover{background:#5a67d8}.teacher-catalogue-pagination{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.teacher-catalogue-pagination button{padding:.5rem 1rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;cursor:pointer}.teacher-catalogue-pagination button:hover:not(:disabled){background:#f3f4f6}.teacher-catalogue-pagination button:disabled{opacity:.5;cursor:not-allowed}.teacher-classes-page{max-width:720px;margin:0 auto;padding:1.5rem}.teacher-classes-header{margin-bottom:1.5rem}.teacher-classes-back{background:none;border:none;color:var(--text-secondary, #666);cursor:pointer;font-size:.95rem;margin-bottom:.75rem;padding:0}.teacher-classes-back:hover{color:var(--text-primary, #111);text-decoration:underline}.teacher-classes-title{font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.teacher-classes-intro{color:var(--text-secondary, #666);font-size:.95rem;margin:0}.teacher-classes-actions{margin-bottom:1.5rem}.teacher-classes-btn-create{background:var(--primary, #2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.6rem 1.2rem}.teacher-classes-btn-create:hover{filter:brightness(1.05)}.teacher-classes-create-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.teacher-classes-create-modal{background:var(--bg, #fff);color:#111827;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:1.5rem;width:100%;max-width:400px}.teacher-classes-create-modal h2{margin:0 0 1.25rem;font-size:1.25rem}.teacher-classes-create-modal label{display:block;margin-bottom:1rem;font-size:.9rem;font-weight:500}.teacher-classes-create-modal input{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;background:#fff;color:#111827;border:1px solid var(--border, #ddd);border-radius:6px;font-size:1rem}.teacher-classes-create-modal input::-moz-placeholder{color:#6b7280}.teacher-classes-create-modal input::placeholder{color:#6b7280}.teacher-classes-create-modal select.teacher-classes-create-select{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;background:#fff;color:#111827;border:1px solid var(--border, #ddd);border-radius:6px;font-size:1rem}.teacher-classes-field-hint{display:block;margin-top:.35rem;font-size:.8rem;font-weight:400;color:var(--text-secondary, #6b7280)}.teacher-classes-create-error{color:var(--danger, #dc2626);font-size:.9rem;margin:0 0 .75rem}.teacher-classes-create-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.teacher-classes-create-actions button{padding:.5rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer}.teacher-classes-create-actions button[type=button]{background:transparent;border:1px solid var(--border, #ddd);color:var(--text-primary, #111)}.teacher-classes-create-actions button[type=submit]{background:var(--primary, #2563eb);border:none;color:#fff}.teacher-classes-loading{text-align:center;padding:2rem;color:var(--text-secondary, #666)}.teacher-classes-loading .spinner{margin:0 auto 1rem}.teacher-classes-empty{padding:2rem;text-align:center;color:var(--text-secondary, #666)}.teacher-classes-empty p{margin:0 0 .5rem}.teacher-classes-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.teacher-classes-card{background:var(--card-bg, #f9fafb);color:#111827;border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:1.25rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.teacher-classes-card-main{flex:1;min-width:0}.teacher-classes-card-name{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#111827}.teacher-classes-card-establishment{margin:0 0 .5rem;font-size:.9rem;color:var(--text-secondary, #6b7280)}.teacher-classes-card-code-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.teacher-classes-card-code{background:var(--bg, #fff);border:1px solid var(--border, #e5e7eb);border-radius:4px;padding:.25rem .5rem;font-size:.95rem;letter-spacing:.05em;color:#1f2937}.teacher-classes-copy-btn{background:transparent;border:1px solid var(--border, #ddd);border-radius:4px;padding:.25rem .5rem;font-size:.85rem;color:#374151;cursor:pointer}.teacher-classes-copy-btn:hover{background:var(--bg-hover, #f3f4f6)}.teacher-classes-card-actions{display:flex;align-items:center;gap:.75rem}.teacher-classes-card-edit{background:transparent;border:1px solid var(--border, #ddd);border-radius:6px;color:var(--text-primary, #374151);cursor:pointer;font-size:.85rem;padding:.4rem .8rem}.teacher-classes-card-edit:hover{background:var(--bg-hover, #f3f4f6)}.teacher-classes-card-link{background:var(--primary, #2563eb);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.4rem .8rem}.teacher-classes-card-link:hover{filter:brightness(1.05)}.teacher-classes-card-clear-assignments{background:transparent;border:1px solid #fcd34d;border-radius:6px;color:#92400e;cursor:pointer;font-size:.85rem;padding:.4rem .8rem}.teacher-classes-card-clear-assignments:hover:not(:disabled){background:#fffbeb}.teacher-classes-card-clear-assignments:disabled{opacity:.6;cursor:not-allowed}.teacher-classes-card-delete{background:transparent;border:1px solid var(--border, #ddd);border-radius:6px;color:var(--text-secondary, #666);cursor:pointer;font-size:.85rem;padding:.4rem .8rem}.teacher-classes-card-delete:hover:not(:disabled){color:var(--danger, #dc2626);border-color:var(--danger, #dc2626)}.teacher-classes-card-delete:disabled{opacity:.6;cursor:not-allowed}.teacher-assignments-page{max-width:1000px;margin:0 auto;padding:1.5rem}.teacher-assignments-header{margin-bottom:1rem}.teacher-assignments-back{background:none;border:none;color:#666;cursor:pointer;font-size:.95rem;margin-bottom:.75rem;padding:0}.teacher-assignments-back:hover{color:#111;text-decoration:underline}.teacher-assignments-title{font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.teacher-assignments-intro{color:#666;font-size:.95rem;margin:0}.teacher-assignments-toolbar{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem 1.5rem;margin-bottom:1.25rem;padding:1rem;background:#f3f4f6;border-radius:8px;border:1px solid #e5e7eb}.teacher-assignments-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem}.teacher-assignments-filter-label{font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.02em}.teacher-assignments-select{padding:.4rem .6rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;min-width:120px}.teacher-assignments-clear-class-btn{padding:.4rem .65rem;font-size:.8rem;border:1px solid #d97706;border-radius:6px;background:#fffbeb;color:#92400e;cursor:pointer;white-space:nowrap}.teacher-assignments-clear-class-btn:hover:not(:disabled){background:#fef3c7}.teacher-assignments-clear-class-btn:disabled{opacity:.65;cursor:not-allowed}.teacher-assignments-filter-buttons{display:flex;flex-wrap:wrap;gap:.35rem}.teacher-assignments-filter-btn{padding:.35rem .65rem;font-size:.8rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer}.teacher-assignments-filter-btn:hover{background:#f9fafb}.teacher-assignments-filter-btn.is-active{background:#667eea;border-color:#667eea;color:#fff}.teacher-assignments-sort-group{display:flex;align-items:center;gap:.5rem}.teacher-assignments-sort-order{padding:.4rem .5rem;font-size:1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;line-height:1}.teacher-assignments-sort-order:hover{background:#f9fafb}.teacher-assignments-group-view{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem}.teacher-assignments-view-toggle{display:flex;gap:0}.teacher-assignments-view-toggle button{padding:.35rem .65rem;font-size:.8rem;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer}.teacher-assignments-view-toggle button:first-child{border-radius:6px 0 0 6px}.teacher-assignments-view-toggle button:last-child{border-radius:0 6px 6px 0;margin-left:-1px}.teacher-assignments-view-toggle button.is-active{background:#667eea;border-color:#667eea;color:#fff;z-index:1}.teacher-assignments-empty-inline{margin:1rem 0;padding:1rem;text-align:center;color:#6b7280;background:#f9fafb;border-radius:8px}.teacher-assignments-group{margin-bottom:1.5rem}.teacher-assignments-group-title{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .75rem;padding-bottom:.35rem;border-bottom:1px solid #e5e7eb}.teacher-assignments-pagination{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;padding:1rem}.teacher-assignments-pagination-btn{padding:.5rem 1rem;font-size:.9rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer}.teacher-assignments-pagination-btn:hover:not(:disabled){background:#f3f4f6}.teacher-assignments-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.teacher-assignments-pagination-info{font-size:.9rem;color:#6b7280}.teacher-assignments-table-wrap{overflow-x:auto;margin-bottom:1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.teacher-assignments-table{width:100%;border-collapse:collapse;font-size:.875rem}.teacher-assignments-table th,.teacher-assignments-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid #e5e7eb;vertical-align:middle}.teacher-assignments-table thead th{background:#f9fafb;font-weight:600;color:#374151}.teacher-assignments-th-btn{background:none;border:none;padding:0;font:inherit;font-weight:600;color:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.teacher-assignments-th-btn:hover{color:#667eea}.teacher-assignments-table tbody tr:hover{background:#f9fafb}.teacher-assignments-table-group-row td{background:#eef2ff;font-weight:600;color:#4338ca}.teacher-assignments-table-detail-row td{background:#f9fafb;padding:.75rem 1rem;vertical-align:top}.teacher-assignments-table-detail{font-size:.85rem}.teacher-assignments-table-detail ul{margin:.5rem 0 0;padding-left:1.25rem;list-style:disc}.teacher-assignments-table-detail li{margin-bottom:.25rem}.teacher-assignments-table td .teacher-assignments-btn-play{padding:.25rem .5rem;font-size:.8rem;margin-right:.25rem}.teacher-assignments-table td button{padding:.25rem .5rem;font-size:.8rem;margin-right:.25rem;margin-bottom:.25rem;border-radius:4px;border:1px solid #d1d5db;background:#fff;cursor:pointer}.teacher-assignments-table td button.danger:hover{color:#dc2626;border-color:#dc2626}@media(max-width:768px){.teacher-assignments-toolbar{flex-direction:column;align-items:stretch}.teacher-assignments-table-wrap{font-size:.8rem}.teacher-assignments-table th,.teacher-assignments-table td{padding:.5rem}}.teacher-assignments-loading{text-align:center;padding:2rem;color:#666}.teacher-assignments-loading .spinner{margin:0 auto 1rem}.teacher-assignments-empty{padding:2rem;text-align:center;color:#666}.teacher-assignments-empty p{margin:0 0 .5rem}.teacher-assignments-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.teacher-assignments-list--nested{margin-top:.5rem;gap:.5rem}.teacher-assignments-card{background:#f9fafb;color:#111827;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.teacher-assignments-card--nested{padding:.75rem}.teacher-assignments-card-main{flex:1 1 280px;min-width:0}.teacher-assignments-thumbnails{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.teacher-assignments-thumbnail-wrap{position:relative;width:80px;height:45px;flex-shrink:0;border:none;border-radius:6px;overflow:hidden;padding:0;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 1px 3px #00000026}.teacher-assignments-thumbnail-wrap:hover{box-shadow:0 2px 8px #667eea66;transform:scale(1.03)}.teacher-assignments-thumbnail-badge{position:absolute;top:.25rem;left:.25rem;z-index:2;display:flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .25rem;border-radius:50%;font-size:.65rem;font-weight:700;color:#fff;background:#000000a6;box-shadow:0 1px 2px #00000040;pointer-events:none}.teacher-assignments-thumbnail-img{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.teacher-assignments-thumbnail-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3;background:linear-gradient(135deg,#667eea,#764ba2)}.teacher-assignments-card-main--expanded{flex-basis:100%;width:100%}.teacher-assignments-card-title{margin:0 0 .35rem;font-size:1.1rem;font-weight:600;color:#111827}.teacher-assignments-edit-title{width:100%;max-width:280px;padding:.35rem .5rem;background:#fff;color:#111827;border:1px solid #d1d5db;border-radius:6px;font-size:1rem}.teacher-assignments-card-class{font-size:.9rem;color:#6b7280;margin:0 0 .25rem}.teacher-assignments-card-date{font-size:.85rem;color:#6b7280;margin:0}.teacher-assignments-edit-date{padding:.25rem .5rem;background:#fff;color:#111827;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem}.teacher-assignments-card-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex:0 0 auto;margin-left:auto}.teacher-assignments-card-actions button{padding:.4rem .75rem;font-size:.875rem;border-radius:6px;cursor:pointer;background:#fff;border:1px solid #d1d5db;color:#374151}.teacher-assignments-card-actions button:hover:not(:disabled){background:#f3f4f6}.teacher-assignments-card-actions button.teacher-assignments-btn-play{background:#667eea;border-color:#667eea;color:#fff}.teacher-assignments-card-actions button.teacher-assignments-btn-play:hover{filter:brightness(1.05)}.teacher-assignments-card-actions button.danger:hover:not(:disabled){color:#dc2626;border-color:#dc2626}.teacher-assignments-card-actions button:disabled{opacity:.6;cursor:not-allowed}.teacher-skills-heatmap{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}.teacher-skills-heatmap-head{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:10px 12px;font-size:.8rem;color:#6b7280;background:#f9fafb}.teacher-skills-heatmap-list{list-style:none;margin:0;padding:0}.teacher-skills-heatmap-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:10px 12px;border-top:1px solid #f3f4f6;align-items:center}.teacher-skills-heatmap-row.excellent{background:#ecfdf5}.teacher-skills-heatmap-row.correct{background:#f0f9ff}.teacher-skills-heatmap-row.fragile{background:#fffbeb}.teacher-skills-heatmap-row.critical{background:#fef2f2}.teacher-skills-heatmap-label{font-weight:600;color:#111827}.teacher-skills-heatmap-score,.teacher-skills-heatmap-count{font-weight:600;color:#1f2937}.teacher-skills-heatmap-empty{padding:14px;border-radius:12px;border:1px dashed #d1d5db;color:#6b7280}.teacher-insights-page{max-width:1200px;margin:0 auto;padding:20px 16px 40px}.teacher-insights-header{margin-bottom:16px}.teacher-insights-back{border:0;background:transparent;color:#a5b4fc;cursor:pointer;padding:0;margin-bottom:8px;font-weight:600}.teacher-insights-title{margin:0;font-size:1.8rem;color:#f8fafc}.teacher-insights-intro{margin:6px 0 0;color:#cbd5e1}.teacher-insights-filters{position:sticky;top:8px;z-index:3;display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:16px;padding:12px;border:1px solid #e5e7eb;border-radius:12px;background:#fffffff0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.teacher-insights-filters label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:#4b5563}.teacher-insights-filters select,.teacher-insights-filters input,.teacher-insights-filters button{border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;background:#fff;color:#111827}.teacher-insights-note{border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:10px;padding:10px 12px;margin-bottom:10px;font-size:.9rem}.teacher-insights-filters button{cursor:pointer;font-weight:600}.teacher-insights-filters button:disabled{color:#6b7280;background:#f3f4f6}.teacher-insights-loading,.teacher-insights-error,.teacher-insights-empty{border:1px dashed #d1d5db;border-radius:12px;padding:22px;color:#4b5563}.teacher-insights-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:14px}.teacher-insights-kpi-card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.teacher-insights-kpi-card h3{margin:0;font-size:.82rem;color:#6b7280;font-weight:600}.teacher-insights-kpi-card p{margin:8px 0 0;font-size:1.3rem;font-weight:800;color:#111827}.teacher-insights-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px;align-items:start}.teacher-insights-grid-bottom{align-items:start}.teacher-insights-panel{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.teacher-insights-panel h2{margin:0 0 10px;font-size:1.02rem;color:#111827}.teacher-insights-chart{width:100%;height:240px}.teacher-insights-alert-list,.teacher-insights-reco-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.teacher-insights-alert-list li,.teacher-insights-reco-list li{border:1px solid #f1f5f9;border-radius:10px;padding:10px;display:flex;justify-content:space-between;gap:10px;min-width:0;overflow:hidden}.teacher-insights-alert-list strong,.teacher-insights-reco-list strong{color:#111827}.teacher-insights-alert-list span{display:block}.teacher-insights-panel--at-risk .teacher-insights-alert-list--scrollable{max-height:360px;overflow-y:auto;padding-right:4px}.teacher-insights-alert-list small,.teacher-insights-reco-list p{color:#6b7280;margin:4px 0 0}.teacher-insights-reco-assignment-card{width:100%;min-width:0}.teacher-insights-reco-assignment-layout{display:flex;gap:10px;align-items:flex-start;width:100%;min-width:0}.teacher-insights-reco-assignment-content{min-width:0;flex:1}.teacher-insights-reco-assignment-visual{flex:0 0 auto}.teacher-insights-reco-thumb{width:64px;height:64px;-o-object-fit:cover;object-fit:cover;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc}.teacher-insights-reco-thumb--placeholder{display:inline-flex;align-items:center;justify-content:center;color:#6b7280;font-size:1.1rem}.teacher-insights-reco-assignment-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;min-width:0}.teacher-insights-reco-badge{display:inline-flex;align-items:center;border-radius:999px;background:#ede9fe;color:#5b21b6;font-size:.74rem;font-weight:700;padding:2px 8px}.teacher-insights-reco-class{color:#6b7280;font-size:.8rem;max-width:42%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-insights-reco-assignment-title{display:block;color:#111827;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-insights-reco-assignment-metrics{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}.teacher-insights-reco-assignment-metrics span{border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;padding:3px 8px;font-size:.78rem;color:#334155}.teacher-insights-risk{display:inline-block;border-radius:999px;padding:3px 8px;font-size:.75rem;text-transform:uppercase;font-weight:700}.teacher-insights-risk-critique{background:#fee2e2;color:#b91c1c}.teacher-insights-risk-a_surveiller{background:#fef3c7;color:#b45309}.teacher-insights-risk-stable{background:#dcfce7;color:#15803d}.teacher-insights-muted{color:#6b7280}.teacher-insights-table-wrap{overflow-x:auto}.teacher-insights-table{width:100%;border-collapse:collapse}.teacher-insights-table th,.teacher-insights-table td{border-bottom:1px solid #f3f4f6;text-align:left;padding:8px;font-size:.9rem;color:#111827;background:#fff}.teacher-insights-table th{font-size:.78rem;letter-spacing:.02em;text-transform:uppercase;color:#374151;background:#f8fafc;font-weight:700}.teacher-insights-table tbody tr:nth-child(2n) td{background:#f9fafb}.teacher-insights-table tbody tr:hover td{background:#eef2ff}.teacher-insights-student-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin-bottom:10px}.teacher-insights-student-filters label{display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:#4b5563}.teacher-insights-student-filters select,.teacher-insights-student-filters input{border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;background:#fff;color:#111827}@media(max-width:980px){.teacher-insights-grid{grid-template-columns:1fr}}.teacher-live-page{max-width:1100px;margin:0 auto;padding:24px 16px 48px;min-height:100vh;background:#f8f9fa;color:#1f2937}.teacher-live-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.teacher-live-back{border:1px solid #d1d5db;background:#fff;border-radius:10px;padding:8px 12px;cursor:pointer;color:#111827}.teacher-live-panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;margin-bottom:14px;box-shadow:0 4px 12px #0f172a0f}.teacher-live-panel-title{margin:0 0 14px;font-size:1.1rem;font-weight:700;color:#1e293b;letter-spacing:.02em;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.teacher-live-panel-subtitle{margin:0 0 10px;font-size:.95rem;font-weight:600;color:#475569}.teacher-live-ranking-title{display:flex;align-items:center;gap:8px;margin:0;font-size:1.15rem;font-weight:800;color:#0f172a;letter-spacing:.02em}.teacher-live-ranking-title--archived{font-size:1.05rem;font-weight:700;color:#334155}.teacher-live-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.teacher-live-row label{display:flex;flex-direction:column;gap:6px;font-weight:600}.teacher-live-row select,.teacher-live-row input{border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;background:#fff;color:#111827}.teacher-live-context{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;padding:10px 12px;border:1px solid #dbeafe;border-radius:10px;background:#eff6ff}.teacher-live-context span{font-size:.85rem;color:#1e40af}.teacher-live-context strong{color:#1e3a8a}.teacher-live-context .teacher-live-btn{margin-left:auto}.teacher-live-context button:not(.teacher-live-btn){margin-left:auto;border:1px solid #93c5fd;border-radius:8px;background:#fff;color:#1d4ed8;padding:6px 10px;cursor:pointer}.teacher-live-timer-presets{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.teacher-live-timer-presets button{border:1px solid #d1d5db;background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer}.teacher-live-timer-presets button.active{background:#2563eb;color:#fff;border-color:#2563eb}.teacher-live-queue ul,.teacher-live-history{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:8px}.teacher-live-queue li,.teacher-live-history li{display:flex;justify-content:space-between;gap:10px;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;background:#fff;color:#111827}.teacher-live-history-cards{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:10px}.teacher-live-history-card-item{display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff}.teacher-live-history-card-item .teacher-live-history-card{border:none;border-radius:0}.teacher-live-history-card{border:1px solid #e5e7eb;border-radius:12px;padding:10px;background:#fff;display:grid;gap:8px}.teacher-live-history-ranking--below-card{margin-top:0;border-top:1px solid #e5e7eb;padding:12px;background:#f9fafb;scroll-margin-top:.75rem}.teacher-live-ranking-head-actions--archived-inline{display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px}.teacher-live-history-ranking-error{margin-top:8px}.teacher-live-history-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.teacher-live-status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.74rem;font-weight:700}.teacher-live-status-pill.tone-collecting{background:#dbeafe;color:#1d4ed8}.teacher-live-status-pill.tone-correction{background:#fef3c7;color:#92400e}.teacher-live-status-pill.tone-closed{background:#dcfce7;color:#166534}.teacher-live-status-pill.tone-unknown{background:#e5e7eb;color:#374151}.teacher-live-history-meta,.teacher-live-history-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;color:#4b5563;font-size:.9rem}.teacher-live-history-actions{display:flex;flex-wrap:wrap;gap:8px}.teacher-live-history-actions .teacher-live-btn{padding:7px 12px}.teacher-live-history-actions button:not(.teacher-live-btn),.teacher-live-history-more:not(.teacher-live-btn){border:1px solid #d1d5db;border-radius:8px;background:#fff;padding:7px 10px;cursor:pointer;color:#111827}.teacher-live-history-actions button:disabled{opacity:.6;cursor:not-allowed}.teacher-live-history-more{margin-top:10px}.teacher-live-history-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 2px}.teacher-live-history-toolbar .teacher-live-btn{padding:7px 12px}.teacher-live-history-toolbar button:not(.teacher-live-btn){border:1px solid #d1d5db;border-radius:8px;background:#fff;padding:7px 10px;cursor:pointer;color:#111827}.teacher-live-history-ranking{margin-top:12px;border-top:1px solid #e5e7eb;padding-top:12px}.teacher-live-exercise-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin-top:8px}.teacher-live-exercise-list button{text-align:left;border:1px solid #d1d5db;border-radius:8px;background:#fff;padding:8px 10px;cursor:pointer}.teacher-live-primary{margin-top:12px;border:none;border-radius:10px;padding:10px 14px;background:#2563eb;color:#fff;cursor:pointer;font-weight:600}.teacher-live-primary:disabled{opacity:.6;cursor:not-allowed}.teacher-live-note{font-size:.92rem;font-weight:500;color:#4b5563;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:8px 10px}.teacher-live-input-mode{margin-top:10px;border:1px solid #e5e7eb;border-radius:10px;padding:10px;background:#f8fafc}.teacher-live-input-mode-label{display:block;font-weight:700;color:#334155;margin-bottom:8px}.teacher-live-input-mode-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.teacher-live-input-mode-buttons .teacher-live-btn.is-active{border-color:#4f46e5;background:#eef2ff;box-shadow:0 2px 8px #4f46e52e}.teacher-live-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.teacher-live-btn{border-radius:10px;padding:8px 14px;font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.teacher-live-btn:hover:not(:disabled){transform:translateY(-1px)}.teacher-live-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.teacher-live-btn--primary{border:none;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;box-shadow:0 4px 12px #4f46e559}.teacher-live-btn--primary:hover:not(:disabled){box-shadow:0 6px 16px #4f46e573}.teacher-live-btn--secondary{border:1px solid #6366f1;background:#fff;color:#4f46e5}.teacher-live-btn--secondary:hover:not(:disabled){background:#eef2ff}.teacher-live-btn--danger{border:none;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 4px 12px #b91c1c40}.teacher-live-btn--danger:hover:not(:disabled){box-shadow:0 6px 14px #b91c1c59}.teacher-live-btn--ghost{border:1px solid #e2e8f0;background:#f8fafc;color:#64748b}.teacher-live-btn--ghost:hover:not(:disabled){background:#f1f5f9;color:#475569}.teacher-live-actions .teacher-live-projection-btn{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:10px;padding:8px 14px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;font-weight:700;box-shadow:0 6px 16px #1d4ed859}.teacher-live-actions .teacher-live-projection-btn:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 8px 20px #1d4ed866}.teacher-live-actions .teacher-live-projection-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.teacher-live-timer-block{border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb;padding:10px;margin-bottom:10px}.teacher-live-timer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:#111827}.teacher-live-stats-wrap{border-top:1px solid #e5e7eb;padding-top:12px}.teacher-live-stats-wrap--ranking-anchor{scroll-margin-top:1rem}.teacher-live-ranking-head{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center}.teacher-live-ranking-head h3{display:flex;align-items:center;gap:8px;margin:0}.teacher-live-ranking-head-actions,.teacher-live-ranking-scope{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.teacher-live-ranking-scope select{border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;padding:7px 10px}.teacher-live-ranking-scope .teacher-live-btn.is-active{background:#2563eb;border-color:#2563eb;color:#fff}.teacher-live-ranking-head-actions .teacher-live-btn{padding:7px 12px}.teacher-live-ranking-head-actions button:not(.teacher-live-btn),.teacher-live-ranking-empty button,.teacher-live-under-toggle{border:1px solid #d1d5db;border-radius:8px;background:#fff;padding:7px 10px;cursor:pointer;color:#111827}.teacher-live-under-toggle{margin-left:10px}.teacher-live-ranking-badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:700}.teacher-live-ranking-badge.is-provisional{color:#92400e;background:#fef3c7}.teacher-live-ranking-badge.is-final{color:#065f46;background:#d1fae5}.teacher-live-ranking-badge.is-mock{color:#6d28d9;background:#ede9fe}.teacher-live-ranking-kpis{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.teacher-live-ranking-kpis article{border:1px solid #e5e7eb;border-radius:10px;padding:10px;background:#f9fafb;display:flex;flex-direction:column;gap:4px}.teacher-live-ranking-kpis article span{color:#6b7280;font-size:.85rem}.teacher-live-ranking-kpis article strong{font-size:1.15rem}.teacher-live-podium{margin-top:12px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:end;gap:10px}.teacher-live-podium-card{border:1px solid #e5e7eb;border-radius:14px 14px 8px 8px;padding:12px 10px;background:#fff;display:grid;gap:6px;justify-items:center;text-align:center;box-shadow:0 8px 18px #1e293b14}.teacher-live-podium-card.slot-first{min-height:220px;border-color:#f59e0b;background:linear-gradient(180deg,#fef3c7,#fde68a)}.teacher-live-podium-card.slot-second{min-height:190px;border-color:#94a3b8;background:linear-gradient(180deg,#f8fafc,#e2e8f0)}.teacher-live-podium-card.slot-third{min-height:170px;border-color:#f97316;background:linear-gradient(180deg,#ffedd5,#fdba74)}.teacher-live-podium-head{display:inline-flex;align-items:center;gap:6px}.teacher-live-podium-icon{font-size:1.2rem}.teacher-live-podium-avatar{width:44px;height:44px;border-radius:999px;background:linear-gradient(135deg,#4338ca,#7c3aed);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;letter-spacing:.03em}.teacher-live-podium-avatar--photo{padding:0;overflow:hidden;background:#e5e7eb}.teacher-live-podium-avatar--photo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.teacher-live-ranking-student-cell{display:inline-flex;align-items:center;gap:10px;min-width:0}.teacher-live-ranking-student-name{font-weight:600;min-width:0}.teacher-live-ranking-avatar-cell{width:36px;height:36px;border-radius:999px;flex-shrink:0;background:linear-gradient(135deg,#4338ca,#7c3aed);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;letter-spacing:.03em}.teacher-live-ranking-avatar-cell--photo{padding:0;overflow:hidden;background:#e5e7eb}.teacher-live-ranking-avatar-cell--photo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.teacher-live-podium-score{font-size:1.08rem;font-weight:800}.teacher-live-podium-point{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#ffffffb8;color:#312e81;padding:3px 8px;font-size:.76rem;font-weight:700}.teacher-live-podium-rank{font-weight:700;color:#0f172a}.teacher-live-ranking-table-wrap{margin-top:10px;overflow:auto;border:1px solid #e5e7eb;border-radius:10px}.teacher-live-ranking-table{width:100%;border-collapse:collapse;min-width:680px;background:#fff}.teacher-live-ranking-table th,.teacher-live-ranking-table td{padding:10px;border-bottom:1px solid #f1f5f9;text-align:left}.teacher-live-ranking-table th{position:sticky;top:0;background:#f8fafc;z-index:1;font-size:.84rem;letter-spacing:.01em;color:#475569}.teacher-live-ranking-table tr.is-under-threshold{opacity:.8}.teacher-live-score-cell{display:grid;gap:6px}.teacher-live-score-bar{width:140px;height:7px;border-radius:999px;background:#e5e7eb;overflow:hidden}.teacher-live-score-bar>div{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed)}.teacher-live-strong-point .degree-roman,.teacher-live-podium-point .degree-roman{font-family:Cinzel,Times New Roman,serif;font-weight:600;letter-spacing:.02em}.teacher-live-strong-point{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:3px 8px;font-size:.78rem;font-weight:700;color:#6d28d9;background:#f3e8ff}.teacher-live-ranking-empty{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px dashed #d1d5db;border-radius:10px;padding:10px}.teacher-live-ranking-skeleton{margin-top:10px;display:grid;gap:8px}.teacher-live-ranking-skeleton>div{height:38px;border-radius:8px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9);background-size:220% 100%;animation:teacherLiveSkeleton 1.2s linear infinite}@keyframes teacherLiveSkeleton{0%{background-position:100% 0}to{background-position:0 0}}.teacher-live-page--ranking-focus .teacher-live-panel{box-shadow:0 8px 24px #0f172a1f}.teacher-live-page--ranking-focus .teacher-live-ranking-table th,.teacher-live-page--ranking-focus .teacher-live-ranking-table td{font-size:1.02rem}.teacher-live-ranking{list-style:none;padding:0;margin:8px 0;display:grid;gap:6px}.teacher-live-ranking li{border:1px solid #e5e7eb;border-radius:8px;padding:8px 10px;display:flex;justify-content:space-between}.teacher-live-question-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.teacher-live-question-card{border:1px solid #e5e7eb;border-radius:10px;padding:10px}.teacher-live-question-card ul{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:6px}.teacher-live-question-card li{display:flex;justify-content:space-between;gap:8px}.teacher-live-muted{color:#6b7280}.teacher-live-error{color:#b91c1c;font-weight:600;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:8px 10px;margin-bottom:12px}@media(max-width:768px){.teacher-live-row{grid-template-columns:1fr}.teacher-live-input-mode-buttons{flex-direction:column;align-items:stretch}.teacher-live-podium{grid-template-columns:1fr}.teacher-live-ranking-empty{flex-direction:column;align-items:flex-start}}.teacher-live-remote-page{max-width:820px;margin:0 auto;padding:1rem .95rem 1.4rem;display:grid;gap:.85rem;color:#e5e7eb}.teacher-live-remote-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.teacher-live-remote-header h1{margin:0;font-size:1.3rem;color:#f8fafc}.teacher-live-remote-back{border:1px solid #334155;background:linear-gradient(180deg,#1f2937,#111827);color:#f8fafc;border-radius:.65rem;padding:.48rem .76rem;cursor:pointer;font-weight:600}.teacher-live-remote-card{border:1px solid #1f2937;border-radius:.9rem;padding:.9rem;background:linear-gradient(180deg,#0f172a,#111827);box-shadow:0 8px 22px #0000002e}.teacher-live-remote-card h2{margin:0 0 .65rem;font-size:1rem;color:#f8fafc}.teacher-live-remote-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.teacher-live-remote-presets-label{margin:.5rem 0 0;font-size:.82rem;color:#94a3b8;font-weight:600}.teacher-live-remote-presets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;margin-top:.35rem}.teacher-live-remote-presets button{border:1px solid #334155;background:linear-gradient(180deg,#111827,#0b1220);color:#f8fafc;border-radius:.55rem;padding:.62rem .5rem;cursor:pointer;font-weight:600;transition:transform .1s ease,border-color .12s ease}.teacher-live-remote-presets button:hover:not(:disabled){border-color:#60a5fa;transform:translateY(-1px)}.teacher-live-remote-presets button:disabled{opacity:.6;cursor:not-allowed}.teacher-live-remote-presets button.is-active{border-color:#38bdf8;background:linear-gradient(180deg,#0c4a6e,#082f49)}.teacher-live-remote-grid button,.teacher-live-remote-duration button{border:1px solid #334155;background:linear-gradient(180deg,#111827,#0b1220);color:#f8fafc;border-radius:.55rem;padding:.62rem .5rem;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;transition:transform .1s ease,border-color .12s ease,background .12s ease}.teacher-live-remote-grid button:hover,.teacher-live-remote-duration button:hover{border-color:#60a5fa;transform:translateY(-1px)}.teacher-live-remote-grid button:disabled,.teacher-live-remote-duration button:disabled{opacity:.6;cursor:not-allowed}.teacher-live-remote-duration{margin-top:.65rem;display:flex;align-items:center;gap:.55rem}.teacher-live-remote-duration input{width:5.5rem;min-width:0;border:1px solid #334155;color:#f8fafc;background:#0b1220;border-radius:.45rem;padding:.4rem .45rem}.teacher-live-remote-muted{margin:.2rem 0;color:#94a3b8;font-size:.9rem}.teacher-live-remote-error{margin:0;padding:.6rem .75rem;border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;border-radius:.6rem}.teacher-live-remote-loading{display:flex;align-items:center;gap:.6rem}.teacher-live-remote-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.teacher-live-remote-nav .nav-btn{border:1px solid #334155;background:linear-gradient(180deg,#111827,#0b1220);color:#f8fafc;border-radius:.65rem;padding:.7rem .5rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-weight:600;transition:transform .1s ease,border-color .12s ease}.teacher-live-remote-nav .nav-btn:hover{border-color:#60a5fa;transform:translateY(-1px)}.teacher-live-remote-nav .nav-btn.is-primary{border-color:#2563eb;background:linear-gradient(180deg,#1d4ed8,#1e40af)}.teacher-live-remote-nav .nav-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:700px){.teacher-live-remote-nav{grid-template-columns:repeat(2,minmax(0,1fr))}}.editor-root{height:100dvh;height:var(--vvh, 100dvh)}body.editor-active{overflow:hidden!important;position:fixed;width:100%;height:100%;height:100dvh;height:var(--vvh, 100dvh)}@media(orientation:landscape){.editor-video-zone{min-height:140px;max-height:220px}.editor-control-dock{min-height:120px;max-height:180px}}@media(max-height:600px){.editor-video-zone{min-height:140px;max-height:220px}.editor-control-dock{min-height:120px;max-height:180px}}.editor-pedal-strip{position:relative;width:100%;min-height:1.75rem;flex-shrink:0;pointer-events:none;margin-top:4px;padding:0 2px;box-sizing:border-box}.editor-pedal-strip-group{position:absolute;top:0;display:flex;align-items:center;gap:4px;min-height:1.5rem;box-sizing:border-box;padding:0 2px}.editor-pedal-strip-label{flex-shrink:0;font-size:clamp(.9rem,2vw,1.05rem);line-height:1.3;white-space:nowrap;color:#67e8f9;display:inline-flex;align-items:baseline;gap:.15em}.editor-pedal-strip-label-word{font-family:cursive;font-style:italic;font-weight:600}.editor-pedal-strip-label-degree{font-family:Georgia,Times New Roman,serif;font-style:normal;font-variant-numeric:tabular-nums;font-weight:700}.editor-pedal-strip-group .editor-pedal-strip-line{flex:1;min-width:4px;height:2px;margin-left:2px;background:#67e8f9;opacity:.7;border-radius:1px;align-self:center}.editor-timeline-rail,.editor-timeline-empty-rail{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:2px;border-radius:1px;background:#ffffff2e;pointer-events:none;z-index:0}.editor-timeline-segments{display:flex;align-items:stretch}.editor-timeline-segment{position:absolute;top:8px;bottom:8px;min-width:4px;border-radius:6px;cursor:pointer;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;transition:border-color .15s,background .15s;display:flex;align-items:stretch}.editor-timeline-segment:hover{border-color:#ffffff59;background:#ffffff1a}.editor-timeline-segment-selected{border-color:#6366f1cc;background:#6366f133}.editor-timeline-segment-selected:hover{border-color:#6366f1e6;background:#6366f140}.editor-timeline-segment-current{border-color:#fbbf2480;background:#fbbf2414}.editor-timeline-segment-body{position:relative;flex:1;min-width:0;height:100%;border-radius:inherit;overflow:hidden;container-type:inline-size;container-name:segment-body}.editor-timeline-handle{flex-shrink:0;width:8px;min-width:8px;cursor:ew-resize;z-index:2}@media(pointer:coarse){.editor-timeline-handle{width:20px;min-width:20px}}.editor-timeline-boundary{flex-shrink:0;width:6px;min-width:6px;cursor:ew-resize;z-index:2}@media(pointer:coarse){.editor-timeline-boundary{width:20px;min-width:20px}}@media(max-width:767px){.editor-timeline-scroll .editor-timeline-segments{min-height:3.5rem}.editor-timeline-timers{min-height:3rem}.editor-pedal-strip{min-height:1.25rem}}.editor-timeline-segment-progress{position:absolute;top:0;left:0;bottom:0;background:#fbbf244d;transition:width .1s linear;pointer-events:none;z-index:1}.editor-timeline-segment-chord{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;padding:0 4px;overflow:hidden}.editor-timeline-segment-chord-label{font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2;display:flex;align-items:center;justify-content:center}.editor-timeline-segment-degree{font-weight:700;line-height:1.2}.editor-timeline-segment-empty{color:#fff6;line-height:1.2}@container segment-body (min-width: 0px){.editor-timeline-segment-chord-label,.editor-timeline-segment-degree{font-size:clamp(1rem,2.5vw,1.5rem)}.editor-timeline-segment-empty{font-size:clamp(.85rem,2vw,1.2rem)}.editor-timeline-segment-chord-label .chord-label-figure{font-size:.85em}}.editor-timeline-segment-delete{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#ec4899e6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;opacity:.85;transition:opacity .15s,background .15s}.editor-timeline-segment-delete:hover{opacity:1;background:#ec4899}.editor-timeline-segment-t{border-color:#3b82f680;background:#3b82f61f}.editor-timeline-segment-sd{border-color:#8b5cf680;background:#8b5cf61f}.editor-timeline-segment-d{border-color:#ec489980;background:#ec48991f}.editor-timeline-scroll{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent;-webkit-overflow-scrolling:touch}.editor-timeline-scroll::-webkit-scrollbar{height:6px}.editor-timeline-scroll::-webkit-scrollbar-track{background:transparent;border-radius:3px}.editor-timeline-scroll::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.editor-timeline-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff59}.baroque-chord-label{display:inline-flex;align-items:baseline;font-variant-numeric:normal}.chord-label-with-parens{flex-shrink:0;white-space:nowrap}.chord-label-with-parens .chord-label-degree{flex-shrink:0}.chord-label-degree{font-size:1em;line-height:1}.chord-label-figure{font-family:inherit;vertical-align:super;position:relative;top:-.25em;margin-left:.15em;line-height:1}.baroque-chord-label .chord-label-figure{font-size:.65em}.chord-label-figure-stacked{display:flex;flex-direction:column;line-height:.85;align-items:center}.chord-label-figure-stacked span{font-size:1em}.chord-label-pedal{display:inline-flex;flex-direction:column;align-items:center;width:-moz-max-content;width:max-content;line-height:1;gap:0}.chord-label-pedal-top{display:inline-flex;align-items:baseline}.chord-label-pedal-bar{display:block;width:100%;min-width:100%;height:1.5px;background:currentColor;opacity:.85;margin:.15em 0;border:none;border-radius:0}.chord-label-pedal-bottom{font-size:.8em;opacity:.9;line-height:1.1}.chord-label-slash{opacity:.85;margin-left:.05em}.chord-label-borrowed-degree{font-weight:600}.video-cockpit{width:100%;display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:#1e1e1e;border-radius:8px;border:1px solid #2a2a2a}.video-cockpit.student-mode{padding:.75rem;gap:.75rem}@media(min-width:1024px){.video-cockpit{padding:1.5rem;gap:1.25rem}.video-cockpit.student-mode{padding:1rem;gap:1rem}}.cockpit-timeline-wrapper{width:100%}.timeline-loading-state{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;color:#b0b0b0;font-size:.9rem}.loading-spinner{width:20px;height:20px;border:3px solid #3a3a3a;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.cockpit-timeline{position:relative;width:100%;height:56px;background:#2a2a2a;border-radius:6px;cursor:pointer;overflow:hidden;border:2px solid #3a3a3a;touch-action:pan-y}@media(min-width:1024px){.cockpit-timeline{height:60px}}.timeline-inactive{position:absolute;top:0;height:100%;background:#1a1a1a;transition:width .1s ease}.timeline-active{position:absolute;top:0;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:inset 0 0 15px #667eea4d;transition:width .1s ease,left .1s ease}.timeline-handle{position:absolute;top:0;width:20px;height:100%;display:flex;align-items:center;justify-content:center;z-index:5;cursor:ew-resize;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.timeline-handle-start{transform:translate(-50%)}.timeline-handle-end{transform:translate(50%)}.handle-indicator{width:4px;height:100%;background:#fff;box-shadow:0 0 10px #fffc;border-radius:2px;transition:width .2s ease}.timeline-handle:hover .handle-indicator{width:6px;box-shadow:0 0 15px #fee140}.timeline-handle:active .handle-indicator{width:8px;background:#fee140}.handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#fff;border:2px solid #667eea;border-radius:50%;box-shadow:0 2px 8px #00000080;opacity:0;transition:opacity .2s ease}.timeline-handle:hover .handle-grip{opacity:1}.timeline-handle:active .handle-grip{background:#fee140;border-color:#fee140;transform:translate(-50%,-50%) scale(1.2)}.playhead{position:absolute;top:0;width:2px;height:100%;background:#fee140;box-shadow:0 0 10px #fee140cc;z-index:10;pointer-events:none;transform:translate(-50%);transition:left .1s linear}.playhead:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #fee140}.timeline-marker{position:absolute;top:0;width:2px;height:100%;background:#fff;box-shadow:0 0 8px #fffc;z-index:8;pointer-events:none;transform:translate(-50%)}.timeline-marker-outside{opacity:.3;background:#888;box-shadow:0 0 4px #8886}.timeline-marker-question{background:#fbbf24!important;box-shadow:0 0 12px #fbbf24cc!important;width:28px!important;height:28px!important;border-radius:50%;display:flex;align-items:center;justify-content:center;top:50%!important;transform:translate(-50%,-50%);pointer-events:auto!important;z-index:20!important;cursor:pointer}.timeline-marker-question .marker-question{color:#1a1a1a;font-size:1rem;font-weight:700;line-height:1}.timeline-marker-answered{background:#10b981!important;box-shadow:0 0 8px #10b98199!important;width:28px!important;height:28px!important;border-radius:50%;display:flex;align-items:center;justify-content:center;top:50%!important;transform:translate(-50%,-50%);pointer-events:auto!important;z-index:20!important;cursor:pointer}.timeline-marker-answered .marker-checkmark{color:#fff;font-size:1.2rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center}.timeline-marker-clickable{cursor:pointer;transition:all .2s ease;pointer-events:auto!important;z-index:20!important}.timeline-marker-clickable:hover,.timeline-marker-answered.timeline-marker-clickable:hover{transform:translate(-50%,-50%) scale(1.2);box-shadow:0 0 16px #10b981e6!important}.timeline-marker:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid #ffffff}.cockpit-toolbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem;width:100%}@media(max-width:768px){.cockpit-toolbar{grid-template-columns:1fr;gap:1rem}}.toolbar-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.toolbar-group-left{justify-content:flex-start}.toolbar-group-center{justify-content:center;flex-shrink:0}.toolbar-group-right{justify-content:flex-end}.student-toolbar{justify-content:center;width:100%}.cockpit-toolbar.student-mode-toolbar{display:flex;flex-direction:column;gap:.75rem}.duration-info-student{font-size:.95rem;color:#b0b0b0;font-family:Courier New,monospace;padding:.5rem 1rem;background:#667eea1a;border-radius:6px;border:1px solid rgba(102,126,234,.2)}.quit-btn-student{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:2px solid #ef4444;box-shadow:0 2px 8px #ef44444d}.quit-btn-student:hover{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 12px #ef444480;transform:translateY(-1px)}.student-progress-section{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #3a3a3a}.student-progress-bar-wrapper{flex:1;display:flex;flex-direction:column;gap:.5rem}.student-progress-text{font-size:.9rem;color:#b0b0b0;text-align:center}.student-progress-bar{width:100%;height:8px;background:#2a2a2a;border-radius:4px;overflow:hidden;border:1px solid #3a3a3a}.student-progress-fill{height:100%;background:linear-gradient(135deg,#10b981,#059669);transition:width .3s ease;box-shadow:0 0 8px #10b98180}.finish-btn-student{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:2px solid #667eea;box-shadow:0 2px 8px #667eea4d;white-space:nowrap}.finish-btn-student:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 4px 12px #667eea80;transform:translateY(-1px)}@media(max-width:768px){.student-progress-section{flex-direction:column;align-items:stretch}.finish-btn-student{width:100%}.student-toolbar{flex-wrap:wrap;justify-content:center}.quit-btn-student,.play-pause-btn{flex:1;min-width:80px}.toolbar-group-left,.toolbar-group-right{justify-content:center}}.action-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;min-height:44px;display:flex;align-items:center;justify-content:center}@media(min-width:1024px){.action-btn{padding:.875rem 1.75rem;font-size:1rem;min-height:48px}}.in-btn,.out-btn{background:linear-gradient(135deg,#fa709a,#fee140);color:#0a0a0a;box-shadow:0 2px 8px #fa709a66}.in-btn:hover,.out-btn:hover{box-shadow:0 4px 12px #fa709a99;transform:translateY(-2px)}.in-btn:active,.out-btn:active{transform:translateY(0)}.play-pause-btn{width:3.5rem;height:3.5rem;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.4rem;border-radius:50%;box-shadow:0 4px 15px #667eea66;display:flex;align-items:center;justify-content:center;min-height:44px}@media(min-width:1024px){.play-pause-btn{width:4rem;height:4rem;font-size:1.6rem;min-height:48px}}.play-pause-btn:hover{box-shadow:0 6px 20px #667eea99;transform:scale(1.1)}.play-pause-btn:active{transform:scale(1.05)}.tap-btn{background:linear-gradient(135deg,#fa709a,#fee140);color:#0a0a0a;box-shadow:0 2px 8px #fa709a66;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem 1rem}.tap-btn:hover{box-shadow:0 4px 12px #fa709a99;transform:translateY(-2px)}.tap-btn:active{transform:translateY(0) scale(.95)}.tap-icon{font-size:1.5rem;font-weight:700;line-height:1}.tap-label{font-size:.7rem;font-weight:700;letter-spacing:1px}@media(min-width:1024px){.tap-btn{padding:.625rem 1.25rem}.tap-icon{font-size:1.75rem}.tap-label{font-size:.75rem}}.play-selection-btn{background:#2a2a2a;border:2px solid #3a3a3a;color:#fff;padding:.625rem 1.25rem;font-size:1.1rem}.play-selection-btn:hover{background:#333;border-color:#667eea;transform:translateY(-2px)}@media(min-width:1024px){.play-selection-btn{padding:.75rem 1.5rem}}.time-display-group{display:flex;align-items:center;gap:.5rem}.time-input{width:6rem;padding:.625rem .75rem;background:#2a2a2a;border:2px solid #3a3a3a;border-radius:6px;color:#fff;font-size:.9rem;font-weight:700;font-family:Courier New,monospace;text-align:center;transition:all .2s ease;min-height:44px}@media(min-width:1024px){.time-input{width:6.5rem;padding:.75rem .875rem;font-size:.95rem;min-height:48px}}.time-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#333}.time-input:-moz-read-only{cursor:default}.time-input:read-only{cursor:default}.nudge-buttons-small{display:flex;flex-direction:column;gap:.25rem}.nudge-btn-small{width:2rem;height:2rem;padding:0;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1;min-height:44px}@media(min-width:1024px){.nudge-btn-small{width:2.25rem;height:2.25rem;font-size:1.2rem;min-height:48px}}.nudge-btn-small:hover{background:#333;border-color:#667eea}.nudge-btn-small:active{background:#667eea;border-color:#667eea}.duration-info{padding:.625rem 1rem;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:6px;color:#b0b0b0;font-size:.9rem;font-weight:600;font-family:Courier New,monospace;white-space:nowrap;min-height:44px;display:flex;align-items:center;justify-content:center}@media(min-width:1024px){.duration-info{padding:.75rem 1.25rem;font-size:.95rem;min-height:48px}}@media(max-width:768px){.video-cockpit{padding:1rem;gap:1rem}.cockpit-timeline{height:50px}.timeline-handle{width:28px}.handle-grip{width:18px;height:18px;opacity:.9}.action-btn{padding:.875rem 1.25rem;font-size:.9rem;min-height:48px}.play-pause-btn{width:3.75rem;height:3.75rem;font-size:1.5rem}.time-input{width:5.5rem;padding:.75rem .625rem;min-height:48px}.nudge-btn-small{width:2.5rem;height:2.5rem;min-height:48px}.duration-info{padding:.75rem 1rem;min-height:48px}}.save-modal-backdrop{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.save-modal-container{background:linear-gradient(135deg,#1e1e1e,#2a2a2a);border-radius:12px;border:2px solid #3a3a3a;box-shadow:0 20px 60px #000c;width:90%;max-width:500px;max-height:min(90vh,calc(100vh - 2rem));display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.save-modal-header{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #3a3a3a}.save-modal-header h2{margin:0;color:#fff;font-size:1.5rem;font-weight:700}.save-modal-close{background:transparent;border:none;color:#b0b0b0;font-size:2rem;cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1;padding:0}.save-modal-close:hover:not(:disabled){background:#333;color:#fff}.save-modal-close:disabled{opacity:.5;cursor:not-allowed}.save-modal-form{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.save-modal-body{flex:1;min-height:0;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;-webkit-overflow-scrolling:touch}.save-modal-footer{flex-shrink:0;padding:1.25rem 1.5rem;border-top:1px solid #3a3a3a;background:#1e1e1e;display:flex;flex-direction:column;gap:1rem}.save-modal-footer .save-modal-privacy-field{margin-bottom:0}.save-modal-field{display:flex;flex-direction:column;gap:.5rem}.save-modal-field label{color:#b0b0b0;font-size:.9rem;font-weight:600}.save-modal-field .required{color:#fa709a}.save-modal-field .save-modal-optional{font-weight:400;color:#888;font-size:.85rem}.save-modal-composer-fields{display:grid;gap:.75rem;grid-template-columns:1fr}.save-modal-composer-fields .save-modal-composer-given,.save-modal-composer-fields .save-modal-composer-family{margin:0}@media(min-width:640px){.save-modal-composer-fields{grid-template-columns:1fr 1fr}}.save-modal-existing-hint{background:#667eea1f;border:1px solid rgba(102,126,234,.3);border-radius:8px;color:#b8c5f0;font-size:.9rem;padding:.6rem .9rem;margin-bottom:1rem}.save-modal-field input,.save-modal-field select{background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;transition:all .2s ease;font-family:inherit}.save-modal-field input:focus,.save-modal-field select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.save-modal-field input:disabled,.save-modal-field select:disabled{opacity:.5;cursor:not-allowed}.save-modal-field input::-moz-placeholder{color:#666}.save-modal-field input::placeholder{color:#666}.save-modal-movement-select{margin-bottom:0}.save-modal-movement-free-input{margin-top:.5rem}.save-modal-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end;margin-top:0}.save-modal-btn{padding:.65rem 1.1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.save-modal-btn:disabled{opacity:.5;cursor:not-allowed}.save-modal-btn.cancel-btn{background:#3a3a3a;color:#b0b0b0;border:2px solid #4a4a4a}.save-modal-btn.cancel-btn:hover:not(:disabled){background:#4a4a4a;color:#fff;border-color:#5a5a5a}.save-modal-btn.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:2px solid #667eea;box-shadow:0 4px 15px #667eea66}.save-modal-btn.save-btn:hover:not(:disabled){background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.save-modal-btn.save-btn:active{transform:translateY(0)}.save-modal-loading{padding:.75rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:6px;text-align:center;color:#667eea;font-size:.9rem;margin-bottom:1rem}.save-modal-reanalyze{margin-top:.35rem;padding:.25rem 0;background:none;border:none;color:#667eea;font-size:.85rem;cursor:pointer;text-decoration:none}.save-modal-reanalyze:hover:not(:disabled){text-decoration:underline}.save-modal-reanalyze:disabled{opacity:.6;cursor:not-allowed}.save-modal-hint{display:block;color:#666;font-size:.75rem;margin-top:.25rem;font-style:italic}.save-modal-movement-search-links{font-size:.85rem;color:#b0b0b0;margin-bottom:.5rem}.save-modal-movement-search-links a{color:#667eea;text-decoration:none}.save-modal-movement-search-links a:hover{text-decoration:underline}.save-modal-movement-search-links .save-modal-movement-links-hint{display:block;margin-top:.25rem;margin-bottom:0}.save-modal-imslp-status{display:block;margin-top:.35rem;font-size:.85rem;color:var(--text-secondary, #555)}.save-modal-imslp-status a{color:var(--link-color, #0a6ebd)}.save-modal-work-unverified{display:block;margin-top:.35rem;padding:.35rem .5rem;font-size:.8rem;color:#b45309;background:#b4530926;border-radius:6px;border-left:3px solid #b45309}.save-modal-work-verified{display:flex;align-items:center;gap:.35rem;margin-top:.35rem;font-size:.8rem;color:#15803d}.save-modal-work-verified:before{content:"✓";font-weight:700;color:#15803d}.save-modal-formation-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem}.save-modal-formation-chip{padding:.4rem .75rem;border-radius:9999px;border:1px solid #4b5563;background:#374151;color:#e5e7eb;font-size:.8rem;cursor:pointer;transition:background .15s ease,border-color .15s ease}.save-modal-formation-chip:hover:not(:disabled){background:#4b5563;border-color:#6b7280}.save-modal-formation-chip-active{background:#6366f1;border-color:#6366f1;color:#fff}.save-modal-formation-chip:disabled{opacity:.6;cursor:not-allowed}.save-modal-warning{padding:.75rem;background:#fee1401a;border:1px solid rgba(254,225,64,.3);border-radius:6px;color:#fee140;font-size:.85rem;margin-bottom:0}.save-modal-btn.save-copy-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:2px solid #f59e0b;box-shadow:0 4px 15px #f59e0b66}.save-modal-btn.save-copy-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 6px 20px #f59e0b99;transform:translateY(-2px)}.save-modal-tags-field{border-top:1px solid #3a3a3a;padding-top:1rem;margin-top:.25rem}.save-modal-tags-chips{display:flex;flex-wrap:wrap;gap:.5rem;min-height:2rem;margin-bottom:.75rem}.save-modal-tag-chip{display:inline-flex;align-items:center;gap:.25rem;background:#2a2a2a;border:1px solid #4a4a4a;border-radius:6px;padding:.35rem .5rem;font-size:.85rem;color:#e0e0e0}.save-modal-tag-chip-remove{background:none;border:none;color:#888;cursor:pointer;padding:0 .15rem;font-size:1.1rem;line-height:1;border-radius:2px;transition:color .15s,background .15s}.save-modal-tag-chip-remove:hover:not(:disabled){color:#fff;background:#555}.save-modal-tag-chip-remove:disabled{opacity:.5;cursor:not-allowed}.save-modal-tags-add{position:relative;display:flex;gap:.5rem;margin-bottom:.5rem}.save-modal-tag-input{flex:1;min-width:0}.save-modal-tag-add-btn{padding:.75rem 1rem;background:#3a3a3a;border:2px solid #4a4a4a;border-radius:8px;color:#e0e0e0;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.save-modal-tag-add-btn:hover:not(:disabled){background:#4a4a4a;border-color:#667eea;color:#fff}.save-modal-tag-add-btn:disabled{opacity:.5;cursor:not-allowed}.save-modal-tag-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:#1a1a1a;border:2px solid #3a3a3a;border-radius:8px;max-height:180px;overflow-y:auto;z-index:10;display:flex;flex-direction:column}.save-modal-tag-suggestion{padding:.5rem .75rem;text-align:left;background:none;border:none;color:#e0e0e0;font-size:.9rem;cursor:pointer;transition:background .15s}.save-modal-tag-suggestion:hover{background:#333}.save-modal-tags-actions{margin-bottom:.25rem}.save-modal-btn-reset-tags{background:none;border:1px dashed #555;color:#888;font-size:.8rem;padding:.4rem .75rem;border-radius:6px;cursor:pointer;transition:all .2s}.save-modal-btn-reset-tags:hover:not(:disabled){border-color:#667eea;color:#667eea}.save-modal-btn-reset-tags:disabled{opacity:.5;cursor:not-allowed}.confirm-exit-modal-backdrop{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.confirm-exit-modal-container{background:linear-gradient(135deg,#1e1b2e,#2d1b3d);border-radius:16px;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #00000080;max-width:480px;width:90%;padding:0;animation:slide-up .3s ease-out}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-exit-modal-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.1)}.confirm-exit-modal-header h2{margin:0;font-size:20px;font-weight:600;color:#fff;display:flex;align-items:center;gap:8px}.confirm-exit-modal-content{padding:24px}.confirm-exit-modal-content p{margin:0 0 16px;color:#ffffffe6;line-height:1.6;font-size:15px}.confirm-exit-modal-warning{color:#fbbf24!important;font-weight:500;background:#fbbf241a;padding:12px;border-radius:8px;border:1px solid rgba(251,191,36,.2)}.confirm-exit-modal-actions{display:flex;gap:12px;padding:24px;border-top:1px solid rgba(255,255,255,.1);justify-content:flex-end}.confirm-exit-modal-btn{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;outline:none}.confirm-exit-modal-btn.cancel-btn{background:#ffffff1a;color:#ffffffe6;border:1px solid rgba(255,255,255,.2)}.confirm-exit-modal-btn.cancel-btn:hover{background:#ffffff26;border-color:#ffffff4d}.confirm-exit-modal-btn.confirm-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.confirm-exit-modal-btn.confirm-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 16px #ef444466;transform:translateY(-1px)}.confirm-exit-modal-btn:active{transform:translateY(0)}.video-import-container{width:100%;max-width:800px;margin:0 auto;padding:3rem 2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif}.video-import-content{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.video-import-input-wrapper{width:100%;display:flex;flex-direction:column;gap:.75rem}.video-import-input-container{position:relative;display:flex;align-items:center;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:16px;padding:1.25rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.video-import-input-container:focus-within{background:#ffffff14;border-color:#667eea80;box-shadow:0 0 0 4px #667eea1a}.video-import-input-container.error{border-color:#ef444480;background:#ef44440d}.video-import-input-container.error:focus-within{border-color:#ef4444b3;box-shadow:0 0 0 4px #ef44441a}.video-import-icon{color:#ffffff80;margin-right:1rem;flex-shrink:0}.video-import-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:1.125rem;font-weight:400;font-family:inherit;width:100%}.video-import-input::-moz-placeholder{color:#fff6}.video-import-input::placeholder{color:#fff6}.video-import-spinner{margin-left:.75rem;flex-shrink:0}.video-import-spinner .spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.video-import-check{margin-left:.75rem;color:#10b981;flex-shrink:0;display:flex;align-items:center;justify-content:center}.video-import-clear{margin-left:.5rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#ffffff14;border:none;border-radius:50%;color:#ffffff80;cursor:pointer;transition:color .2s ease,background .2s ease}.video-import-clear:hover{color:#fff;background:#ffffff26}.video-import-error{color:#ef4444;font-size:.875rem;font-weight:500;padding:.5rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;text-align:center;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.video-import-search-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.875rem 1.5rem;color:#ffffffe6;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;gap:.5rem}.video-import-search-btn:hover{background:#ffffff1f;border-color:#ffffff40;color:#fff;transform:translateY(-2px)}.video-import-search-btn:active{transform:translateY(0)}.video-import-search-actions{display:flex;flex-wrap:wrap;gap:.75rem;width:100%;justify-content:center}.video-import-search-in-app{background:#667eea33;border-color:#667eea66}.video-import-search-in-app:hover{background:#667eea4d;border-color:#667eea99}.video-import-search-in-app:disabled{opacity:.7;cursor:not-allowed}.video-import-results{width:100%;margin-top:.5rem}.video-import-results-title{font-size:.9375rem;font-weight:600;color:#ffffffe6;margin:0 0 .75rem}.video-import-results-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;max-height:320px;overflow-y:auto}.video-import-result-card{display:flex;align-items:center;gap:1rem;width:100%;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;font-family:inherit}.video-import-result-card:hover{background:#ffffff1a;border-color:#fff3}.video-import-result-thumb{flex-shrink:0;width:120px;height:68px;border-radius:8px;overflow:hidden;background:#0000004d}.video-import-result-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.video-import-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.video-import-result-name{font-size:.9375rem;font-weight:500;color:#fff;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.video-import-result-channel{font-size:.8125rem;color:#fff9}.video-import-preview{width:100%;margin-top:1rem;animation:fadeInUp .4s cubic-bezier(.16,1,.3,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.video-import-preview-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;overflow:hidden;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s ease}.video-import-preview-card:hover{background:#ffffff14;border-color:#ffffff26;box-shadow:0 8px 24px #0000004d}.video-import-preview-thumbnail{flex-shrink:0;width:240px;height:135px;border-radius:12px;overflow:hidden;background:#0000004d}.video-import-preview-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.video-import-preview-content{flex:1;display:flex;flex-direction:column;gap:.75rem;justify-content:space-between}.video-import-preview-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.video-import-preview-channel{font-size:.9375rem;color:#fff9;margin:0}.video-import-confirm-btn{align-self:flex-start;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;padding:.875rem 1.75rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #10b9814d;margin-top:.5rem}.video-import-confirm-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.video-import-confirm-btn:active{transform:translateY(0)}@media(max-width:768px){.video-import-container{padding:2rem 1.5rem}.video-import-input-container{padding:1rem 1.25rem}.video-import-input{font-size:1rem}.video-import-preview-card{flex-direction:column;padding:1.25rem}.video-import-preview-thumbnail{width:100%;height:auto;aspect-ratio:16 / 9}.video-import-preview-title{font-size:1.125rem}.video-import-confirm-btn{width:100%;justify-content:center}}@media(max-width:480px){.video-import-container{padding:1.5rem 1rem}.video-import-input-container{padding:.875rem 1rem}.video-import-input{font-size:.9375rem}.video-import-icon{width:20px;height:20px;margin-right:.75rem}.video-import-search-btn{padding:.75rem 1.25rem;font-size:.875rem;width:100%;justify-content:center}.video-import-preview-card{padding:1rem}.video-import-preview-title{font-size:1rem}}.ios-paste-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:.875rem 1.5rem;color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #667eea4d;margin-top:.5rem}.ios-paste-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.ios-paste-btn:active{transform:translateY(0)}.ios-help-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.75rem 1.25rem;color:#ffffffe6;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.ios-help-btn:hover{background:#ffffff1f;border-color:#ffffff40;color:#fff}@media(max-width:480px){.ios-paste-btn{padding:.75rem 1.25rem;font-size:.875rem}.ios-help-btn{padding:.625rem 1rem;font-size:.8125rem}}.vi-explore{width:100%;display:flex;flex-direction:column;gap:1.25rem;animation:fadeInUp .5s cubic-bezier(.16,1,.3,1)}.vi-explore-stats{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.8125rem;color:#ffffff73;flex-wrap:wrap}.vi-explore-stats-sep{color:#fff3}.vi-explore-stat-block{display:inline-flex;align-items:baseline;gap:.25rem}.vi-explore-stat-value{font-size:1rem;font-weight:700;color:#fffc}.vi-explore-stat-label{font-size:.75rem;color:#fff6}.vi-explore-suggestion{display:flex;align-items:stretch;gap:0;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;transition:border-color .2s ease}.vi-explore-suggestion:hover{border-color:#ffffff26}.vi-explore-suggestion-btn{flex:1;display:flex;flex-direction:column;gap:.25rem;padding:.875rem 1rem;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .2s ease;min-width:0}.vi-explore-suggestion-btn:hover{background:#ffffff0a}.vi-explore-suggestion-label{font-size:.75rem;font-weight:500;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.vi-explore-suggestion-text{font-size:.9375rem;font-weight:500;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vi-explore-refresh{display:flex;align-items:center;justify-content:center;padding:0 .875rem;background:none;border:none;border-left:1px solid rgba(255,255,255,.08);color:#fff6;cursor:pointer;transition:color .2s ease,background .2s ease;flex-shrink:0}.vi-explore-refresh:hover{color:#fffc;background:#ffffff0f}.vi-explore-eras{display:flex;flex-direction:column;gap:.75rem}.vi-explore-era-pills{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.vi-explore-era-pill{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;color:#ffffffb3;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.vi-explore-era-pill:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.vi-explore-era-pill.active{background:#667eea33;border-color:#667eea80;color:#fff}.vi-explore-era-count{font-size:.6875rem;color:#ffffff59;font-weight:400}.vi-explore-era-pill.active .vi-explore-era-count{color:#fff9}.vi-explore-era-composers{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;animation:fadeInUp .3s ease-out}.vi-explore-composer-chip{display:flex;flex-direction:column;gap:.125rem;padding:.5rem .75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:inherit;text-align:left}.vi-explore-composer-chip:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.vi-explore-chip-name{font-size:.8125rem;font-weight:600;color:#ffffffe6}.vi-explore-chip-meta{font-size:.6875rem;color:#fff6}.vi-explore-top{display:flex;flex-direction:column;gap:.625rem}.vi-explore-top-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.5rem}.vi-explore-top-item{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:inherit;text-align:left}.vi-explore-top-item:hover{background:#ffffff14;border-color:#ffffff2e;transform:translateY(-1px)}.vi-explore-top-rank{font-size:.8125rem;font-weight:700;color:#667eea99;width:1.25rem;text-align:center;flex-shrink:0}.vi-explore-top-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.vi-explore-top-header{display:flex;align-items:center;gap:.5rem}.vi-explore-top-name{font-size:.8125rem;font-weight:600;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vi-explore-top-meta{font-size:.6875rem;color:#fff6}.vi-explore-underrep{display:flex;flex-direction:column;gap:.625rem}.vi-explore-section-title{font-size:.75rem;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.06em;margin:0;text-align:center}.vi-explore-underrep-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.vi-explore-underrep-item{display:flex;flex-direction:column;gap:.25rem;padding:.625rem .75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:inherit;text-align:left}.vi-explore-underrep-item:hover{background:#ffffff14;border-color:#ffffff2e;transform:translateY(-1px)}.vi-explore-underrep-header{display:flex;align-items:center;gap:.5rem;justify-content:space-between}.vi-explore-underrep-name{font-size:.8125rem;font-weight:600;color:#ffffffe6}.vi-explore-underrep-era{font-size:.625rem;font-weight:500;color:#667eeab3;background:#667eea1a;padding:.125rem .375rem;border-radius:4px;flex-shrink:0}.vi-explore-underrep-info{font-size:.6875rem;color:#fff6}.vi-explore-underrep-bar{height:2px;background:#ffffff14;border-radius:1px;overflow:hidden;margin-top:.125rem}.vi-explore-underrep-bar-fill{height:100%;background:#667eea99;border-radius:1px;transition:width .4s ease;min-width:1px}@media(max-width:768px){.vi-explore-underrep-list,.vi-explore-top-list{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:480px){.vi-explore{gap:1rem}.vi-explore-stats{font-size:.6875rem;gap:.375rem}.vi-explore-stat-value{font-size:.875rem}.vi-explore-suggestion-text{font-size:.8125rem}.vi-explore-era-pills{gap:.375rem}.vi-explore-era-pill{padding:.375rem .625rem;font-size:.75rem}.vi-explore-underrep-list,.vi-explore-top-list{grid-template-columns:1fr}}.ios-instructions-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}.ios-instructions-card{background:#18181bfa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ios-instructions-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.ios-instructions-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.ios-instructions-close{background:transparent;border:none;color:#fff9;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;transition:color .2s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%}.ios-instructions-close:hover{color:#fff;background:#ffffff1a}.ios-instructions-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.ios-instructions-tab{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.75rem 1rem;color:#fff9;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.ios-instructions-tab:hover{background:#ffffff14;border-color:#fff3}.ios-instructions-tab.active{background:#667eea33;border-color:#667eea80;color:#fff}.ios-instructions-content{padding:1.5rem}.ios-instructions-method h3{margin:0 0 1.25rem;font-size:1.125rem;font-weight:600;color:#fff}.ios-instructions-steps{margin:0;padding-left:1.5rem;list-style:none;counter-reset:step-counter}.ios-instructions-steps li{counter-increment:step-counter;position:relative;padding-left:2rem;margin-bottom:1rem;color:#ffffffe6;font-size:.9375rem;line-height:1.6}.ios-instructions-steps li:before{content:counter(step-counter);position:absolute;left:0;top:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;flex-shrink:0}.ios-instructions-steps li strong{color:#fff;font-weight:600}.ios-instructions-footer{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.ios-instructions-btn-primary{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;padding:.875rem 1.5rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #667eea4d}.ios-instructions-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.ios-instructions-btn-primary:active{transform:translateY(0)}.ios-instructions-btn-secondary{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:.875rem 1.5rem;color:#ffffffe6;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.ios-instructions-btn-secondary:hover{background:#ffffff1f;border-color:#ffffff40;color:#fff}@media(max-width:640px){.ios-instructions-overlay{padding:.5rem}.ios-instructions-card{max-height:95vh;border-radius:20px}.ios-instructions-header{padding:1.25rem}.ios-instructions-header h2{font-size:1.25rem}.ios-instructions-tabs{padding:.75rem 1rem}.ios-instructions-tab{padding:.625rem .75rem;font-size:.875rem}.ios-instructions-content{padding:1.25rem}.ios-instructions-method h3{font-size:1rem;margin-bottom:1rem}.ios-instructions-steps li{font-size:.875rem;margin-bottom:.875rem;padding-left:1.75rem}.ios-instructions-steps li:before{width:20px;height:20px;font-size:.75rem}.ios-instructions-footer{flex-direction:column;padding:1.25rem}.ios-instructions-btn-primary,.ios-instructions-btn-secondary{width:100%}}.pwa-install-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:1000;max-width:90%;width:100%;max-width:500px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pwa-install-content{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 8px 32px #0000004d}.pwa-install-icon{font-size:2rem;flex-shrink:0}.pwa-install-text{flex:1}.pwa-install-text h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#18181b}.pwa-install-text p{margin:0;font-size:.875rem;color:#18181bb3}.pwa-install-buttons{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.pwa-install-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.625rem 1.25rem;color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 2px 8px #667eea4d}.pwa-install-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.pwa-install-btn-primary:active{transform:translateY(0)}.pwa-install-btn-dismiss{background:transparent;border:none;color:#18181b80;font-size:1.25rem;cursor:pointer;padding:.5rem;line-height:1;transition:color .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.pwa-install-btn-dismiss:hover{color:#18181bcc;background:#18181b0d}@media(max-width:640px){.pwa-install-prompt{bottom:10px;left:10px;right:10px;max-width:none;width:auto;transform:none}.pwa-install-content{padding:1rem;gap:.75rem}.pwa-install-icon{font-size:1.5rem}.pwa-install-text h3{font-size:1rem}.pwa-install-text p{font-size:.8125rem}.pwa-install-btn-primary{padding:.5rem 1rem;font-size:.875rem}}.parcours-images-editor-page{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.parcours-images-editor-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.parcours-images-editor-back{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:.875rem;font-weight:500;color:#374151;transition:background .2s ease,border-color .2s ease}.parcours-images-editor-back:hover{background:#f9fafb;border-color:#d1d5db}.parcours-images-editor-header h1{margin:0;font-size:1.5rem;font-weight:700;color:#111827;letter-spacing:-.5px}.parcours-images-editor-main{max-width:960px;margin:0 auto;padding:1.5rem 2rem 2rem}.parcours-images-editor-tabs{display:flex;gap:4px;margin-bottom:1.25rem;background:#f3f4f6;border-radius:10px;padding:4px}.parcours-images-editor-tab{flex:1;padding:.55rem 1rem;border:none;border-radius:8px;background:transparent;font-size:.9375rem;font-weight:500;color:#6b7280;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.parcours-images-editor-tab:hover{color:#374151;background:#ffffff80}.parcours-images-editor-tab-active{background:#fff;color:#111827;box-shadow:0 1px 3px #00000014;font-weight:600}.parcours-images-editor-tab-active:hover{background:#fff;color:#111827}.parcours-images-editor-intro{color:#6b7280;margin:0 0 1.5rem;font-size:.9375rem}.parcours-images-editor-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;padding:1.25rem 1.5rem;margin-bottom:1.25rem}.parcours-images-editor-card-title{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#111827}.parcours-images-editor-nodes-hint{margin:0 0 .75rem;font-size:.8125rem;color:#6b7280}.parcours-images-editor-nodes-list{display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto;padding:2px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb}.parcours-images-editor-node-item{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;padding:.6rem .85rem;text-align:left;font-size:.9375rem;color:#111827;background:#fff;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.parcours-images-editor-node-item:hover{background:#f3f4f6;border-color:#e5e7eb}.parcours-images-editor-node-item-selected{background:linear-gradient(135deg,#667eea26,#764ba21f);border-color:#667eea;color:#111827;font-weight:500}.parcours-images-editor-node-item-selected:hover{background:linear-gradient(135deg,#667eea33,#764ba22e)}.parcours-images-editor-node-label{font-size:.9375rem;font-weight:500;line-height:1.35}.parcours-images-editor-node-id{font-size:.8125rem;color:#6b7280;font-weight:400;font-family:ui-monospace,monospace}.parcours-images-editor-node-item-selected .parcours-images-editor-node-id{color:#4b5563}.parcours-images-editor-field{margin-bottom:0}.parcours-images-editor-field:not(:last-child){margin-bottom:1rem}.parcours-images-editor-field label{display:block;font-weight:500;margin-bottom:.35rem;font-size:.875rem;color:#374151}.parcours-images-editor-select,.parcours-images-editor-input{width:100%;max-width:100%;padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.9375rem;background:#fff;color:#111827}.parcours-images-editor-select:focus,.parcours-images-editor-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.parcours-images-editor-url-final{margin:.5rem 0 0;font-size:.8125rem;color:#6b7280;word-break:break-all}.parcours-images-editor-url-final code{background:#f3f4f6;color:#111827;padding:.15rem .35rem;border-radius:4px;font-size:.75rem}.parcours-images-editor-preview-card .parcours-images-editor-card-title{margin-bottom:.35rem}.parcours-images-editor-crop-hint{margin:0 0 1rem;font-size:.8125rem;color:#6b7280}.parcours-images-editor-preview-wrap{position:relative;display:inline-block;max-width:100%;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.parcours-images-editor-preview-img{display:block;max-width:100%;max-height:320px;-o-object-fit:contain;object-fit:contain;vertical-align:middle}.parcours-images-editor-crop-box{position:absolute;top:0;left:0;box-sizing:border-box;border:3px solid #667eea;box-shadow:0 0 0 2px #ffffffe6,0 0 12px #667eea80;cursor:move;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:2}.parcours-images-editor-crop-box:hover{border-color:#5a67d8;box-shadow:0 0 0 2px #fff,0 0 16px #667eea99}.parcours-images-editor-render-section .parcours-images-editor-card-title{margin-bottom:.35rem}.parcours-images-editor-render-hint{margin:0 0 .75rem;font-size:.8125rem;color:#6b7280}.parcours-images-editor-render-card{width:100%;max-width:480px;min-height:140px;aspect-ratio:8 / 5;flex-shrink:0;border-radius:16px;overflow:hidden;border:1px solid #e5e7eb;box-shadow:0 2px 4px #0000000a,0 8px 24px #00000014;background-color:#f3f4f6;background-repeat:no-repeat}.parcours-images-editor-crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:2px solid #667eea;border-radius:2px;box-shadow:0 1px 3px #0003;z-index:3;touch-action:none}.parcours-images-editor-crop-handle-nw{top:-2px;left:-2px;cursor:nwse-resize}.parcours-images-editor-crop-handle-ne{top:-2px;right:-2px;cursor:nesw-resize}.parcours-images-editor-crop-handle-sw{bottom:-2px;left:-2px;cursor:nesw-resize}.parcours-images-editor-crop-handle-se{bottom:-2px;right:-2px;cursor:nwse-resize}.parcours-images-editor-export .parcours-images-editor-card-title{margin-bottom:.75rem}.parcours-images-editor-export-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.parcours-images-editor-btn{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:.875rem;font-weight:500;color:#374151;transition:background .2s ease,border-color .2s ease,color .2s ease}.parcours-images-editor-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.parcours-images-editor-btn:disabled{opacity:.6;cursor:not-allowed}.parcours-images-editor-btn-save{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.parcours-images-editor-btn-save:hover:not(:disabled){background:linear-gradient(135deg,#5a67d8,#6b46a1);color:#fff;border-color:transparent}.parcours-images-editor-export-hint{margin:0;font-size:.8125rem;color:#6b7280}.parcours-images-editor-export-hint code{background:#f3f4f6;padding:.1rem .25rem;border-radius:4px}.parcours-images-editor-access-denied{max-width:400px;margin:4rem auto;padding:2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;border:1px solid #e5e7eb}.parcours-images-editor-access-denied h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#111827}.parcours-images-editor-access-denied p{margin:0 0 1.5rem;color:#6b7280}.parcours-images-editor-toast{margin:.75rem 0 0;padding:.5rem .75rem;font-size:.875rem;font-weight:500;color:#047857;background:#d1fae5;border-radius:8px;border:1px solid #a7f3d0}.parcours-images-editor-toast-error{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.parcours-images-editor-access-denied .parcours-images-editor-back{margin:0}@media(max-width:768px){.parcours-images-editor-header{padding:.75rem 1rem}.parcours-images-editor-header h1{font-size:1.25rem}.parcours-images-editor-main{padding:1rem 1rem 1.5rem}.parcours-images-editor-card{padding:1rem 1.25rem}.parcours-images-editor-nodes-list{max-height:200px}.parcours-images-editor-preview-img{max-height:240px}.parcours-images-editor-export-actions{flex-direction:column}.parcours-images-editor-export-actions .parcours-images-editor-btn{width:100%}}@media(max-width:480px){.parcours-images-editor-main{padding:.75rem}.parcours-images-editor-crop-handle{width:20px;height:20px}}.parcours-coverage-page{min-height:100vh;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.parcours-coverage-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.parcours-coverage-back{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:.875rem;font-weight:500;color:#374151;transition:background .2s ease,border-color .2s ease}.parcours-coverage-back:hover{background:#f9fafb;border-color:#d1d5db}.parcours-coverage-header h1{margin:0;font-size:1.5rem;font-weight:700;color:#111827;letter-spacing:-.5px}.parcours-coverage-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.parcours-coverage-tab{padding:.625rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.9375rem;font-weight:600;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s ease,border-color .2s ease}.parcours-coverage-tab:hover{color:#374151}.parcours-coverage-tab-active{color:#667eea;border-bottom-color:#667eea}.parcours-coverage-main{max-width:1060px;margin:0 auto;padding:1.5rem 2rem 3rem}.parcours-coverage-intro{color:#6b7280;margin:0 0 1.5rem;font-size:.9375rem;line-height:1.5}.parcours-coverage-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 0;color:#6b7280}.parcours-coverage-loading .spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.parcours-coverage-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem 1.25rem;font-size:.9375rem}.parcours-coverage-summary{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem}.parcours-coverage-stat{flex:1 1 140px;background:#fff;border-radius:10px;padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;gap:.25rem}.parcours-coverage-stat-value{font-size:1.5rem;font-weight:700;color:#111827}.parcours-coverage-stat-critical{color:#dc2626}.parcours-coverage-stat-low{color:#ea580c}.parcours-coverage-stat-draft{color:#6b7280}.parcours-coverage-stat-label{font-size:.8125rem;color:#6b7280;font-weight:500}.parcours-coverage-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem}.parcours-coverage-legend-item{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;padding:.3rem .75rem;border-radius:6px}.parcours-coverage-legend-item.parcours-coverage-level-critical{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.parcours-coverage-legend-item.parcours-coverage-level-low{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.parcours-coverage-legend-item.parcours-coverage-level-ok{background:#fefce8;color:#a16207;border:1px solid #fde68a}.parcours-coverage-legend-item.parcours-coverage-level-good{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.parcours-coverage-legend-hint{display:inline-flex;align-items:center;font-size:.75rem;color:#9ca3af;font-style:italic}.parcours-coverage-stage{margin-bottom:2rem}.parcours-coverage-stage-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 .75rem;letter-spacing:-.3px}.parcours-coverage-table{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.parcours-coverage-table-header,.parcours-coverage-row{display:grid;grid-template-columns:1fr 90px 55px 50px 55px 45px 45px 100px;align-items:center;padding:.625rem 1rem;gap:.5rem}.parcours-coverage-table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.parcours-coverage-row{border-bottom:1px solid #f3f4f6;font-size:.875rem;color:#374151;transition:background .15s ease}.parcours-coverage-row:last-child{border-bottom:none}.parcours-coverage-row:hover{background:#fafbfc}.parcours-coverage-row.parcours-coverage-level-critical{background:#fef2f2}.parcours-coverage-row.parcours-coverage-level-critical:hover{background:#fee2e2}.parcours-coverage-row.parcours-coverage-level-low{background:#fff7ed}.parcours-coverage-row.parcours-coverage-level-low:hover{background:#ffedd5}.parcours-coverage-col-node{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.parcours-coverage-col-type{font-size:.8125rem;color:#9ca3af}.parcours-coverage-col-total{text-align:center}.parcours-coverage-col-major,.parcours-coverage-col-minor{text-align:center;font-size:.8125rem;color:#6b7280}.parcours-coverage-col-effective{text-align:center;font-size:.8125rem;font-weight:600;color:#667eea}.parcours-coverage-col-drafts{text-align:center;font-size:.8125rem;color:#9ca3af;font-style:italic}.parcours-coverage-col-status{text-align:right}.parcours-coverage-badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.75rem;font-weight:600;letter-spacing:.01em}.parcours-coverage-badge-critical{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.parcours-coverage-badge-low{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.parcours-coverage-badge-ok{background:#fefce8;color:#a16207;border:1px solid #fde68a}.parcours-coverage-badge-good{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.horizons-coverage-cards{display:flex;flex-direction:column;gap:1rem}.horizons-coverage-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000f;overflow:hidden;border-left:4px solid #e5e7eb}.horizons-coverage-card.horizons-coverage-level-critical{border-left-color:#dc2626}.horizons-coverage-card.horizons-coverage-level-low{border-left-color:#ea580c}.horizons-coverage-card.horizons-coverage-level-ok{border-left-color:#eab308}.horizons-coverage-card.horizons-coverage-level-good{border-left-color:#16a34a}.horizons-coverage-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem}.horizons-coverage-card-title{display:flex;flex-direction:column;gap:.125rem}.horizons-coverage-card-tag{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#667eea}.horizons-coverage-card-label{font-size:1rem;font-weight:600;color:#111827}.horizons-coverage-card-count{display:flex;align-items:center;gap:.75rem}.horizons-coverage-card-total{font-size:1.75rem;font-weight:700;color:#111827}.horizons-coverage-card-drafts{font-size:.8125rem;color:#9ca3af;font-style:italic;font-weight:500}.horizons-coverage-card-details{padding:0 1.25rem 1rem;display:flex;flex-direction:column;gap:.75rem}.horizons-coverage-detail-section{display:flex;flex-direction:column;gap:.375rem}.horizons-coverage-detail-title{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.horizons-coverage-detail-chips{display:flex;flex-wrap:wrap;gap:.375rem}.horizons-coverage-chip{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.horizons-coverage-chip-zero{color:#9ca3af;background:#fafafa;border-color:#f3f4f6}@media(max-width:768px){.parcours-coverage-header{padding:.75rem 1rem}.parcours-coverage-header h1{font-size:1.125rem}.parcours-coverage-main{padding:1rem}.parcours-coverage-summary{gap:.5rem}.parcours-coverage-stat{flex:1 1 100px;padding:.75rem}.parcours-coverage-stat-value{font-size:1.25rem}.parcours-coverage-table-header,.parcours-coverage-row{grid-template-columns:1fr 50px 44px 48px 44px 44px 80px;padding:.5rem .75rem;font-size:.8125rem}.parcours-coverage-col-type{display:none}.horizons-coverage-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.horizons-coverage-card-count{align-self:flex-end}}@media(max-width:480px){.parcours-coverage-table-header,.parcours-coverage-row{grid-template-columns:1fr 44px 48px 70px}.parcours-coverage-col-minor,.parcours-coverage-col-drafts,.parcours-coverage-col-major{display:none}.parcours-coverage-tabs{gap:0}.parcours-coverage-tab{flex:1;text-align:center;padding:.5rem .75rem;font-size:.8125rem}}.player-immersive{position:fixed;inset:0;width:100%;height:100vh;height:100dvh;height:var(--vvh, 100dvh);background:#000;z-index:1000;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;display:flex;flex-direction:column}.player-video-zone{position:relative;width:100%;flex:1 1 0;min-height:0;min-width:0;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden}.player-video-wrapper{position:relative;z-index:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.player-youtube{width:100%;height:100%;max-width:100%;max-height:100%}.player-youtube iframe{position:relative;z-index:0;width:100%;height:100%;aspect-ratio:16 / 9;pointer-events:none}.player-video-tap-overlay{position:absolute;inset:0;z-index:9998;pointer-events:auto;cursor:pointer}.player-video-zone-actions{position:absolute;inset:0;z-index:10000;pointer-events:none}.player-video-zone-actions .player-quit-btn,.player-video-zone-actions .player-open-full-video-btn{pointer-events:auto}.player-open-full-video-btn{position:absolute;top:calc(env(safe-area-inset-top,0px) + 2rem);left:max(1.5rem,env(safe-area-inset-left,0px));display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.35);border-radius:50px;color:#fff;font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;z-index:60;font-family:inherit}.player-open-full-video-btn:hover{background:#000c;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0006;color:#fff}.player-open-full-video-btn:active{transform:translateY(0)}.player-quit-btn{position:absolute;top:calc(env(safe-area-inset-top,0px) + 2rem);right:max(1.5rem,env(safe-area-inset-right,0px));display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.35);border-radius:50px;color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;z-index:60;font-family:inherit}.player-quit-btn:hover{background:#000c;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0006}.player-quit-btn:active{transform:translateY(0)}.player-onboarding-coachmark{position:absolute;top:.4rem;left:50%;transform:translate(-50%);z-index:40;display:inline-flex;align-items:center;gap:.5rem;padding:.42rem .7rem;border-radius:999px;border:1px solid rgba(148,163,184,.25);background:linear-gradient(135deg,#0f172ae0,#111827b8);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 8px 24px #02061761;animation:onboardingCoachmarkIn .18s ease-out;pointer-events:none}.player-onboarding-coachmark-dot{width:7px;height:7px;border-radius:50%;background:#38bdf8;box-shadow:0 0 0 3px #38bdf833}.player-onboarding-coachmark-label{font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;color:#bfdbfeeb;font-weight:600}.player-onboarding-coachmark p{margin:0;font-size:.8rem;line-height:1.25;color:#f1f5f9eb;white-space:nowrap;font-weight:500}.player-onboarding-coachmark-close{width:1.25rem;height:1.25rem;border-radius:999px;border:1px solid rgba(148,163,184,.3);background:#0f172a8c;color:#e2e8f0e6;font-size:.88rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;font-family:inherit;pointer-events:auto}.player-onboarding-coachmark-close:hover{background:#1e293bd9;border-color:#94a3b873}@keyframes onboardingCoachmarkIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(prefers-reduced-motion:reduce){.player-onboarding-coachmark{animation:none}}.player-timeline-section{position:relative;flex-shrink:0;width:100%;min-width:0;overflow-x:hidden;background:linear-gradient(to top,#000000eb,#000000bf);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:0 1rem .5rem;display:flex;flex-direction:column;gap:0}.player-timeline-section-has-cadences{padding-top:2rem}.player-timeline-section-has-pedal{padding-bottom:.5rem}.player-pedal-strip{position:relative;width:100%;min-height:28px;flex-shrink:0;pointer-events:none;margin-top:4px}.player-pedal-strip-group{position:absolute;top:0;display:flex;align-items:center;gap:0;min-height:24px;box-sizing:border-box}.player-pedal-strip-label{flex-shrink:0;font-size:1.05rem;line-height:1.3;white-space:nowrap;color:#67e8f9;display:inline-flex;align-items:baseline;gap:.15em}.player-pedal-strip-label-word{font-family:cursive;font-style:italic;font-weight:600}.player-pedal-strip-label-degree{font-family:Georgia,Times New Roman,serif;font-style:normal;font-variant-numeric:tabular-nums;font-weight:700}.player-pedal-strip-group .player-pedal-strip-line{flex:1;min-width:4px;height:2px;margin-left:2px;background:#67e8f9;opacity:.7;border-radius:1px;align-self:center}.player-control-zone{flex-shrink:0;min-height:180px;background:#27272acc;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.05);padding:1.5rem 2rem 2rem;display:flex;flex-direction:column;gap:1.25rem;z-index:20;box-shadow:0 -4px 24px #00000080;overflow:visible}.player-live-ranking-compact-btn{z-index:1;max-width:160px;border:1px solid rgba(148,163,184,.45);border-radius:8px;padding:.32rem .5rem;background:#1e293bd9;color:#f8fafc;font-size:.74rem;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.player-live-ranking-compact-btn:hover{background:#334155eb;border-color:#94a3b8b3}.player-live-controls-stack{display:inline-flex;flex-direction:column;align-items:flex-end;gap:.35rem}.player-timeline-section .player-timeline-overlay{position:relative;width:100%;min-width:0;height:auto;min-height:80px;background:transparent;padding:0;display:flex;flex-direction:column;align-items:stretch;pointer-events:auto;z-index:auto}.player-video-zone .player-timeline-overlay{position:absolute;bottom:0;left:0;right:0;height:96px;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.6) 50%,transparent 100%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;z-index:9999;display:flex;align-items:flex-end;padding:0 1rem 1rem}.player-timeline-overlay-has-cadences{padding-top:32px;min-height:128px;overflow-y:visible}.player-timeline-overlay-has-borrowed-pedal{min-height:112px;overflow-y:visible}.player-timeline-content-viewport{width:100%;min-width:0}.player-timeline-content-frame{position:relative;width:100%;min-width:0}.player-timeline-cadence-braces{position:absolute;top:0;left:0;width:100%;height:28px;pointer-events:none;z-index:10}.player-timeline-cadence-brace{position:absolute;top:0;height:28px;box-sizing:border-box}.player-timeline-cadence-brace-bar{position:absolute;top:0;left:0;width:100%;height:16px;border:2px solid rgba(251,191,36,.5);border-bottom:none;border-radius:8px 8px 0 0;box-sizing:border-box}.player-timeline-cadence-brace-label{position:absolute;top:2px;left:50%;transform:translate(-50%);padding:2px 8px;border-radius:4px;background:#fbbf2433;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(251,191,36,.35);font-size:.75rem;font-weight:600;color:#fcd34d;white-space:nowrap;z-index:5;max-width:90%;overflow:hidden;text-overflow:ellipsis}.player-timeline-cadence-braces-review{top:-28px;left:0;right:0;height:28px}.player-timeline-cadence-braces-review .player-cadence-brace-correct .player-timeline-cadence-brace-bar,.player-timeline-cadence-braces-review .player-cadence-brace-correct .player-timeline-cadence-brace-label{border-color:#05966980;color:#059669}.player-timeline-cadence-braces-review .player-cadence-brace-correct .player-timeline-cadence-brace-bar{background:linear-gradient(180deg,#05966940,#0596691a)}.player-timeline-cadence-braces-review .player-cadence-brace-correct .player-timeline-cadence-brace-label{background:#05966933}.player-timeline-cadence-braces-review .player-cadence-brace-incorrect .player-timeline-cadence-brace-bar,.player-timeline-cadence-braces-review .player-cadence-brace-incorrect .player-timeline-cadence-brace-label{border-color:#ef444480;color:#ef4444}.player-timeline-cadence-braces-review .player-cadence-brace-incorrect .player-timeline-cadence-brace-bar{background:linear-gradient(180deg,#ef444433,#ef444414)}.player-timeline-cadence-braces-review .player-cadence-brace-incorrect .player-timeline-cadence-brace-label{background:#ef444426}.player-timeline-cadence-braces-review .player-cadence-brace-preview .player-timeline-cadence-brace-bar,.player-timeline-cadence-braces-review .player-cadence-brace-preview .player-timeline-cadence-brace-label{border-color:#6366f180;color:#ffffffe6}.player-timeline-cadence-braces-review .player-cadence-brace-preview .player-timeline-cadence-brace-bar{background:linear-gradient(180deg,#6366f133,#6366f114)}.player-timeline-cadence-braces-review .player-cadence-brace-preview .player-timeline-cadence-brace-label{background:#6366f126}@media(max-width:768px){.player-timeline-equal-width.player-review-timeline .player-timeline-cadence-braces-review{top:-6px;left:0;right:0;height:18px}.player-timeline-equal-width.player-review-timeline .player-timeline-cadence-brace-bar{height:14px;border-radius:6px 6px 0 0}.player-timeline-equal-width.player-review-timeline .player-timeline-cadence-brace-label{top:0;font-size:.7rem}}.player-timeline-with-segments{position:relative;--desktop-segment-min-width: 72px;width:100%;height:80px;min-height:80px;background:#27272ab3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(255,255,255,.1);cursor:pointer;pointer-events:auto;overflow:visible;padding:8px 8px 10px;box-sizing:border-box;z-index:5}.player-timeline-with-segments-has-pedal{height:auto;min-height:100px;padding-bottom:14px}.player-timeline-pedal-lines{position:absolute;left:0;right:0;bottom:6px;height:2px;pointer-events:none;z-index:1}.player-timeline-pedal-line{position:absolute;bottom:0;height:2px;background:currentColor;opacity:.5;border-radius:1px}.player-chord-segment-pedal-notation{flex-shrink:0;margin-top:4px;padding-bottom:2px;font-size:.7rem;line-height:1.2;opacity:.95;font-variant-numeric:tabular-nums;min-height:1.2em}.player-pedal-notation-text{font-family:inherit;font-style:italic}.player-chord-segment-has-pedal-notation{flex-direction:column;justify-content:center}.player-timeline-segments-container{position:relative;width:100%;height:100%}.player-timeline-playhead{position:absolute;top:0;bottom:0;width:2px;background:#fbbf24;box-shadow:0 0 12px #fbbf24cc;z-index:20;pointer-events:none;transform:translate(-50%);transition:left .1s linear}.player-timeline-playhead-indicator{position:absolute;top:-4px;left:50%;transform:translate(-50%);width:12px;height:12px;background:#fbbf24;border:2px solid rgba(0,0,0,.8);border-radius:50%;box-shadow:0 0 8px #fbbf24e6}.player-chord-segment{position:absolute;top:8px;bottom:8px;min-width:var(--desktop-segment-min-width);border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;transition:all .2s ease;overflow:hidden;display:flex;align-items:center;justify-content:center;pointer-events:auto;background:#ffffff0d}.player-chord-segment-body{flex:1;min-height:0;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.player-chord-segment-borrowed .player-chord-segment-content{padding-left:6px;padding-right:6px;min-width:0}.player-timeline-equal-width .player-chord-segment{min-width:0}.player-chord-segment-last{right:8px;width:auto!important;min-width:0;box-sizing:border-box}.player-chord-segment:hover{border-color:#fff6;background:#ffffff1a;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.player-chord-segment-t{border-color:#3b82f680;background:#3b82f61a}.player-chord-segment-t:hover{border-color:#3b82f6cc;background:#3b82f633}.player-chord-segment-sd{border-color:#8b5cf680;background:#8b5cf61a}.player-chord-segment-sd:hover{border-color:#8b5cf6cc;background:#8b5cf633}.player-chord-segment-d{border-color:#ec489980;background:#ec48991a}.player-chord-segment-d:hover{border-color:#ec4899cc;background:#ec489933}.player-chord-segment-empty{border-color:#fff3;background:#ffffff0d}.player-chord-segment-answered{border-width:3px;box-shadow:0 0 16px #10b98166}.player-chord-segment-answered.player-chord-segment-t{border-color:#3b82f6cc;background:#3b82f640}.player-chord-segment-answered.player-chord-segment-sd{border-color:#8b5cf6cc;background:#8b5cf640}.player-chord-segment-answered.player-chord-segment-d{border-color:#ec4899cc;background:#ec489940}.player-chord-segment-correct{border-color:#059669e6!important;background:#05966933!important;box-shadow:0 0 24px #05966999,inset 0 0 20px #0596691a!important;animation:chordValidationCorrect .6s cubic-bezier(.34,1.56,.64,1),correctGlowPulse 2s ease-in-out infinite}@keyframes correctGlowPulse{0%,to{box-shadow:0 0 24px #05966999,0 0 40px #05966966,inset 0 0 20px #0596691a}50%{box-shadow:0 0 32px #059669cc,0 0 56px #05966999,inset 0 0 20px #0596691a}}.player-chord-segment-incorrect{border-color:#dc2626e6!important;background:#dc262633!important;box-shadow:0 0 24px #dc262699,inset 0 0 20px #dc26261a!important;animation:chordValidationIncorrect .6s cubic-bezier(.34,1.56,.64,1)}.player-chord-segment-partial{border-color:#eab308e6!important;background:#eab30833!important;box-shadow:0 0 24px #eab30899,inset 0 0 20px #eab3081a!important;animation:chordValidationPartial .6s cubic-bezier(.34,1.56,.64,1)}.player-chord-segment-animated{pointer-events:none;z-index:10}.player-chord-segment-locked{opacity:.5;filter:grayscale(.7);cursor:not-allowed;pointer-events:auto}.player-chord-segment-locked:hover{border-color:inherit!important;background:inherit!important;transform:none}.player-chord-solution-overlay{position:absolute;top:-55px;left:50%;transform:translate(-50%);z-index:15;pointer-events:none;animation:solutionSlideDown .5s cubic-bezier(.34,1.56,.64,1);min-width:-moz-max-content;min-width:max-content}.player-chord-solution-label{background:linear-gradient(135deg,#22c55ef2,#10b981f2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid rgba(34,197,94,.8);border-radius:8px;padding:6px 12px;box-shadow:0 4px 16px #22c55e66,0 0 24px #22c55e4d;white-space:nowrap;font-family:Georgia,Times New Roman,serif;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center}@media(max-width:768px){.player-chord-solution-overlay{top:-50px}.player-chord-solution-label{padding:4px 10px;font-size:.9em}}@media(max-width:480px){.player-chord-solution-overlay{top:-45px}.player-chord-solution-label{padding:3px 8px;font-size:.85em}}@keyframes chordValidationCorrect{0%{transform:scale(1);box-shadow:0 0 #05966900}50%{transform:scale(1.08);box-shadow:0 0 40px #059669e6,0 0 60px #059669b3,inset 0 0 30px #05966933}to{transform:scale(1);box-shadow:0 0 24px #05966999,0 0 40px #05966966,inset 0 0 20px #0596691a}}@keyframes chordValidationIncorrect{0%{transform:scale(1);box-shadow:0 0 #dc262600}50%{transform:scale(1.08);box-shadow:0 0 32px #dc2626cc,inset 0 0 30px #dc262633}to{transform:scale(1);box-shadow:0 0 24px #dc262699,inset 0 0 20px #dc26261a}}@keyframes chordValidationPartial{0%{transform:scale(1);box-shadow:0 0 #eab30800}50%{transform:scale(1.08);box-shadow:0 0 32px #eab308cc,inset 0 0 30px #eab30833}to{transform:scale(1);box-shadow:0 0 24px #eab30899,inset 0 0 20px #eab3081a}}@keyframes solutionSlideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.player-chord-segment-next{animation:pulseGlowSegment 2s ease-in-out infinite;box-shadow:0 0 20px #fbbf2499}@keyframes pulseGlowSegment{0%,to{box-shadow:0 0 20px #fbbf2499;transform:translateY(-2px)}50%{box-shadow:0 0 30px #fbbf24e6;transform:translateY(-4px)}}.player-chord-segment-progress{position:absolute;top:0;left:0;bottom:0;background:#fbbf244d;transition:width .1s linear;pointer-events:none;z-index:1}.player-chord-segment-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;padding:4px 8px;font-family:Georgia,Times New Roman,serif;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8)}.player-chord-function{font-size:1.5rem;font-weight:900}.player-chord-function-t{color:#60a5fa}.player-chord-function-sd{color:#a78bfa}.player-chord-function-d{color:#f9a8d4}.player-chord-segment-intuition .player-chord-segment-content{flex-direction:row;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:6px}.player-chord-segment-full-hint{font-size:.6rem;font-weight:600;opacity:.85;line-height:1.1;flex-shrink:0;white-space:nowrap;max-width:none}.player-chord-label{display:flex;align-items:baseline;gap:2px;font-size:1.25rem;color:#fffffff2}.player-chord-label .baroque-chord-label{color:inherit;font-size:inherit}.player-chord-label .chord-label-degree{font-size:1.2em}.player-chord-label .chord-label-figure{color:#ffffffb3}.player-chord-accidental{color:#fbbf24;font-size:1rem}.player-chord-degree{font-size:1.5rem;display:inline-flex;align-items:baseline;gap:2px}.player-chord-quality{font-size:1rem;color:#fffc}.player-chord-figure{font-size:.58em;font-family:sans-serif;color:#ffffffb3;vertical-align:super;position:relative;top:-.25em}.player-chord-figure-stacked{display:flex;flex-direction:column;line-height:.85}.player-chord-borrowed{color:#ffffff80;font-size:1.2rem}.player-chord-empty{display:flex;align-items:center;justify-content:center}.player-chord-empty-icon{font-size:1.5rem;color:#fff6;font-weight:700}.player-controls-group{display:flex;align-items:center;justify-content:center;gap:2rem}.player-time-display{font-size:1rem;font-weight:600;color:#ffffffe6;font-variant-numeric:tabular-nums;letter-spacing:.5px;min-width:120px;text-align:center}.player-play-btn{width:64px;height:64px;border-radius:50%;background:#fffffff2;border:none;color:#111827;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 4px 16px #0000004d;flex-shrink:0}.player-play-btn:hover{background:#fff;transform:scale(1.1);box-shadow:0 6px 20px #0006}.player-play-btn:active{transform:scale(1.05)}.player-finish-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea66;font-family:inherit}.player-finish-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea99}.player-finish-btn:active{transform:translateY(0)}@media(max-width:768px){.player-timeline-section .player-timeline-overlay{min-height:72px;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;--segment-min-width: clamp(44px, 12vw, 72px)}.player-timeline-overlay .player-timeline-content-frame{min-width:max(100%,calc(var(--segment-count, 1) * var(--segment-min-width, 44px)))}.player-review-integrated-timeline{--segment-min-width: clamp(44px, 12vw, 72px)}.player-timeline-with-segments.player-timeline-equal-width{min-width:max(100%,calc(var(--segment-count, 1) * var(--segment-min-width)))}.player-pedal-strip{min-height:28px}.player-control-zone{min-height:180px;padding:1.25rem 1.5rem;gap:1rem}.player-live-ranking-compact-btn{max-width:130px;font-size:.7rem;padding:.26rem .42rem}.player-open-full-video-btn{top:calc(env(safe-area-inset-top,0px) + 1.5rem);left:max(1rem,env(safe-area-inset-left,0px));padding:.5rem 1rem;font-size:.8125rem}.player-open-full-video-btn svg{width:16px;height:16px}.player-quit-btn{top:calc(env(safe-area-inset-top,0px) + 1.5rem);right:max(1rem,env(safe-area-inset-right,0px));padding:.5rem 1rem;font-size:.875rem}.player-quit-btn svg{width:16px;height:16px}.player-onboarding-coachmark{top:.3rem;width:calc(100% - 1rem);max-width:calc(100% - 1rem);justify-content:flex-start;border-radius:10px;padding:.38rem .55rem}.player-onboarding-coachmark p{font-size:.75rem;white-space:normal}.player-onboarding-coachmark-label{display:none}.player-video-zone .player-timeline-overlay{height:82px;padding:0 .75rem .75rem;overflow-x:auto;overflow-y:hidden}.player-timeline-overlay-has-cadences{min-height:114px}.player-timeline-with-segments{height:70px;padding:6px;flex-shrink:0}.player-chord-segment{min-width:50px}.player-chord-segment-last{right:6px;min-width:0}.player-chord-label{font-size:1rem}.player-chord-degree,.player-chord-function{font-size:1.25rem}.player-controls-group{gap:1.5rem}.player-play-btn{width:56px;height:56px}.player-time-display{font-size:.9375rem;min-width:100px}.player-finish-btn{padding:.625rem 1.25rem;font-size:.9375rem}.player-validation-feedback{bottom:11rem;max-width:95%;padding:.625rem 1rem}.player-validation-feedback-main{font-size:.9rem}.player-validation-feedback-revelation{font-size:.75rem}.player-segment-tooltip{bottom:11rem;max-width:95%;padding:.625rem 1rem}.player-segment-tooltip .player-validation-feedback-main{font-size:.9rem}.player-segment-tooltip .player-validation-feedback-revelation{font-size:.75rem}}@media(max-width:480px){.player-control-zone{min-height:160px;padding:1rem 1.25rem;gap:.875rem}.player-live-ranking-compact-btn{max-width:116px;font-size:.66rem;padding:.24rem .36rem}.player-open-full-video-btn{top:calc(env(safe-area-inset-top,0px) + 1.25rem);left:max(.75rem,env(safe-area-inset-left,0px));padding:.5rem .875rem;font-size:.75rem;gap:.375rem}.player-quit-btn{top:calc(env(safe-area-inset-top,0px) + 1.25rem);right:max(.75rem,env(safe-area-inset-right,0px));padding:.5rem .875rem;font-size:.8125rem;gap:.375rem}.player-onboarding-coachmark{width:calc(100% - .6rem);padding:.35rem .5rem}.player-onboarding-coachmark p{font-size:.72rem;line-height:1.2}.player-video-zone .player-timeline-overlay{height:68px;padding:0 .5rem .5rem;overflow-x:auto;overflow-y:hidden}.player-timeline-section .player-timeline-overlay{min-height:64px}.player-timeline-overlay-has-cadences{min-height:92px}.player-timeline-with-segments{height:60px;padding:4px;flex-shrink:0}.player-chord-segment{min-width:40px}.player-chord-segment-last{right:4px;min-width:0}.player-chord-label{font-size:.875rem}.player-chord-degree,.player-chord-function{font-size:1rem}.player-controls-group{gap:1rem}.player-play-btn{width:52px;height:52px}.player-time-display{font-size:.875rem;min-width:90px}.player-finish-btn{padding:.5rem 1rem;font-size:.875rem}.player-validation-feedback{bottom:12rem;max-width:95%;padding:.5rem .875rem}.player-validation-feedback-main{font-size:.875rem}.player-validation-feedback-revelation{font-size:.7rem}.player-segment-tooltip{bottom:12rem;max-width:95%;padding:.5rem .875rem}.player-segment-tooltip .player-validation-feedback-main{font-size:.875rem}.player-segment-tooltip .player-validation-feedback-revelation{font-size:.7rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}body.player-active{overflow:hidden!important;position:fixed;width:100%;height:100%;height:100dvh;height:var(--vvh, 100dvh)}.player-review-mode{display:flex;flex-direction:column;height:100vh;overflow:hidden}.player-teacher-preview-banner{position:absolute;top:calc(env(safe-area-inset-top,0px) + .5rem);left:max(1rem,env(safe-area-inset-left,0px));z-index:100;display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#1e3a8ae6;color:#fffffff2;border-radius:.5rem;font-size:.8125rem;box-shadow:0 2px 8px #00000040;pointer-events:none}.player-teacher-preview-banner-label{font-weight:600}.player-teacher-preview-banner-hint{opacity:.9}.player-teacher-preview-timer{font-weight:700;background:#0f172a59;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:.1rem .5rem}.player-live-waiting{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:radial-gradient(circle at 30% 20%,#3b82f633,#020617f2 60%)}.player-live-waiting-card{width:min(560px,100%);border-radius:14px;border:1px solid rgba(148,163,184,.25);background:#0f172adb;color:#e5e7eb;padding:1.1rem 1rem;box-shadow:0 14px 30px #02061773}.player-live-waiting-card h2{margin:0 0 .45rem;font-size:1.2rem}.player-live-waiting-card p{margin:0;color:#cbd5e1}.player-live-waiting-btn{margin-top:.9rem;border:1px solid rgba(148,163,184,.35);border-radius:10px;padding:.55rem .85rem;background:#1e293bcc;color:#e5e7eb;cursor:pointer}.player-live-timer-controls{position:relative;display:flex;flex-direction:column;gap:.4rem;padding:.5rem;border-radius:10px;background:#0f172adb;border:1px solid rgba(148,163,184,.4);width:-moz-fit-content;width:fit-content;max-width:min(94vw,520px)}.player-live-timer-controls--bottom{margin:.65rem auto .2rem}.player-live-timer-controls--inline{margin-left:.5rem;padding:.4rem;align-self:center}.player-live-timer-controls--inline .player-live-timer-controls-row{justify-content:flex-end}.player-live-timer-controls-row{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.player-live-timer-controls button,.player-live-timer-controls input{border:1px solid rgba(148,163,184,.45);background:#1e293bd9;color:#f8fafc;border-radius:8px;font-size:.78rem;padding:.3rem .55rem}.player-live-timer-controls button{cursor:pointer;font-weight:600}.player-live-timer-controls button.active{background:#4f46e5e6;border-color:#818cf8f2}.player-live-timer-controls button:disabled{opacity:.55;cursor:not-allowed}.player-live-timer-controls input{width:78px}.player-live-timer-overlay{position:absolute;top:50%;left:max(1.25rem,env(safe-area-inset-left,0px));transform:translateY(-50%);z-index:120;display:flex;flex-direction:column;align-items:center;gap:.08rem;padding:.28rem .72rem;border-radius:12px;border:2px solid rgba(255,255,255,.5);background:#020617b3;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.55)}.player-live-timer-overlay-label{font-size:clamp(.62rem,1.2vw,.78rem);letter-spacing:.12em;font-weight:700;opacity:.9}.player-live-timer-overlay-value{font-size:clamp(1.65rem,4.8vw,3.1rem);line-height:.95;letter-spacing:.06em;font-weight:800}@keyframes player-live-timer-shake{0%,to{transform:translateY(-50%) translate(0)}12%{transform:translateY(-50%) translate(-4px)}24%{transform:translateY(-50%) translate(4px)}36%{transform:translateY(-50%) translate(-3px)}48%{transform:translateY(-50%) translate(3px)}60%{transform:translateY(-50%) translate(-2px)}72%{transform:translateY(-50%) translate(2px)}84%{transform:translateY(-50%) translate(-1px)}}@keyframes player-live-timer-pulse-zero{0%,to{opacity:1;box-shadow:0 0 #ef444480}50%{opacity:.95;box-shadow:0 0 20px 4px #ef444466}}.player-live-timer-overlay--zero{animation:player-live-timer-shake .6s ease-in-out infinite,player-live-timer-pulse-zero 1.2s ease-in-out infinite;border-color:#ef4444cc;background:#7f1d1d80}.player-live-timer-overlay--zero .player-live-timer-overlay-value{color:#fca5a5}@media(max-width:768px){.player-live-timer-controls--bottom{margin-top:.5rem}.player-live-timer-controls--inline{margin-left:0;width:100%}.player-live-timer-controls--inline .player-live-timer-controls-row{justify-content:center}.player-live-timer-controls-row{gap:.25rem}.player-live-timer-controls button,.player-live-timer-controls input{font-size:.74rem;padding:.28rem .45rem}.player-live-timer-overlay{top:50%;left:max(.65rem,env(safe-area-inset-left,0px));padding:.22rem .56rem}.player-live-timer-overlay-label{font-size:.58rem}.player-live-timer-overlay-value{font-size:clamp(1.35rem,8vw,2.25rem)}.player-teacher-preview-banner{flex-direction:column;align-items:flex-start;gap:.2rem;max-width:calc(100vw - 6rem)}.player-teacher-preview-banner-hint{font-size:.75rem}}.player-badge-unlocked-banner{position:fixed;top:0;left:0;right:0;z-index:2000;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#8b5cf6f2,#667eeaf2);color:#fff;box-shadow:0 4px 12px #0003;animation:player-badge-banner-in .4s ease-out}@keyframes player-badge-banner-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.player-badge-unlocked-content{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:0}.player-badge-unlocked-title{font-weight:700;font-size:.95rem}.player-badge-unlocked-list{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.player-badge-unlocked-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;opacity:.95}.player-badge-unlocked-emoji{font-size:1.1rem}.player-badge-unlocked-dismiss{flex-shrink:0;width:32px;height:32px;border:none;background:#ffffff40;color:#fff;font-size:1.25rem;line-height:1;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.player-badge-unlocked-dismiss:hover{background:#fff6}.player-review-upper-zone{position:relative;flex:0 1 40%;min-height:0;overflow:hidden;display:flex;align-items:stretch}.player-video-blurred{position:absolute;inset:0;z-index:1}.player-review-mode .player-youtube{filter:blur(20px) brightness(.3);opacity:.2;pointer-events:none;width:100%;height:100%}.player-review-mode .player-youtube iframe{width:100%;height:100%}.player-review-timeline-zone{flex:0 0 auto;padding:clamp(.3rem,.8vh,.6rem) clamp(.5rem,2vw,1rem);background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);z-index:150;overflow:visible}.player-review-timeline-container{max-width:100%;overflow-x:auto;overflow-y:visible;position:relative;padding-top:36px;margin-top:-36px}.player-review-timeline{position:relative;height:clamp(55px,7vh,85px);background:#27272acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:clamp(8px,1vh,12px);border:1px solid rgba(255,255,255,.1);padding:clamp(4px,.5vh,7px);cursor:default;overflow:visible}@media(min-width:769px){.player-review-upper-zone{flex:0 1 28%;max-height:280px}.player-review-timeline{height:clamp(100px,14vh,160px)}.player-review-timeline-container{padding-top:40px;margin-top:-40px}.player-review-timeline .player-chord-segment .player-chord-degree,.player-review-timeline .player-chord-segment .player-chord-function{font-size:1.75rem}.player-review-timeline .player-chord-segment .player-chord-label{font-size:1.4rem}.player-review-timeline .player-chord-segment-intuition .player-chord-segment-full-hint{font-size:.72rem}.player-review-timeline .player-chord-segment{min-width:72px}}.player-review-segment{cursor:pointer;transition:all .2s ease}.player-review-segment:hover{transform:translateY(-3px);box-shadow:0 4px 16px #fff3}.player-segment-selected{border:3px solid rgba(255,255,255,.9)!important;box-shadow:0 0 24px #fff9,0 0 48px #ffffff4d!important;z-index:25!important;animation:segmentPulse 2s ease-in-out infinite}.player-chord-segment-given .player-chord-segment-content{opacity:.7}.player-chord-segment-given .player-chord-function,.player-chord-segment-given .player-chord-label,.player-chord-segment-given .player-chord-label .baroque-chord-label,.player-chord-segment-given .player-chord-degree,.player-chord-segment-given .player-chord-accidental,.player-chord-segment-given .player-chord-quality,.player-chord-segment-given .player-chord-figure,.player-chord-segment-given .chord-label-figure,.player-chord-segment-given .player-chord-borrowed{color:#a1a1aaf2!important}.player-chord-segment-given{border-color:#ffffff26!important;background:#3f3f4666!important}@keyframes segmentPulse{0%,to{box-shadow:0 0 24px #fff9,0 0 48px #ffffff4d}50%{box-shadow:0 0 32px #fffc,0 0 64px #ffffff80}}.player-immersive{transition:all .6s cubic-bezier(.34,1.56,.64,1)}.player-review-mode{animation:reviewModeTransition .8s cubic-bezier(.34,1.56,.64,1)}@keyframes reviewModeTransition{0%{opacity:0}to{opacity:1}}.player-open-chord-btn{position:fixed;bottom:6rem;right:1rem;width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-weight:700;box-shadow:0 8px 24px #4f46e580;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:30;border:2px solid rgba(255,255,255,.2);cursor:pointer;font-family:inherit}.player-open-chord-btn:hover{background:linear-gradient(135deg,#4338ca,#6d28d9);box-shadow:0 12px 32px #4f46e5b3;transform:translateY(-2px) scale(1.05)}.player-open-chord-btn:active{transform:translateY(0) scale(.95)}.player-open-chord-btn svg{width:24px;height:24px}@media(min-width:768px){.player-open-chord-btn{display:none}}@media(max-width:480px){.player-open-chord-btn{bottom:5.5rem;right:.75rem;width:3rem;height:3rem}.player-open-chord-btn svg{width:20px;height:20px}}.player-validation-feedback{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);max-width:90%;padding:.75rem 1.25rem;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(255,255,255,.15);z-index:100;text-align:center;animation:player-feedback-in .3s ease}@keyframes player-feedback-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player-validation-feedback-main{margin:0;font-size:.95rem;font-weight:600}.player-validation-feedback--level-1 .player-validation-feedback-main{color:#86efac}.player-validation-feedback--level-0\.5 .player-validation-feedback-main,.player-validation-feedback--level-2 .player-validation-feedback-main,.player-validation-feedback--level-3 .player-validation-feedback-main{color:#eab308}.player-validation-feedback--level-0 .player-validation-feedback-main{color:#f87171}.player-validation-feedback-revelation{margin:.35rem 0 0;font-size:.8rem;color:#ffffffb3}.player-validation-feedback-codex{margin:.5rem 0 0}.player-codex-link{display:inline-block;padding:.35rem .5rem;font-size:.8rem;color:#93c5fd;background:transparent;border:1px solid rgba(147,197,253,.4);border-radius:8px;cursor:pointer;text-decoration:none}.player-codex-link:hover{color:#bfdbfe;border-color:#93c5fdb3}.player-segment-tooltip{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);max-width:90%;padding:.75rem 1.25rem;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(255,255,255,.15);z-index:101;text-align:center;animation:player-feedback-in .3s ease}.player-segment-tooltip .player-validation-feedback-main{margin:0;font-size:.95rem;font-weight:600}.player-segment-tooltip.player-validation-feedback--level-1 .player-validation-feedback-main{color:#86efac}.player-segment-tooltip.player-validation-feedback--level-0\.5 .player-validation-feedback-main,.player-segment-tooltip.player-validation-feedback--level-2 .player-validation-feedback-main,.player-segment-tooltip.player-validation-feedback--level-3 .player-validation-feedback-main{color:#eab308}.player-segment-tooltip.player-validation-feedback--level-0 .player-validation-feedback-main{color:#f87171}.player-segment-tooltip .player-validation-feedback-revelation{margin:.35rem 0 0;font-size:.8rem;color:#ffffffb3}.player-review-integrated-video-zone{position:relative}.player-review-integrated--teacher-preview .player-review-integrated-overlay,.player-review-integrated--teacher-preview .player-review-integrated-score{animation:player-review-teacher-preview-fade-in .35s ease-out}@keyframes player-review-teacher-preview-fade-in{0%{opacity:0}to{opacity:1}}.player-chord-segment--flip-reveal{perspective:420px;transform-origin:center center}.player-chord-segment--flip-reveal:not(.player-chord-segment--flip-flip-active){animation:player-flip-reveal-dimension .6s cubic-bezier(.32,.72,.45,1) both}@keyframes player-flip-reveal-dimension{0%{transform:scale(.94);opacity:.92}to{transform:scale(1);opacity:1}}.player-chord-segment--flip-reveal .player-chord-segment-flip-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;animation:player-flip-reveal-inner .78s cubic-bezier(.32,.72,.45,1) forwards}.player-chord-segment--flip-reveal .player-chord-segment-flip-front,.player-chord-segment--flip-reveal .player-chord-segment-flip-back{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:inherit}.player-chord-segment--flip-reveal .player-chord-segment-flip-front{background:inherit;border:2px solid rgba(255,255,255,.35);box-shadow:inset 0 0 0 1px #00000026}.player-chord-segment--flip-reveal .player-chord-segment-flip-back{transform:rotateY(180deg);background:inherit}.player-chord-segment--flip-reveal .player-chord-segment-flip-back .player-chord-segment-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.player-chord-segment--flip-reveal .player-chord-segment-flip-front-icon{display:flex;align-items:center;justify-content:center;color:#ffffffb3}.player-chord-segment--flip-reveal .player-chord-segment-flip-front-svg{width:1.5rem;height:1.5rem}@keyframes player-flip-reveal-inner{0%{transform:rotateY(0) translateZ(0) translateY(0)}45%{transform:rotateY(90deg) translateZ(4px) translateY(-10px)}to{transform:rotateY(180deg) translateZ(0) translateY(0)}}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(1) .player-chord-segment-flip-inner{animation-delay:.06s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(1){animation-delay:.06s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(2) .player-chord-segment-flip-inner{animation-delay:.12s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(2){animation-delay:.12s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(3) .player-chord-segment-flip-inner{animation-delay:.18s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(3){animation-delay:.18s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(4) .player-chord-segment-flip-inner{animation-delay:.24s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(4){animation-delay:.24s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(5) .player-chord-segment-flip-inner{animation-delay:.3s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(5){animation-delay:.3s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(6) .player-chord-segment-flip-inner{animation-delay:.36s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(6){animation-delay:.36s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(7) .player-chord-segment-flip-inner{animation-delay:.42s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(7){animation-delay:.42s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(8) .player-chord-segment-flip-inner{animation-delay:.48s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(8){animation-delay:.48s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(9) .player-chord-segment-flip-inner{animation-delay:.54s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(9){animation-delay:.54s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(10) .player-chord-segment-flip-inner{animation-delay:.6s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(10){animation-delay:.6s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(n+11) .player-chord-segment-flip-inner{animation-delay:.66s}.player-review-integrated--teacher-preview .player-review-integrated-timeline .player-chord-segment--flip-reveal:nth-child(n+11){animation-delay:.66s}.player-review-integrated-video-blur{filter:blur(14px);transform:scale(1.05)}.player-review-integrated-overlay{position:absolute;inset:0;z-index:1;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;padding:1.5rem;box-sizing:border-box;overflow-y:auto}.player-review-integrated-overlay .player-feedback-card{position:absolute;bottom:10rem;left:50%;transform:translate(-50%);margin:0}@media(max-width:768px){.player-review-integrated-overlay .player-feedback-card{padding:.75rem 1rem;max-height:min(220px,35vh);overflow-y:auto}.player-review-integrated-overlay .player-feedback-card-message{margin-bottom:.5rem;font-size:.95rem}.player-review-integrated-overlay .player-feedback-card-comparison{margin-bottom:.5rem;gap:.35rem}.player-review-integrated-overlay .player-feedback-card-label,.player-review-integrated-overlay .player-feedback-card-value{font-size:.9rem}.player-review-integrated-overlay .player-feedback-card-cadence,.player-review-integrated-overlay .player-feedback-card-xp{margin-top:.35rem;font-size:.8rem}.player-review-integrated-overlay .player-feedback-card-codex{margin-top:.5rem;padding:.35rem .6rem;font-size:.8rem}}@media(max-width:480px){.player-review-integrated-overlay .player-feedback-card{padding:.6rem .875rem;max-height:min(200px,32vh)}.player-review-integrated-overlay .player-feedback-card-message{font-size:.9rem}}.player-review-integrated-score{position:absolute;top:1rem;left:50%;transform:translate(-50%);font-size:1.35rem;font-weight:700;color:#fff;background:#ffffff2e;padding:.5rem 1.25rem;border-radius:9999px;border:1px solid rgba(255,255,255,.25);box-shadow:0 2px 12px #0000004d;white-space:nowrap;z-index:2}.player-feedback-card{max-width:90%;width:100%;max-width:420px;padding:1.25rem 1.5rem;border-radius:14px;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid rgba(255,255,255,.2);text-align:left;box-sizing:border-box}.player-feedback-card--level-1{border-color:#86efac99}.player-feedback-card--level-0\.5,.player-feedback-card--level-2,.player-feedback-card--level-3{border-color:#eab308a6}.player-feedback-card--level-0{border-color:#f8717199}.player-feedback-card--correction-only{border-color:#6366f180}.player-feedback-card--correction-only .player-feedback-card-message{color:#fffffff2}.player-feedback-card-message{margin:0 0 1rem;font-size:1.05rem;font-weight:600}.player-feedback-card--level-1 .player-feedback-card-message{color:#86efac}.player-feedback-card--level-0\.5 .player-feedback-card-message,.player-feedback-card--level-2 .player-feedback-card-message,.player-feedback-card--level-3 .player-feedback-card-message{color:#eab308}.player-feedback-card--level-0 .player-feedback-card-message{color:#f87171}.player-feedback-card-comparison{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.player-feedback-card-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.player-feedback-card-label{font-size:.85rem;color:#ffffffa6;min-width:6rem}.player-feedback-card-value{font-size:1rem;color:#fff}.player-feedback-card-cadence,.player-feedback-card-xp{margin:.5rem 0 0;font-size:.9rem;color:#ffffffd9}.player-feedback-card-codex{margin-top:1rem;padding:.4rem .75rem;font-size:.875rem;color:#93c5fd;background:transparent;border:1px solid rgba(147,197,253,.4);border-radius:8px;cursor:pointer;font-family:inherit}.player-feedback-card-codex:hover{color:#bfdbfe;border-color:#93c5fdb3}.player-feedback-card-context{margin-top:.75rem;font-size:.8rem;color:#9ca3af;display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.player-feedback-card-context-icon{flex-shrink:0;color:#93c5fd;opacity:.9;display:inline-flex;align-items:center;justify-content:center}.player-feedback-card-context-label{margin-right:.25rem}.player-feedback-card-context-link{background:none;border:none;padding:.15rem .35rem;margin:0 -.35rem;font-size:inherit;color:#93c5fd;cursor:pointer;text-decoration:none;border-radius:4px;transition:color .15s ease,background-color .15s ease,text-decoration-color .15s ease}.player-feedback-card-context-link:hover,.player-feedback-card-context-link:focus-visible{color:#bfdbfe;background-color:#93c5fd1f;outline:none}.player-live-errors-block{margin-top:.7rem;padding-top:.55rem;border-top:1px solid rgba(148,163,184,.3)}.player-live-errors-title{margin:0 0 .45rem;font-size:.85rem;color:#c7d2fe;font-weight:700}.player-live-errors-empty{margin:0;font-size:.82rem;color:#e2e8f0cc}.player-live-errors-list{margin:0;padding:0;list-style:none;display:grid;gap:.4rem}.player-live-errors-item{display:grid;grid-template-columns:minmax(78px,1fr) minmax(90px,2fr) auto;align-items:center;gap:.4rem}.player-live-errors-label{font-size:.8rem;color:#ffffffe6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-live-errors-bar-wrap{height:8px;border-radius:999px;background:#475569a6;overflow:hidden}.player-live-errors-bar{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#ef4444)}.player-live-errors-value{font-size:.8rem;color:#fde68a}.player-review-integrated-timeline{z-index:9999}.player-review-integrated-btn-replay,.player-review-integrated-btn-next,.player-review-integrated-btn-back{min-width:2.5rem;min-height:2.5rem;padding:.5rem}@media(min-width:769px){.player-review-integrated-btn-replay,.player-review-integrated-btn-next,.player-review-integrated-btn-back{min-width:auto;padding:.5rem 1rem}}@media(max-width:768px){.player-review-integrated-timeline .player-timeline-with-segments .player-chord-segment{top:0;bottom:0}.player-review-integrated-timeline .player-timeline-with-segments{padding:4px}.player-review-integrated-overlay .player-feedback-card{bottom:6.5rem}}@media(max-width:480px){.player-review-integrated-overlay .player-feedback-card{bottom:6.5rem}}@media(max-width:768px){.player-timeline-overlay-has-cadences{overflow-y:visible;overflow-x:auto}.player-review-integrated-timeline.player-timeline-overlay-has-cadences{overflow-y:visible}}.player-review-integrated-timeline .player-timeline-cadence-braces-review .player-timeline-cadence-brace-bar{border-width:2px;box-shadow:0 0 0 1px #0000004d}.player-review-integrated-timeline .player-timeline-cadence-braces-review .player-timeline-cadence-brace-label{text-shadow:0 0 8px rgba(0,0,0,.8),0 1px 2px rgba(0,0,0,.9)}:root{--codex-bg: #0b1220;--codex-surface: #101a2f;--codex-surface-2: #0f172a;--codex-border: #2b3b57;--codex-text: #e5e7eb;--codex-muted: #9ca3af;--codex-primary: #6366f1;--codex-primary-strong: #4f46e5;--codex-success: #22c55e;--codex-danger: #ef4444;--codex-shadow: 0 10px 30px rgba(0, 0, 0, .25)}.codex-admin-page{padding:22px;color:var(--codex-text);background:radial-gradient(circle at 20% 0%,#1b2a46 0%,var(--codex-bg) 42%);min-height:calc(100vh - 40px)}.codex-admin-page h1,.codex-admin-page h2,.codex-admin-page h3,.codex-admin-page h4,.codex-admin-page p,.codex-admin-page label,.codex-admin-page span,.codex-admin-page small,.codex-admin-page strong{color:inherit}.codex-admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.codex-admin-header h1{margin:0;font-size:clamp(1.55rem,2.5vw,2rem);font-weight:700;letter-spacing:-.02em}.codex-admin-header-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.codex-admin-back-btn,.codex-admin-actions button,.codex-admin-template-row button,.codex-admin-add-row button,.codex-admin-revisions button,.codex-admin-mapping-list button{border:1px solid var(--codex-border);border-radius:10px;background:linear-gradient(180deg,#1b2a46,#15233c);color:#f8fafc;cursor:pointer;transition:all .16s ease}.codex-admin-back-btn,.codex-admin-actions button{padding:8px 12px}.codex-admin-template-row button,.codex-admin-add-row button{padding:7px 10px}.codex-admin-back-btn:hover,.codex-admin-actions button:hover,.codex-admin-template-row button:hover,.codex-admin-add-row button:hover,.codex-admin-revisions button:hover,.codex-admin-mapping-list button:hover{transform:translateY(-1px);border-color:#465d86;background:linear-gradient(180deg,#223252,#1b2b49)}.codex-admin-back-btn:focus-visible,.codex-admin-actions button:focus-visible,.codex-admin-template-row button:focus-visible,.codex-admin-add-row button:focus-visible,.codex-admin-revisions button:focus-visible,.codex-admin-mapping-list button:focus-visible,.codex-admin-doc-btn:focus-visible{outline:2px solid var(--codex-primary);outline-offset:2px}.codex-admin-actions{display:flex;gap:8px;flex-wrap:wrap}.codex-admin-actions button:nth-child(3){background:linear-gradient(180deg,#256d3c,#1f5a32);border-color:#2f8f4d}.codex-admin-actions button:nth-child(3):hover{border-color:#36aa5d}.codex-admin-actions .codex-admin-danger-btn{border-color:#7f1d1d;background:linear-gradient(180deg,#5a1820,#47131a);color:#fecaca}.codex-admin-actions .codex-admin-danger-btn:hover{border-color:#b91c1c}.codex-admin-message{margin:10px 0 14px;padding:10px 12px;border-radius:10px;border:1px solid #3a4d72;background:#1b2a46a6;color:#dbeafe}.codex-admin-layout{display:grid;grid-template-columns:280px minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}.codex-admin-editor,.codex-admin-preview{min-width:0}.codex-admin-list,.codex-admin-editor,.codex-admin-preview,.codex-admin-revisions,.codex-admin-mappings{border:1px solid var(--codex-border);border-radius:14px;padding:14px;background:linear-gradient(180deg,#101a2feb,#0f172af5);box-shadow:var(--codex-shadow)}.codex-admin-list{max-height:74vh;overflow:auto;position:sticky;top:12px}.codex-admin-list h3,.codex-admin-editor h3,.codex-admin-preview h3,.codex-admin-revisions h3,.codex-admin-mappings h3{margin:0 0 10px;font-size:1.02rem;font-weight:650}.codex-admin-list ul,.codex-admin-revisions ul,.codex-admin-mapping-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.codex-admin-archived-section{margin-top:10px;padding-top:10px;border-top:1px dashed #3a4f74}.codex-admin-archived-toggle{width:100%;padding:8px 10px;border-radius:10px;border:1px solid var(--codex-border);background:#1b2a468c;color:var(--codex-text);cursor:pointer;text-align:left;transition:all .16s ease}.codex-admin-archived-toggle:hover{border-color:#4b6391;background:#213351a6}.codex-admin-archived-list{margin-top:8px}.codex-admin-archived-empty{margin-top:8px;font-size:.88rem;color:var(--codex-muted)}.codex-admin-doc-btn{width:100%;text-align:left;padding:10px;border:1px solid var(--codex-border);border-radius:10px;background:#1b2a4685;color:#f8fafc;display:flex;justify-content:space-between;gap:8px;cursor:pointer;transition:all .15s ease}.codex-admin-doc-btn:hover{border-color:#5973a5;transform:translateY(-1px)}.codex-admin-doc-btn.active{border-color:var(--codex-primary);box-shadow:0 0 0 1px #6366f173;background:#464ea038}.codex-admin-doc-btn small{color:#c7d2fe;text-transform:uppercase;font-size:.72rem;letter-spacing:.04em}.codex-admin-errors{background:#7f1d1d4d;color:#fecaca;border:1px solid rgba(248,113,113,.6);border-radius:10px;padding:10px;margin-bottom:10px}.codex-admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.codex-admin-grid label,.codex-admin-mapping-builder-grid label{display:flex;flex-direction:column;gap:5px;font-size:.87rem;color:#cbd5e1}.codex-admin-grid input,.codex-admin-grid select,.codex-admin-block textarea,.codex-admin-block input,.codex-admin-mapping-builder-grid input,.codex-admin-mapping-builder-grid select,.codex-admin-mappings textarea{width:100%;max-width:100%;box-sizing:border-box;border:1px solid #3d5278;border-radius:10px;padding:9px 10px;background:#0c1528;color:#f8fafc;transition:border-color .12s ease,box-shadow .12s ease}.codex-admin-block textarea{display:block;resize:vertical;min-height:5rem}.codex-admin-grid input:focus,.codex-admin-grid select:focus,.codex-admin-block textarea:focus,.codex-admin-block input:focus,.codex-admin-mapping-builder-grid input:focus,.codex-admin-mapping-builder-grid select:focus,.codex-admin-mappings textarea:focus{outline:none;border-color:#647eff;box-shadow:0 0 0 3px #6366f12e}.codex-admin-template-row,.codex-admin-add-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.codex-admin-blocks{display:flex;flex-direction:column;gap:10px;margin-top:12px;width:100%;min-width:0}.codex-admin-block{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%;min-width:0;border:1px solid var(--codex-border);border-radius:12px;padding:10px;background:#1b2a4673}.codex-admin-block>textarea,.codex-admin-block>input{width:100%;max-width:100%;box-sizing:border-box}.codex-admin-block-header{display:flex;justify-content:space-between;margin-bottom:8px}.codex-admin-preview-card{border:1px solid var(--codex-border);border-radius:12px;padding:14px;background:#0c1528bf}.codex-admin-preview-card h2{margin-top:0}.codex-admin-revisions li,.codex-admin-mapping-list li{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid var(--codex-border);border-radius:10px;padding:9px 10px;background:#1b2a4666}.codex-admin-mappings p{color:var(--codex-muted);margin:4px 0 10px}.codex-admin-mapping-builder{border:1px solid var(--codex-border);border-radius:12px;padding:12px;margin-bottom:12px;background:#1b2a466b}.codex-admin-mapping-builder-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.codex-admin-mapping-list code{color:#bfdbfe}.codex-block-callout{border-left:4px solid #60a5fa;padding:10px 12px;background:#1e3a8a3d;border-radius:10px}.codex-block-example{background:#0b1220;color:#f9fafb;padding:12px;border-radius:10px;overflow-x:auto;border:1px solid #334155}.codex-block-divider{border:none;border-top:1px solid #334155;margin:16px 0}.codex-block-image-wrap{margin:12px 0}.codex-block-image{width:100%;border-radius:10px;border:1px solid #334155}@media(prefers-color-scheme:light){:root{--codex-bg: #f4f7fb;--codex-surface: #ffffff;--codex-surface-2: #f8fafc;--codex-border: #dbe2ef;--codex-text: #0f172a;--codex-muted: #64748b;--codex-shadow: 0 8px 24px rgba(15, 23, 42, .08)}.codex-admin-page{background:radial-gradient(circle at 12% 0%,#eef2ff 0%,var(--codex-bg) 45%)}.codex-admin-list,.codex-admin-editor,.codex-admin-preview,.codex-admin-revisions,.codex-admin-mappings{background:linear-gradient(180deg,#fff,#f9fbff)}.codex-admin-back-btn,.codex-admin-actions button,.codex-admin-template-row button,.codex-admin-add-row button,.codex-admin-revisions button,.codex-admin-mapping-list button{background:linear-gradient(180deg,#fff,#f8fafc);color:#0f172a;border:1px solid #d3dbe8}.codex-admin-actions button:nth-child(3){background:linear-gradient(180deg,#ecfdf3,#dcfce7);border-color:#86efac;color:#166534}.codex-admin-doc-btn,.codex-admin-block,.codex-admin-preview-card,.codex-admin-revisions li,.codex-admin-mapping-list li,.codex-admin-mapping-builder{background:#fff;border-color:#e2e8f0;color:#0f172a}.codex-admin-grid label,.codex-admin-mapping-builder-grid label{color:#334155}.codex-admin-grid input,.codex-admin-grid select,.codex-admin-block textarea,.codex-admin-block input,.codex-admin-mapping-builder-grid input,.codex-admin-mapping-builder-grid select,.codex-admin-mappings textarea{background:#fff;color:#0f172a;border-color:#d3dbe8}.codex-admin-message{color:#1e3a8a;background:#eff6ff;border-color:#bfdbfe}}@media(max-width:1280px){.codex-admin-layout{grid-template-columns:250px minmax(0,1fr)}.codex-admin-preview{grid-column:1 / -1}}@media(max-width:980px){.codex-admin-header{flex-direction:column;align-items:stretch}.codex-admin-layout{grid-template-columns:1fr}.codex-admin-list{position:static;max-height:none}.codex-admin-mapping-builder-grid,.codex-admin-grid{grid-template-columns:1fr}}.network-status{position:fixed;top:0;left:0;right:0;background:#ff6b6b;color:#fff;padding:12px 20px;text-align:center;z-index:10000;box-shadow:0 2px 8px #0003;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:500}.network-status.offline{background:#ff6b6b;animation:slideDown .3s ease-out}.network-status.online{background:#51cf66;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.network-icon{font-size:18px;flex-shrink:0}.network-message{flex:1}@media(max-width:768px){.network-status{padding:10px 15px;font-size:13px;flex-direction:row;gap:8px}.network-message{text-align:left}}
