*,:before,:after,::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:#3b82f680;--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:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family: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:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-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{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}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{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.static{position:static}.order-1{order:1}.order-2{order:2}.\!mx-auto{margin-left:auto!important;margin-right:auto!important}.mx-8{margin-left:2rem;margin-right:2rem}.mx-auto{margin-left:auto;margin-right:auto}.\!mb-2{margin-bottom:.5rem!important}.\!mb-4{margin-bottom:1rem!important}.\!ml-4{margin-left:1rem!important}.\!mr-4{margin-right:1rem!important}.\!mt-2{margin-top:.5rem!important}.\!mt-6{margin-top:1.5rem!important}.-mb-px{margin-bottom:-1px}.-ml-1{margin-left:-.25rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.\!table{display:table!important}.table{display:table}.grid{display:grid}.hidden{display:none}.size-32{width:8rem;height:8rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-fit{height:fit-content}.h-full{height:100%}.\!max-h-48{max-height:12rem!important}.max-h-64{max-height:16rem}.max-h-\[600px\]{max-height:600px}.max-h-\[800px\]{max-height:800px}.min-h-\[120px\]{min-height:120px}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-1\/3{width:33.3333%}.w-1\/4{width:25%}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-2\/3{width:66.6667%}.w-3{width:.75rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-fit{width:fit-content}.w-full{width:100%}.min-w-48{min-width:12rem}.\!max-w-48{max-width:12rem!important}.max-w-4xl{max-width:56rem}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.rotate-1{--tw-rotate:1deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-3{--tw-rotate:3deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(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)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{0%{transform:scale(1);box-shadow:0 2px 8px #06c6}50%{transform:scale(1.1);box-shadow:0 4px 16px #06c9}to{transform:scale(1);box-shadow:0 2px 8px #06c6}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.\!space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0!important;margin-right:calc(1rem * var(--tw-space-x-reverse))!important;margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))!important}.\!space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0!important;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)))!important;margin-bottom:calc(1rem * var(--tw-space-y-reverse))!important}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(2rem * var(--tw-space-x-reverse));margin-left:calc(2rem * calc(1 - var(--tw-space-x-reverse)))}.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))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(229 231 235/var(--tw-divide-opacity,1))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-b-xl{border-bottom-right-radius:.75rem;border-bottom-left-radius:.75rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.\!border-b{border-bottom-width:1px!important}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-solid{border-style:solid}.border-dashed{border-style:dashed}.\!border-gray-200{--tw-border-opacity:1!important;border-color:rgb(229 231 235/var(--tw-border-opacity,1))!important}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-400{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-emerald-300{--tw-border-opacity:1;border-color:rgb(110 231 183/var(--tw-border-opacity,1))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-300{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-green-400{--tw-border-opacity:1;border-color:rgb(74 222 128/var(--tw-border-opacity,1))}.border-indigo-200{--tw-border-opacity:1;border-color:rgb(199 210 254/var(--tw-border-opacity,1))}.border-orange-200{--tw-border-opacity:1;border-color:rgb(254 215 170/var(--tw-border-opacity,1))}.border-purple-200{--tw-border-opacity:1;border-color:rgb(233 213 255/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-400{--tw-border-opacity:1;border-color:rgb(248 113 113/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.border-violet-300{--tw-border-opacity:1;border-color:rgb(196 181 253/var(--tw-border-opacity,1))}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-yellow-200{--tw-border-opacity:1;border-color:rgb(254 240 138/var(--tw-border-opacity,1))}.border-yellow-300{--tw-border-opacity:1;border-color:rgb(253 224 71/var(--tw-border-opacity,1))}.border-t-transparent{border-top-color:#0000}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-indigo-100{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity,1))}.bg-orange-50{--tw-bg-opacity:1;background-color:rgb(255 247 237/var(--tw-bg-opacity,1))}.bg-purple-50{--tw-bg-opacity:1;background-color:rgb(250 245 255/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/50{background-color:#ffffff80}.bg-white\/60{background-color:#fff9}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.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-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:#eff6ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-50{--tw-gradient-from:#f9fafb var(--tw-gradient-from-position);--tw-gradient-to:#f9fafb00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-50{--tw-gradient-from:#f0fdf4 var(--tw-gradient-from-position);--tw-gradient-to:#f0fdf400 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-500{--tw-gradient-from:#22c55e var(--tw-gradient-from-position);--tw-gradient-to:#22c55e00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-50{--tw-gradient-from:#eef2ff var(--tw-gradient-from-position);--tw-gradient-to:#eef2ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-orange-50{--tw-gradient-from:#fff7ed var(--tw-gradient-from-position);--tw-gradient-to:#fff7ed00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-50{--tw-gradient-from:#faf5ff var(--tw-gradient-from-position);--tw-gradient-to:#faf5ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from:#f8fafc var(--tw-gradient-from-position);--tw-gradient-to:#f8fafc00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-cyan-50{--tw-gradient-to:#ecfeff var(--tw-gradient-to-position)}.to-emerald-50{--tw-gradient-to:#ecfdf5 var(--tw-gradient-to-position)}.to-gray-100{--tw-gradient-to:#f3f4f6 var(--tw-gradient-to-position)}.to-gray-50{--tw-gradient-to:#f9fafb var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-red-50{--tw-gradient-to:#fef2f2 var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.fill-current{fill:currentColor}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-3{padding:.75rem!important}.\!p-4{padding:1rem!important}.\!p-5{padding:1.25rem!important}.\!p-6{padding:1.5rem!important}.\!p-8{padding:2rem!important}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.\!px-4{padding-left:1rem!important;padding-right:1rem!important}.\!px-6{padding-left:1.5rem!important;padding-right:1.5rem!important}.\!py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.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}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.\!pt-4{padding-top:1rem!important}.pb-2{padding-bottom:.5rem}.pr-4{padding-right:1rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.\!text-center{text-align:center!important}.text-center{text-align:center}.text-right{text-align:right}.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-6xl{font-size:3.75rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.tracking-wider{letter-spacing:.05em}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-emerald-700{--tw-text-opacity:1;color:rgb(4 120 87/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity,1))}.text-orange-700{--tw-text-opacity:1;color:rgb(194 65 12/var(--tw-text-opacity,1))}.text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234/var(--tw-text-opacity,1))}.text-purple-800{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-violet-700{--tw-text-opacity:1;color:rgb(109 40 217/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.text-yellow-500{--tw-text-opacity:1;color:rgb(234 179 8/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:rgb(202 138 4/var(--tw-text-opacity,1))}.text-yellow-700{--tw-text-opacity:1;color:rgb(161 98 7/var(--tw-text-opacity,1))}.text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-gray-500::placeholder{--tw-placeholder-opacity:1;color:rgb(107 114 128/var(--tw-placeholder-opacity,1))}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--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-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--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 #0000001a, 0 2px 4px -2px #0000001a;--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-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 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)}.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)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-property:opacity;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}:root{--primary-color:#475569;--primary-light:#64748b;--primary-dark:#334155;--accent-color:#1e293b;--success-color:#059669;--light-gray:#f1f5f9;--medium-gray:#e2e8f0;--dark-gray:#64748b;--text-primary:#1e293b;--text-secondary:#475569;--navbar-bg:#1e293b;--white:#fff;--black:#000;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-light:0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--transition:all .3s ease;--color-primary:var(--primary-color);--color-primary-light:var(--light-gray);--color-accent:var(--primary-dark);--color-text:var(--text-primary);--color-text-muted:var(--text-secondary);--color-background-light:var(--light-gray);--color-border:var(--medium-gray);--color-hover:var(--light-gray);--color-success:#059669;--color-warning:#d97706;--color-warning-light:#fef3c7;--color-accent-light:#e2e8f0;--text-dark:var(--text-primary);--text-muted:var(--text-secondary)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#0f172a;background-color:var(--white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin-bottom:.5rem;font-weight:600;line-height:1.2}h1{font-family:var(--font-shojumaru), system-ui, sans-serif;font-size:2.5rem}h2{font-family:var(--font-bebas-neue), system-ui, sans-serif;letter-spacing:.025em;font-size:2rem}.navbar-brand h2{font-family:var(--font-shojumaru), system-ui, sans-serif;letter-spacing:normal}h3{font-size:1.5rem}p{color:var(--text-secondary);margin-bottom:1rem;line-height:1.7}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.section-header{text-align:center;margin-bottom:3rem}.section-header h2{color:var(--text-primary);margin-bottom:1rem;display:inline-block;position:relative}.section-header h2:after{content:"";background:var(--primary-color);border-radius:2px;width:50px;height:3px;margin:.5rem auto 0;display:block}.section-header p{max-width:600px;margin:0 auto;font-size:1.1rem}.btn{text-align:center;cursor:pointer;transition:var(--transition);border:2px solid #0000;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;display:inline-block}.btn-primary{background:var(--primary-color);color:var(--white);border-color:var(--primary-color);letter-spacing:.03em;text-transform:uppercase;font-size:.9rem}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 20px #47556966}.btn-secondary{color:#ffffffd9;letter-spacing:.03em;text-transform:uppercase;background:0 0;border-color:#fff6;font-size:.9rem}.btn-secondary:hover{color:var(--white);background:#ffffff1a;border-color:#ffffffb3;transform:translateY(-2px)}.btn-danger{color:var(--white);background:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;transform:translateY(-2px);box-shadow:0 10px 15px -3px #dc262633,0 4px 6px -2px #dc26261a}.btn-full{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.navbar{background:var(--navbar-bg);z-index:100;width:100%;position:sticky;top:0;box-shadow:0 2px 8px #0006}.navbar-content{justify-content:space-between;align-items:center;padding:1rem 0;display:flex}.navbar-brand{color:var(--white);text-decoration:none}.navbar-brand:hover{color:var(--primary-light)}.navbar-brand h2{color:var(--white);margin:0;font-size:1.5rem}.navbar-menu{align-items:center;gap:1rem;display:flex}.navbar-link{color:#ffffffd9;transition:var(--transition);letter-spacing:.01em;font-weight:500;text-decoration:none}.navbar-link:hover{color:var(--white)}.navbar-btn{margin-left:1rem}.navbar-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;padding:.5rem;display:none}.navbar-toggle span{background:var(--white);width:25px;height:3px;margin:3px 0;transition:all .3s}.profile-dropdown{margin-left:1rem;display:inline-block;position:relative}.profile-button{cursor:pointer;color:#ffffffd9;transition:var(--transition);background:0 0;border:none;border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.profile-button:hover{color:var(--white);background-color:#ffffff1a}.profile-icon{background-color:var(--primary-color);width:40px;height:40px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.profile-name{white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-weight:500;overflow:hidden}.dropdown-arrow{transition:transform .2s}.dropdown-arrow.open{transform:rotate(180deg)}.profile-dropdown-menu{background:var(--white);border:1px solid var(--medium-gray);box-shadow:var(--shadow-lg);z-index:50;border-radius:.5rem;min-width:180px;margin-top:.25rem;position:absolute;top:100%;right:0;overflow:hidden}.dropdown-item{width:100%;color:var(--text-primary);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.875rem;text-decoration:none;display:flex}.dropdown-item:hover{background-color:var(--light-gray)}.dropdown-item svg{color:var(--dark-gray)}.logout-item{border-top:1px solid var(--medium-gray);color:#dc2626}.logout-item:hover{background-color:#fef2f2}.logout-item svg{color:#dc2626}.user-profile .profile-section{margin-bottom:2rem}.profile-header{align-items:center;gap:1.5rem;margin-bottom:1.5rem;display:flex}.profile-avatar .avatar-circle{background:linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);width:80px;height:80px;color:var(--white);box-shadow:var(--shadow);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:600;display:flex}.profile-info h3{color:var(--text-primary);margin-bottom:.25rem;font-size:1.5rem}.profile-email{color:var(--text-secondary);margin-bottom:.25rem}.profile-member-since{color:var(--text-secondary);font-size:.875rem;font-style:italic}.ranks-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.rank-card{background:var(--light-gray);border:1px solid var(--medium-gray);transition:var(--transition);border-radius:.5rem;padding:1.5rem}.rank-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.rank-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.belt-indicator{border:2px solid var(--medium-gray);width:12px;height:40px;box-shadow:var(--shadow-light);border-radius:6px}.rank-discipline{color:var(--text-primary);font-size:1.1rem;font-weight:600}.rank-title{color:var(--primary-color);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.rank-date{color:var(--text-secondary);font-size:.875rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section-header h4{margin:0;font-size:1.1rem}.description-editor{margin-top:1rem}.description-textarea{border:2px solid var(--medium-gray);resize:vertical;width:100%;min-height:120px;transition:var(--transition);border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:.875rem;line-height:1.5}.description-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4755691a}.editor-buttons{gap:.75rem;margin-top:1rem;display:flex}.description-display p{color:var(--text-primary);margin:0;line-height:1.6}.description-empty{color:var(--text-secondary);font-style:italic}.hero{color:var(--white);background:linear-gradient(135deg,#0f172a 0%,#1c1917 60%,#1a0a0a 100%);align-items:center;min-height:85vh;padding:8rem 0;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#47556933 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-50%;right:-10%}.hero .container{flex-direction:column;align-items:center;gap:4rem;display:flex}.hero-content h1{color:var(--white);text-shadow:0 2px 20px #0000004d;text-align:center;margin-bottom:1.5rem;font-size:3.75rem;line-height:1.1}.hero-subtitle{color:#ffffffbf;text-align:center;max-width:600px;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;font-size:1.2rem;line-height:1.7}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.hero-image{justify-content:center;display:flex}.placeholder-image{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:1rem;justify-content:center;align-items:center;width:100%;max-width:400px;height:300px;display:flex}.placeholder-image p{color:#fffc;text-align:center;font-size:1.1rem}.hero-curriculum{width:100%;max-width:1000px}.hero-curriculum h2{color:#ffffffe6;text-align:center;letter-spacing:.05em;margin-bottom:2rem;font-size:2rem;font-weight:700}.curriculum-loading,.curriculum-error{text-align:center;color:#fffc;padding:2rem}.hero-curriculum-card{cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #0000;border-radius:12px;transition:all .3s;overflow:hidden;box-shadow:0 4px 12px #00000026}.hero-curriculum-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000040}.hero-curriculum-card.collapsed{max-height:120px}.hero-curriculum-card.expanded{max-height:600px;overflow-y:auto}.hero-curriculum-card.white{color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#47556980 0%,#33415599 100%);border-color:#ffffff1f}.hero-curriculum-card.brown{color:#fff;background:linear-gradient(135deg,#92400ee6 0%,#78350fe6 100%)}.hero-curriculum-card.green{color:#fff;background:linear-gradient(135deg,#22c55ee6 0%,#16a34ae6 100%)}.hero-curriculum-card.blue{color:#fff;background:linear-gradient(135deg,#3b82f6e6 0%,#2563ebe6 100%)}.hero-curriculum-card.red{color:#fff;background:linear-gradient(135deg,#dc2626e6 0%,#b91c1ce6 100%)}.hero-curriculum-card.black{color:#fff;background:linear-gradient(135deg,#1f2937e6 0%,#111827e6 100%)}.card-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.hero-curriculum-card.white .card-header{border-bottom-color:#ffffff26}.category-info{flex:1;align-items:center;display:flex}.category-icon{text-shadow:0 2px 4px #0000004d,0 1px 2px #0003;filter:drop-shadow(1px 1px 2px #0006);margin-right:1rem;font-size:1.5rem}.category-text h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600}.category-text p{opacity:.9;margin:0;font-size:.875rem}.expand-indicator{margin-left:1rem}.arrow{opacity:.7;font-size:.875rem;transition:transform .3s}.card-content{padding:0 1.5rem 1.5rem;animation:.3s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.techniques-list{gap:.75rem;margin-top:1rem;display:grid}.technique-card{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;align-items:center;padding:.75rem 1rem;transition:all .2s;display:flex}.hero-curriculum-card.white .technique-card{color:#ffffffe6;background:#ffffff14;border-color:#ffffff26}.technique-card:hover{background:#ffffffb3;transform:translate(4px)}.hero-curriculum-card.white .technique-card:hover{background:#ffffff26;transform:translate(4px)}.technique-content{flex:1}.technique-content h5{margin:0 0 .25rem;font-size:.9rem;font-weight:600}.korean-name{opacity:.8;margin-bottom:.25rem;font-size:.75rem;font-style:italic;display:block}.technique-description{opacity:.7;margin:0;font-size:.75rem;line-height:1.4}.no-techniques{text-align:center;opacity:.7;margin:1rem 0;font-style:italic}@media (max-width:768px){.curriculum-categories-grid{grid-template-columns:1fr;gap:1rem}.hero-curriculum-card{margin:0 1rem}.hero-curriculum h2{font-size:1.5rem}.card-header{padding:1rem}.card-content{padding:0 1rem 1rem}}.about{background:var(--white);padding:6rem 0}.about-content{grid-template-columns:1fr;align-items:start;gap:3rem;max-width:800px;margin-top:3rem;margin-left:auto;margin-right:auto;display:grid}.about-text h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.3rem}.about-text p{margin-bottom:1.5rem;line-height:1.7}.about-text ul{margin-bottom:2rem;padding:0;list-style:none}.about-text li{padding:.5rem 0 .5rem 1.5rem;position:relative}.about-text li:before{content:"✓";color:var(--primary-color);font-weight:700;position:absolute;left:0}.stats{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem;display:grid}.stat{text-align:center;background:var(--light-gray);border:1px solid var(--medium-gray);transition:var(--transition);border-radius:.75rem;padding:1.5rem}.stat:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #47556926}.stat h4{color:var(--primary-color);margin-bottom:.25rem;font-size:2.25rem;font-weight:700}.stat p{color:var(--text-secondary);margin:0;font-size:.9rem}.about-image .placeholder-image{background:var(--accent-color);height:400px;color:var(--white)}.schedule-section{background:var(--white);padding:6rem 0}.schedule-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;display:grid}.schedule-card{background:var(--white);box-shadow:var(--shadow);transition:var(--transition);border-radius:1rem;padding:2rem}.schedule-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.schedule-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.schedule-header h3{color:var(--primary-color)}.day{background:var(--primary-color);color:var(--white);border-radius:1rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.schedule-info{margin-bottom:2rem}.time{color:var(--primary-color);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.instructor{color:var(--text-secondary);margin-bottom:1rem}.description{color:var(--text-secondary);line-height:1.6}.instructors-section{background:var(--light-gray);border-top:1px solid var(--medium-gray);padding:6rem 0}.instructors-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.instructor-card{background:var(--white);transition:var(--transition);border:1px solid var(--medium-gray);border-radius:1rem;overflow:hidden;box-shadow:0 2px 12px #00000014}.instructor-card:hover{border-color:#0000;transform:translateY(-6px);box-shadow:0 12px 32px #00000024}.instructor-image{background:var(--medium-gray);height:280px;position:relative;overflow:hidden}.instructor-image img{-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top;width:100%;height:100%;transition:transform .4s}.instructor-card:hover .instructor-image img{transform:scale(1.04)}.instructor-image .placeholder-image{height:100%;color:var(--white);background:linear-gradient(135deg,#1e293b,#374151);border-radius:0}.instructor-info{padding:2rem}.instructor-info h3{color:var(--text-primary);margin-bottom:.25rem;font-size:1.2rem}.specialty{color:var(--primary-color);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.experience{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.bio{line-height:1.6}.contact-section{background:var(--white);padding:6rem 0}.contact-content{grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;display:grid}.contact-item{margin-bottom:2rem}.contact-item strong{color:var(--primary-color);margin-bottom:.5rem;display:block}.form-group{margin-bottom:1.5rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group label{color:var(--text-primary);margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group textarea{border:2px solid var(--medium-gray);width:100%;transition:var(--transition);border-radius:.5rem;padding:.75rem;font-size:1rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4755691a}.auth-page{background:var(--light-gray);align-items:center;min-height:100vh;padding:2rem 0;display:flex}.auth-container{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;max-width:1000px;margin:0 auto;display:grid}.auth-card{background:var(--white);box-shadow:var(--shadow-lg);border-radius:1rem;padding:3rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{color:var(--primary-color);margin-bottom:.5rem}.auth-form .form-group{margin-bottom:1.5rem}.auth-footer{text-align:center;margin-top:2rem}.auth-link{color:var(--primary-color);font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-image .placeholder-image{background:var(--primary-color);height:400px;color:var(--white)}.error-message{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1rem;padding:.75rem}.success-message{text-align:center;padding:2rem}.success-message h1{color:var(--primary-color);margin-bottom:1rem}.submit-message{border-radius:.5rem;margin-top:1rem;padding:.75rem}.submit-message.success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.submit-message.error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.footer{color:var(--white);border-top:3px solid var(--primary-light);background:#0f172a;padding:4rem 0 1.5rem}.footer-content{grid-template-columns:repeat(4,1fr);gap:2rem;margin-bottom:2rem;display:grid}.footer-section h3,.footer-section h4{color:var(--white);margin-bottom:1rem}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:.5rem}.footer-section ul li a{color:#fffc;transition:var(--transition);text-decoration:none}.footer-section ul li a:hover{color:var(--white)}.social-links{gap:1rem;margin-top:1rem;display:flex}.social-link{color:#fffc;transition:var(--transition);text-decoration:none}.social-link:hover{color:var(--white)}.footer-bottom{border-top:1px solid #fff3;justify-content:space-between;align-items:center;padding-top:2rem;display:flex}.footer-links{gap:2rem;display:flex}.footer-links a{color:#fffc;transition:var(--transition);text-decoration:none}.footer-links a:hover{color:var(--white)}.loading{text-align:center;color:var(--text-secondary);padding:2rem}@media (max-width:768px){.container{padding:0 1rem}.hero{padding:4rem 0}.hero .container{grid-template-columns:1fr;gap:2rem}.hero-content h1{font-size:2.5rem}.hero-buttons{justify-content:center}.about-content,.contact-content{grid-template-columns:1fr;gap:2rem}.stats{grid-template-columns:1fr;gap:1rem}.schedule-grid,.instructors-grid{grid-template-columns:1fr}.auth-container{grid-template-columns:1fr;gap:2rem}.auth-card{padding:2rem}.form-row{grid-template-columns:1fr}.footer-content{grid-template-columns:1fr 1fr;gap:2rem}.footer-bottom{text-align:center;flex-direction:column;gap:1rem}.navbar-menu{background:var(--navbar-bg);opacity:0;visibility:hidden;flex-direction:column;padding:2rem;transition:all .3s;position:fixed;top:80px;left:0;right:0;transform:translateY(-100%);box-shadow:0 8px 20px #0006}.navbar-menu.active{opacity:1;visibility:visible;transform:translateY(0)}.navbar-toggle{display:flex}.navbar-btn{margin-top:1rem;margin-left:0}.profile-dropdown{width:100%;margin-top:1rem;margin-left:0}.profile-button{background-color:#ffffff14;border-radius:.5rem;justify-content:space-between;width:100%;padding:1rem}.profile-dropdown-menu{width:100%;box-shadow:none;background-color:#0000;border:none;margin-top:.5rem;position:static}.dropdown-item{background-color:var(--white);border:1px solid var(--medium-gray);border-radius:.375rem;margin-bottom:.25rem;padding:.75rem 1rem}}@media (max-width:480px){.hero-content h1{font-size:2rem}.section-header h2{font-size:1.5rem}.footer-content{grid-template-columns:1fr}}.customer-portal{background-color:var(--light-gray);min-height:100vh;padding:2rem 0}.portal-content{max-width:1200px;margin:0 auto;padding:2rem}.account-section,.payment-section,.subscription-section,.payment-form-section{background:#fff;border-radius:8px;margin-bottom:2rem;padding:2rem;box-shadow:0 2px 4px #0000001a}.account-info{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem;display:grid}.account-info p{background-color:var(--light-gray);border-radius:4px;margin:0;padding:1rem}.status{text-transform:capitalize;border-radius:4px;margin-left:.5rem;padding:.25rem .5rem;font-size:.875rem;font-weight:600}.status.active{color:#166534;background-color:#dcfce7}.status.inactive{color:#991b1b;background-color:#fee2e2}.status.past_due{color:#92400e;background-color:#fef3c7}.payment-form{align-items:end;gap:1rem;margin-top:1rem;display:flex}.payment-form input{border:1px solid var(--medium-gray);border-radius:4px;flex:1;padding:.75rem;font-size:1rem}.plans-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem;display:grid}.plan-card{border:2px solid var(--medium-gray);text-align:center;background:#fff;border-radius:8px;padding:2rem;transition:transform .2s,box-shadow .2s}.plan-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.plan-card.featured{border-color:var(--primary-color);background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);position:relative}.plan-card.featured:before{content:"Most Popular";background:var(--primary-color);color:#fff;border-radius:20px;padding:.25rem 1rem;font-size:.875rem;font-weight:600;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.plan-card h3{color:var(--primary-color);margin-bottom:.5rem}.price{color:var(--primary-color);margin-bottom:1rem;font-size:2rem;font-weight:700}.plan-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem;line-height:1.4}.plan-card ul{margin:1.5rem 0;padding:0;list-style:none}.plan-card li{border-bottom:1px solid var(--light-gray);padding:.5rem 0}.plan-card li:last-child{border-bottom:none}.payment-form-section{max-width:600px;margin:0 auto}.payment-form{margin:2rem 0}.loading{text-align:center;color:var(--primary-color);padding:4rem 2rem;font-size:1.125rem}.error{text-align:center;color:#dc2626;background-color:#fef2f2;border-radius:8px;margin:2rem 0;padding:4rem 2rem}.error-message{color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-top:1rem;padding:1rem}@media (max-width:768px){.portal-content{padding:1rem}.account-info{grid-template-columns:1fr}.payment-form{flex-direction:column;align-items:stretch}.plans-grid{grid-template-columns:1fr}.plan-card{margin-bottom:1rem}}.student-portal-page{background:var(--light-gray);min-height:100vh;padding:2rem 0}.portal-header{text-align:center;margin-bottom:3rem}.portal-header h1{color:var(--primary-color);margin-bottom:.5rem;font-size:2.5rem}.portal-header p{color:var(--text-secondary);font-size:1.2rem}.portal-content{max-width:1200px;margin:0 auto}.portal-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:2rem;display:grid}.portal-card{background:var(--white);box-shadow:var(--shadow-lg);border-radius:1rem;transition:transform .3s,box-shadow .3s;overflow:hidden}.portal-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.card-header{background:var(--primary-color);color:var(--white);padding:1.5rem}.card-header h2{margin:0;font-size:1.5rem}.card-content{padding:2rem}.info-group{border-bottom:1px solid var(--light-gray);justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.info-group:last-child{border-bottom:none}.info-group label{color:var(--text-primary);flex:1;font-weight:600}.info-group span{text-align:right;color:var(--text-secondary);flex:2}.account-type{background:var(--primary-color);color:var(--white);border-radius:1rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.subscription-status{text-transform:capitalize;border-radius:1rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.subscription-status.active{color:#166534;background:#dcfce7}.subscription-status.inactive,.subscription-status.canceled{color:#991b1b;background:#fee2e2}.subscription-status.past_due{color:#92400e;background:#fef3c7}.balance{font-size:1.1rem;font-weight:600}.balance.positive{color:#16a34a}.balance.negative{color:#dc2626}.action-buttons{gap:1rem;display:grid}.btn-danger{color:var(--white);background:#dc2626;border:2px solid #dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.loading-message{text-align:center;padding:4rem 0}.loading-message h2{color:var(--text-secondary);font-size:1.5rem}.billing-section{grid-column:1/-1;min-height:auto}.billing-item{border-bottom:1px solid var(--medium-gray);margin-bottom:2rem;padding-bottom:2rem}.billing-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.billing-item h3{color:var(--primary-color);margin-bottom:1rem;font-size:1.2rem}.balance-display{background:var(--light-gray);border-radius:8px;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;display:flex}.balance-amount{font-size:2rem;font-weight:700}.balance-display.negative .balance-amount{color:#dc2626}.balance-display.positive .balance-amount{color:#16a34a}.balance-status{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.9rem}.subscription-card{border:1px solid var(--medium-gray);background:var(--white);border-radius:8px;margin-bottom:1rem;padding:1rem}.status-active{color:#16a34a}.status-paused{color:#f59e0b}.status-canceled,.status-past_due{color:#dc2626}.subscription-actions{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.cancellation-notice{color:#f59e0b;margin-top:.5rem;font-size:.9rem;font-weight:500}.invoices-list{flex-direction:column;gap:.75rem;display:flex}.invoice-item{justify-content:between;border:1px solid var(--medium-gray);background:var(--white);border-radius:6px;align-items:center;padding:.75rem;display:flex}.invoice-info{flex:1;align-items:center;gap:1rem;display:flex}.invoice-date{color:var(--text-secondary);min-width:100px;font-size:.9rem}.invoice-amount{color:var(--text-primary);min-width:80px;font-weight:600}.invoice-status{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:.25rem .5rem;font-size:.85rem;font-weight:500}.status-paid{color:#166534;background:#dcfce7}.status-open{color:#92400e;background:#fef3c7}.status-draft{background:var(--medium-gray);color:var(--text-secondary)}.payment-methods-list{flex-direction:column;gap:.5rem;display:flex}.payment-method-item{border:1px solid var(--medium-gray);background:var(--white);border-radius:6px;align-items:center;padding:.75rem;display:flex}.card-info{align-items:center;gap:1rem;display:flex}.card-brand{color:var(--primary-color);text-transform:uppercase;font-size:.9rem;font-weight:600}.card-last4{color:var(--text-primary);font-family:Courier New,monospace;font-size:1rem}.card-exp{color:var(--text-secondary);font-size:.9rem}.payment-modal{z-index:1000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.payment-modal-content{background:var(--white);border-radius:12px;width:90%;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto}.payment-modal-content h3{color:var(--primary-color);margin-bottom:1rem}.payment-form{margin-top:1rem}.card-element-container{border:1px solid var(--medium-gray);background:var(--white);border-radius:6px;margin-bottom:1rem;padding:1rem}.payment-form-actions{justify-content:flex-end;gap:1rem;margin-top:1rem;display:flex}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-bottom:1rem;padding:.5rem;font-size:.9rem}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.current-subscriptions-section{margin-bottom:3rem}.current-subscriptions-section h2{color:var(--primary-color);margin-bottom:1.5rem}.subscriptions-list{flex-direction:column;gap:1rem;display:flex}.subscription-card{border:2px solid var(--medium-gray);background:var(--white);box-shadow:var(--shadow);border-radius:12px;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem;display:flex}.subscription-card:hover{border-color:var(--primary-light)}.subscription-info{flex:1}.subscription-info h4{color:var(--primary-color);margin-bottom:.5rem;font-size:1.2rem}.subscription-amount{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.subscription-status,.subscription-period{color:var(--text-secondary);margin-bottom:.25rem;font-size:.9rem}.status-active{color:#16a34a;font-weight:600}.status-paused{color:#f59e0b;font-weight:600}.status-canceled,.status-past_due{color:#dc2626;font-weight:600}.cancellation-notice{color:#f59e0b;background:#fef3c7;border-radius:6px;margin-top:.5rem;padding:.5rem;font-size:.9rem;font-weight:500}.subscription-actions{flex-direction:column;gap:.5rem;min-width:120px;display:flex}@media (max-width:768px){.subscription-actions{flex-direction:column}.invoice-info{flex-direction:column;align-items:flex-start;gap:.5rem}.card-info{flex-direction:column;align-items:flex-start;gap:.25rem}.payment-modal-content{width:95%;padding:1rem}.payment-form-actions{flex-direction:column}}.balance-alert{color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:1rem;padding:1rem;font-size:1.1rem}.customer-summary{gap:.75rem;margin-bottom:1.5rem;display:grid}.customer-summary p{border-bottom:1px solid var(--light-gray);justify-content:space-between;align-items:center;margin:0;padding:.5rem 0;display:flex}.customer-summary p:last-child{border-bottom:none}.total-spent{color:var(--primary-color);font-weight:600}.subscription-count{background:var(--primary-color);color:var(--white);border-radius:4px;padding:.25rem .5rem;font-size:.875rem;font-weight:600}.payment-history-section{margin-bottom:3rem}.payment-history-section h2{color:var(--primary-color);margin-bottom:1.5rem}.payment-history-list{flex-direction:column;gap:1rem;max-height:400px;display:flex;overflow-y:auto}.payment-history-item{border:1px solid var(--medium-gray);background:var(--white);transition:var(--transition);border-radius:8px;justify-content:space-between;align-items:center;padding:1rem;display:flex}.payment-history-item:hover{border-color:var(--primary-light);box-shadow:var(--shadow-light)}.payment-info{flex:1;grid-template-columns:auto 1fr auto auto;align-items:center;gap:1rem;display:grid}.payment-date{color:var(--text-secondary);min-width:100px;font-size:.9rem}.payment-description{color:var(--text-primary);font-weight:500}.payment-amount{color:var(--primary-color);font-size:1.1rem;font-weight:600}.payment-status{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:.25rem .5rem;font-size:.85rem;font-weight:500}.error-message{text-align:center;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:2rem 0;padding:2rem}.error-message h2{color:#dc2626;margin-bottom:.5rem}.portal-nav{background:#fff;border:1px solid #e2e8f0;border-radius:16px;gap:.75rem;width:fit-content;max-width:1200px;margin:2rem auto;padding:.5rem;display:flex;box-shadow:0 4px 20px #00000014}.portal-nav-btn{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.75rem;padding:1rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.portal-nav-btn:hover{color:#475569;background:#f1f5f9;transform:translateY(-1px)}.portal-nav-btn.active{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);transform:translateY(-2px);box-shadow:0 8px 25px #3b82f64d}.portal-nav-btn.active:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff1a 0%,#fff0 100%);position:absolute;inset:0}.portal-nav-btn svg{flex-shrink:0;width:20px;height:20px;transition:transform .2s}.portal-nav-btn.active svg{transform:scale(1.1)}.program-selector{gap:.75rem;margin:1rem 0 .5rem;display:flex}.program-btn{border:2px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:.4rem;padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.program-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.program-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #00000026}.portal-tabs{background:var(--color-background-light);border:1px solid var(--color-border);border-radius:10px;gap:.5rem;margin:1.5rem 0;padding:.25rem;display:flex}.tab-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex}.tab-btn:hover{color:var(--color-text);background:var(--color-hover)}.tab-btn.active{color:var(--color-primary);background:#fff;box-shadow:0 2px 4px #0000001a}.curriculum-section{margin:2rem 0}.rank-progress{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#fff;border-radius:12px;margin-bottom:2rem;padding:2rem}.progress-header h2{margin:0 0 1rem;font-size:1.5rem;font-weight:600}.progress-bar{background:#fff3;border-radius:25px;height:50px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:25px;height:100%;transition:width .3s;position:relative}.progress-text{text-shadow:0 1px 2px #0000004d;font-size:1.1rem;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.curriculum-grid{grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem;display:grid}.lessons-section h3{color:var(--color-text);margin:0 0 1rem;font-size:1.2rem;font-weight:600}.lessons-list{flex-direction:column;gap:1rem;display:flex}.lesson-card{background:#fff;border-radius:12px;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #0000001a}.lesson-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.lesson-card.completed{border-left:4px solid var(--color-success)}.lesson-card.upcoming{border-left:4px solid var(--color-primary)}.lesson-status{color:var(--color-success);flex-shrink:0;font-size:1.5rem;font-weight:700}.lesson-card.upcoming .lesson-status{color:var(--color-text-muted)}.lesson-content{flex:1}.lesson-content h4{color:var(--color-text);margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.lesson-content p{color:var(--color-text-muted);margin:0 0 1rem;line-height:1.5}.lesson-meta{gap:1rem;margin-bottom:1rem;display:flex}.lesson-meta span{border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-weight:500}.lesson-meta .category{background:var(--color-primary-light);color:var(--color-primary)}.lesson-meta .rank{background:var(--color-background-light);color:var(--color-text-muted)}.schedule-section{margin:2rem 0}.schedule-list{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.schedule-card{background:#fff;border-radius:12px;gap:1.5rem;padding:1.5rem;transition:transform .2s;display:flex;box-shadow:0 2px 8px #0000001a}.schedule-card:hover{transform:translateY(-2px)}.schedule-card.regular{border-left:4px solid var(--color-primary)}.schedule-card.special{border-left:4px solid var(--color-accent)}.schedule-card.tournament{border-left:4px solid var(--color-warning)}.schedule-date{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-width:60px;display:flex}.schedule-date .day{color:var(--color-primary);font-size:1.5rem;font-weight:700;line-height:1}.schedule-date .month{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem}.schedule-details{flex:1}.schedule-details h4{color:var(--color-text);margin:0 0 .5rem;font-size:1.2rem;font-weight:600}.schedule-details p{color:var(--color-text-muted);margin:.25rem 0;font-size:.9rem}.type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;margin-top:.5rem;padding:.25rem .5rem;font-size:.8rem;font-weight:500;display:inline-block}.type-badge.regular{background:var(--color-primary-light);color:var(--color-primary)}.type-badge.special{background:var(--color-accent-light);color:var(--color-accent)}.type-badge.tournament{background:var(--color-warning-light);color:var(--color-warning)}.progress-section{margin:2rem 0}.progress-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.stat-card{text-align:center;background:#fff;border-radius:12px;padding:1.5rem;transition:transform .2s;box-shadow:0 2px 8px #0000001a}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 1rem;font-size:.9rem;font-weight:500}.stat-value{color:var(--color-primary);margin:0;font-size:2rem;font-weight:700}.portal-footer{border-top:1px solid var(--color-border);text-align:center;margin-top:3rem;padding-top:2rem}@media (max-width:768px){.portal-navigation{flex-direction:column;gap:.5rem}.nav-btn{justify-content:center}.curriculum-grid{grid-template-columns:1fr;gap:1rem}.schedule-card{flex-direction:column;gap:1rem}.schedule-date{flex-direction:row;gap:.5rem;min-width:auto}.progress-stats{grid-template-columns:repeat(2,1fr);gap:1rem}}.profile-avatar{cursor:pointer;transition:all .3s;position:relative}.profile-avatar:hover{transform:scale(1.05)}.avatar-circle{border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.avatar-image{-o-object-fit:cover;object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-placeholder{color:#fff;font-size:3rem;font-weight:700}.avatar-overlay{opacity:0;color:#fff;text-align:center;background:#000000b3;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;font-size:.8rem;font-weight:500;transition:opacity .3s;display:flex;position:absolute;inset:0}.avatar-circle:hover .avatar-overlay{opacity:1}.upload-progress{flex-direction:column;align-items:center;gap:8px;display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:24px;height:24px;animation:1s ease-in-out infinite spin}.spinner-small{border:2px solid #ffffff4d;border-top-color:#3b82f6;border-radius:50%;width:16px;height:16px;animation:1s ease-in-out infinite spin}.rank-selector{border:2px solid var(--color-border);background:#fff;border-radius:16px;margin-bottom:2rem;padding:1.5rem;transition:all .3s;box-shadow:0 4px 12px #0000001a}.rank-selector:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.rank-selector-header{text-align:center;margin-bottom:1.5rem}.rank-selector-header h3{color:var(--color-primary);margin:0 0 .5rem;font-size:1.3rem;font-weight:600}.rank-selector-subtitle{color:var(--color-text-muted);margin:0;font-size:.9rem}.rank-selector-loading,.rank-selector-error{text-align:center;border-radius:8px;padding:2rem 1rem}.rank-selector-loading{background:var(--color-background-light);color:var(--color-text-muted)}.rank-selector-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.rank-slider-container{margin-bottom:1.5rem}.rank-slider{scroll-behavior:smooth;gap:.75rem;margin-bottom:1rem;padding:1rem 0;display:flex;overflow-x:auto}.rank-slider::-webkit-scrollbar{height:6px}.rank-slider::-webkit-scrollbar-track{background:var(--color-background-light);border-radius:3px}.rank-slider::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:3px}.rank-button{border:2px solid var(--rank-border);background:linear-gradient(135deg, var(--rank-color) 0%, #ffffff1a 100%);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-width:100px;padding:1rem .75rem;transition:all .3s;display:flex;position:relative;box-shadow:0 2px 8px #0000001a}.rank-button:hover{border-color:var(--color-primary);transform:translateY(-4px)scale(1.05);box-shadow:0 6px 16px #0003}.rank-button.active{border-color:#06c;transform:translateY(-4px)scale(1.1);box-shadow:0 0 0 3px #06c3,0 6px 16px #0003}.rank-icon{filter:drop-shadow(0 2px 4px #0000004d);margin-bottom:.5rem;font-size:1.8rem}.rank-name{color:var(--color-text);text-shadow:0 1px 2px #0000001a;font-size:.8rem;font-weight:600;line-height:1.2}.rank-button:hover .rank-name{color:var(--color-primary)}.rank-button.active .rank-name{color:#06c}.rank-active-indicator{color:#fff;background:#06c;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:700;animation:2s infinite pulse;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 8px #06c6}.rank-progress-bar{background:var(--color-background-light);border-radius:4px;width:100%;height:8px;position:relative;overflow:hidden}.rank-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:4px;height:100%;transition:width .5s;position:relative}.rank-progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);animation:2s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.rank-selector-info{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.current-selection{color:var(--color-text);font-size:.9rem}.current-selection strong{color:var(--color-primary);font-weight:600}.review-mode{color:#92400e;text-transform:uppercase;letter-spacing:.5px;background:#fef3c7;border-radius:12px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}@media (max-width:768px){.rank-selector{padding:1rem}.rank-slider{gap:.5rem;padding:.75rem 0}.rank-button{min-width:80px;padding:.75rem .5rem}.rank-icon{font-size:1.4rem}.rank-name{font-size:.7rem}.rank-selector-info{text-align:center;flex-direction:column;align-items:center}}.notifications-container{pointer-events:none;flex-direction:column;gap:10px;max-width:400px;display:flex;z-index:999999!important;position:fixed!important;bottom:20px!important;right:20px!important}.notification{box-shadow:var(--shadow-lg);cursor:pointer;pointer-events:auto;border-radius:8px;justify-content:space-between;align-items:center;min-width:300px;padding:16px;transition:all .3s;animation:.3s slideInFromBottomRight;display:flex}.notification:hover{transform:translateY(-2px);box-shadow:0 12px 20px -3px #00000026,0 6px 8px -2px #00000014}.notification.success{color:#166534;background-color:#dcfce7;border-left:4px solid #22c55e}.notification.error{color:#991b1b;background-color:#fef2f2;border-left:4px solid #dc2626}.notification.info{color:#1e40af;background-color:#eff6ff;border-left:4px solid #3b82f6}.notification-content{flex:1;align-items:center;gap:12px;display:flex}.notification-icon{border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;font-weight:700;display:flex}.notification.success .notification-icon{color:#fff;background-color:#22c55e}.notification.error .notification-icon{color:#fff;background-color:#dc2626}.notification.info .notification-icon{color:#fff;background-color:#3b82f6}.notification-message{font-size:14px;font-weight:500;line-height:1.4}.notification-close{cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:20px;font-weight:700;transition:background-color .2s}.notification-close:hover{opacity:1;background-color:#0000001a}@keyframes slideInFromBottomRight{0%{opacity:0;transform:translate(100%)translateY(100%)}to{opacity:1;transform:translate(0)translateY(0)}}@keyframes slideOutToBottomRight{0%{opacity:1;transform:translate(0)translateY(0)}to{opacity:0;transform:translate(100%)translateY(100%)}}.notification.removing{animation:.3s forwards slideOutToBottomRight}@media (max-width:768px){.notifications-container{max-width:none;bottom:10px!important;left:10px!important;right:10px!important}.notification{min-width:auto}}.navbar-avatar-image{-o-object-fit:cover;object-fit:cover;border:1px solid var(--white);border-radius:50%;width:40px;height:40px}.curriculum-sections{margin-bottom:2rem}.curriculum-sections h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem}.curriculum-categories-grid{grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem;display:grid}.curriculum-category{box-shadow:var(--shadow);transition:var(--transition);cursor:pointer;border:2px solid #0000;border-radius:12px;padding:1.5rem;overflow:hidden}.curriculum-category:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.curriculum-category.collapsed{max-height:200px}.curriculum-category.expanded{max-height:none;overflow-y:auto}.curriculum-category .category-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.curriculum-category .category-info{flex:1;align-items:center;display:flex}.curriculum-category .category-info h3{margin:0 0 .25rem 1rem}.curriculum-category .category-info p{opacity:.9;margin:0 0 0 1rem;font-size:.875rem}.curriculum-category .expand-indicator{margin-left:1rem}.curriculum-category .expand-indicator .arrow{opacity:.7;font-size:.875rem;transition:transform .3s}.curriculum-category .category-content{animation:.3s ease-out slideDown}.curriculum-category.white{color:var(--text-primary);background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border-color:#e2e8f0}.curriculum-category.white .category-header h3{color:var(--text-primary)}.curriculum-category.white p{color:var(--text-secondary)}.curriculum-category.brown{color:#fff;background:linear-gradient(135deg,#996235 0%,#81562b 100%)}.curriculum-category.brown .category-header h3{color:#fff}.curriculum-category.brown p{color:#ffffffe6}.curriculum-category.green{color:#fff;background:linear-gradient(135deg,#46a16b 0%,#3e8f57 100%)}.curriculum-category.green .category-header h3{color:#fff}.curriculum-category.green p{color:#ffffffe6}.curriculum-category.blue{color:#fff;background:linear-gradient(135deg,#5b8edf 0%,#4a7ad3 100%)}.curriculum-category.blue .category-header h3{color:#fff}.curriculum-category.blue p{color:#ffffffe6}.curriculum-category.red{color:#fff;background:linear-gradient(135deg,#ce4e4e 0%,#b94343 100%)}.curriculum-category.red .category-header h3{color:#fff}.curriculum-category.red p{color:#ffffffe6}.curriculum-category.black{color:#fff;background:linear-gradient(135deg,#3a4c5e 0%,#2f3f4f 100%)}.curriculum-category.black .category-header h3{color:#fff}.curriculum-category.black p{color:#ffffffe6}.curriculum-category.yellow{color:#2d3748;background:linear-gradient(135deg,#e9c355 0%,#ddb342 100%)}.curriculum-category.yellow .category-header h3{color:#1f2937}.curriculum-category.yellow p{color:#374151}.category-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.category-icon{font-size:1.5rem}.category-header h3{margin:0;font-size:1.25rem;font-weight:600}.category-stats{margin-bottom:.75rem}.progress-badge{color:#1f2937;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:20px;padding:.25rem .75rem;font-size:.875rem;font-weight:600;box-shadow:0 2px 4px #0000001a}.curriculum-category.white .progress-badge{background:var(--primary-color);color:#fff}.curriculum-category.brown .progress-badge{color:#78350f;background:#fffffffa;font-weight:700}.curriculum-category.green .progress-badge{color:#15803d;background:#fffffffa;font-weight:700}.curriculum-category.blue .progress-badge{color:#1d4ed8;background:#fffffffa;font-weight:700}.curriculum-category.red .progress-badge{color:#b91c1c;background:#fffffffa;font-weight:700}.curriculum-category.black .progress-badge{color:#000;background:#fffffffa;border:1px solid #ffffff4d}.curriculum-category.yellow .progress-badge{background:var(--primary-dark);color:#fff}.curriculum-category p{opacity:.9;margin:0;font-size:.875rem}.curriculum-category-section{transition:var(--transition);border:2px solid #0000;border-radius:12px;margin-bottom:2rem;padding:1.5rem;box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.curriculum-category-section:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000026,0 4px 8px #0000001a}.curriculum-category-section[data-category=basic-techniques]{background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border-color:#e2e8f0}.curriculum-category-section[data-category=board-breaking]{color:#fff;background:linear-gradient(135deg,#92400e 0%,#78350f 100%)}.curriculum-category-section[data-category=kicks]{color:#fff;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%)}.curriculum-category-section[data-category=poomsae]{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}.curriculum-category-section[data-category=self-defense]{color:#fff;background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%)}.curriculum-category-section[data-category=sparring]{color:#fff;background:linear-gradient(135deg,#1f2937 0%,#111827 100%)}.curriculum-category-section .category-title{align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.125rem;font-weight:600;display:flex}.curriculum-category-section[data-category=basic-techniques] .category-title{color:#374151;border-bottom:2px solid #e5e7eb}.curriculum-category-section[data-category=board-breaking] .category-title,.curriculum-category-section[data-category=kicks] .category-title,.curriculum-category-section[data-category=poomsae] .category-title,.curriculum-category-section[data-category=self-defense] .category-title,.curriculum-category-section[data-category=sparring] .category-title{color:#fff;border-bottom:2px solid #ffffff4d}.curriculum-category-section .category-icon{margin-right:.75rem;font-size:1.25rem}.technique-card{transition:var(--transition);color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;padding:1rem;display:flex;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.technique-card:hover{transform:translateY(-1px);box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.technique-card.completed{background:#f0f9ff;border-color:#3b82f6;box-shadow:0 1px 3px #3b82f633,0 1px 2px #3b82f61a}.technique-card.completed:hover{box-shadow:0 4px 6px #3b82f633,0 2px 4px #3b82f61a}.technique-media{margin:.5rem 0!important}.technique-media .media-item{transition:transform .2s}.technique-media .media-item:hover{transform:scale(1.02)}.technique-media img,.technique-media video,.technique-media iframe{cursor:pointer;transition:all .3s}.technique-media img:hover,.technique-media video:hover,.technique-media iframe:hover{box-shadow:0 4px 12px #00000026}.technique-media audio{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px}.technique-card .technique-meta .category,.technique-card .technique-meta .rank{color:#374151;background:#f3f4f6}@media (max-width:768px){.curriculum-categories-grid{grid-template-columns:1fr;gap:1rem}.curriculum-category{padding:1rem}}.training-program-section{max-width:1000px;margin:0 auto}.program-header{text-align:center;background:linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);color:#fff;border-radius:12px;margin-bottom:2rem;padding:2rem}.program-header h2{margin-bottom:.5rem;font-size:2rem}.program-description{opacity:.9;margin:0;font-size:1.1rem}.training-sections{flex-direction:column;gap:1.5rem;margin-bottom:2rem;display:flex}.training-section{background:var(--white);box-shadow:var(--shadow);transition:var(--transition);border-radius:12px;overflow:hidden}.training-section:hover{box-shadow:var(--shadow-lg)}.section-header{background:var(--light-gray);border-bottom:1px solid var(--medium-gray);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.section-header h3{align-items:center;gap:.5rem;margin:0;font-size:1.25rem;display:flex}.section-status{background:var(--medium-gray);color:var(--text-secondary);border-radius:20px;padding:.25rem .75rem;font-size:.875rem;font-weight:500}.exercises-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;padding:2rem;display:grid}.exercise-placeholder{text-align:center;color:var(--text-secondary);background:var(--light-gray);border-radius:8px;padding:2rem}.exercise-card{border:1px solid var(--medium-gray);box-shadow:var(--shadow);transition:var(--transition);background:#fff;border-radius:8px;padding:1.5rem}.exercise-card.sequential{align-items:flex-start;gap:1.5rem;width:100%;margin-bottom:1rem;display:flex}.exercise-number{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;min-width:80px;display:flex}.step-number{background:var(--primary-color);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:.5rem;font-size:1.1rem;font-weight:700;transition:all .3s;display:inline-flex;position:relative;box-shadow:0 2px 4px #0000001a}.step-number:before{content:"";opacity:0;z-index:-1;background:linear-gradient(45deg,#0000,#47556933,#0000);border-radius:50%;transition:opacity .3s;position:absolute;inset:-4px}.step-number:hover:before{opacity:1}.step-number:hover{background:var(--primary-dark);border-color:var(--primary-light);transform:scale(1.15);box-shadow:0 6px 16px #47556966}.step-number:active{transform:scale(1.05);box-shadow:0 2px 8px #4755694d}.step-number.completed{background:var(--success-color);color:#fff;animation:.6s ease-out completePulse}.step-number.completed:hover{background:#047857;border-color:#10b981;box-shadow:0 6px 16px #05966966}@keyframes completePulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes hintPulse{0%,to{box-shadow:0 2px 4px #0000001a}50%{box-shadow:0 4px 8px #4755694d}}.exercise-card:hover .step-number:not(.completed){animation:2s infinite hintPulse}.exercise-type{color:var(--text-secondary);text-align:center;font-size:.8rem;font-weight:500}.exercise-content{flex:1;width:100%}.exercise-sequence{flex-direction:column;gap:2rem;width:100%;display:flex}.exercise-section{width:100%}.exercise-section .section-header{border-bottom:2px solid var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem}.exercise-section .section-header h3{color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:600}.exercise-section .exercise-card:last-child{margin-bottom:0}.training-sequence{flex-direction:column;gap:2rem;width:100%;display:flex}.training-summary{background:var(--light-gray);border:1px solid var(--medium-gray);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.training-summary.top-summary{background:linear-gradient(135deg, var(--light-gray) 0%, #f8fafc 100%);border:2px solid var(--primary-color);box-shadow:0 4px 6px #0000000d}.training-summary h3{color:var(--text-primary);margin:0 0 1rem}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.stat-item{border:1px solid var(--medium-gray);background:#fff;border-radius:6px;align-items:center;gap:.5rem;padding:.75rem;transition:all .3s;display:flex;position:relative}.stat-item.completed{border-color:var(--success-color);background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%);box-shadow:0 2px 4px #0596691a}.stat-item.completed .stat-text{color:#065f46;font-weight:600}.completed-badge{background:var(--success-color);color:#fff;border-radius:12px;margin-left:.5rem;padding:.2rem .5rem;font-size:.7rem;font-weight:700;animation:2s infinite badgePulse;display:inline-block}@keyframes badgePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.stat-icon{font-size:1.2rem}.stat-text{color:var(--text-primary);font-weight:500}.exercise-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.exercise-card h4{color:var(--text-primary);margin:0 0 .5rem;font-size:1.1rem}.exercise-kname{color:var(--text-secondary);margin:0 0 .5rem;font-size:.9rem;font-style:italic}.exercise-description{color:var(--text-secondary);margin:0 0 1rem;font-size:.9rem;line-height:1.4}.exercise-reps{color:var(--primary-color);background:var(--light-gray);text-align:center;border-radius:4px;margin:0;padding:.5rem;font-size:1rem}.training-loading{text-align:center;color:var(--text-secondary);padding:3rem}.no-program{text-align:center;color:var(--text-secondary);background:var(--light-gray);border-radius:12px;margin:2rem 0;padding:3rem}.session-actions{text-align:center;background:var(--light-gray);border-radius:12px;padding:2rem}.complete-session-btn{background:var(--primary-color);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:8px;margin-bottom:1rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600}.complete-session-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.complete-session-btn:disabled{background:var(--medium-gray);color:var(--text-secondary);cursor:not-allowed}.complete-session-btn.completed{background:var(--success-color);color:#fff;cursor:pointer}.complete-session-btn.completed:hover{background:#047857;transform:translateY(-1px)}.completion-note{color:var(--text-secondary);margin:0;font-size:.9rem}.completion-note.completed{color:var(--success-color);font-weight:600}.confetti-container{pointer-events:none;z-index:1000;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{opacity:0;transform-origin:50%;width:8px;height:8px;animation:1.2s ease-out forwards confetti-float;position:absolute}.confetti-piece:nth-child(odd){animation:1s ease-out forwards confetti-drift}.confetti-piece:nth-child(2n){animation:1.4s ease-out forwards confetti-float}.confetti-piece:nth-child(3n){animation:1.1s ease-out forwards confetti-float}.confetti-piece:nth-child(4n){animation:1.3s ease-out forwards confetti-drift}.confetti-piece:nth-child(5n){animation:.9s ease-out forwards confetti-float}.confetti-piece.square{background:#f39c12}.confetti-piece.circle{background:#e74c3c;border-radius:50%}.confetti-piece.triangle{background:0 0;border-bottom:8px solid #3498db;border-left:4px solid #0000;border-right:4px solid #0000;width:0;height:0}.confetti-piece.rectangle{background:#9b59b6;width:6px;height:12px}.confetti-piece.diamond{background:#1abc9c;width:8px;height:8px;transform:rotate(45deg)}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes confetti-float{0%{opacity:1;transform:translate(0)rotate(0)scale(.3)}1%{transform:translate(calc(var(--random-x) * .1), calc(var(--random-y) * .1)) rotate(calc(var(--random-rotation) * .1)) scale(.8);opacity:1}8%{transform:translate(calc(var(--random-x) * .3), calc(var(--random-y) * .3)) rotate(calc(var(--random-rotation) * .3)) scale(1);opacity:1}30%{transform:translate(calc(var(--random-x) * .7), calc(var(--random-y) * .7)) rotate(calc(var(--random-rotation) * .7)) scale(1);opacity:1}70%{opacity:.7}90%{opacity:.2}to{transform:translate(var(--random-x), var(--random-y)) rotate(var(--random-rotation)) scale(.6);opacity:0}}@keyframes confetti-drift{0%{opacity:1;transform:translate(0)rotate(0)scale(.3)}1%{transform:translate(calc(var(--drift-x) * .08), calc(var(--drift-y) * .08)) rotate(calc(var(--drift-rotation) * .08)) scale(.7);opacity:1}6%{transform:translate(calc(var(--drift-x) * .25), calc(var(--drift-y) * .25)) rotate(calc(var(--drift-rotation) * .25)) scale(1);opacity:1}25%{transform:translate(calc(var(--drift-x) * .6), calc(var(--drift-y) * .6)) rotate(calc(var(--drift-rotation) * .6)) scale(1);opacity:1}75%{opacity:.6}90%{opacity:.1}to{transform:translate(var(--drift-x), var(--drift-y)) rotate(var(--drift-rotation)) scale(.4);opacity:0}}@keyframes confetti-wiggle{0%,to{transform:translate(0)translateY(0)}25%{transform:translate(-15px)translateY(-10px)}50%{transform:translate(10px)translateY(-20px)}75%{transform:translate(-5px)translateY(-15px)}}.training-calendar-section{max-width:1000px;margin:0 auto}.calendar-header{text-align:center;background:linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);color:#fff;border-radius:12px;margin-bottom:2rem;padding:2rem}.calendar-header h2{margin-bottom:.5rem;font-size:2rem}.calendar-description{opacity:.9;margin:0;font-size:1.1rem}.calendar-controls{background:var(--white);box-shadow:var(--shadow);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 2rem;display:flex}.calendar-nav-btn{background:var(--primary-color);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:500}.calendar-nav-btn:hover{background:var(--primary-dark)}.current-month{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:600}.calendar-grid{background:var(--white);box-shadow:var(--shadow);border-radius:12px;margin-bottom:2rem;padding:2rem}.calendar-placeholder{text-align:center}.calendar-placeholder p{color:var(--text-secondary);margin-bottom:2rem}.calendar-demo{max-width:400px;margin:0 auto}.calendar-week-header{grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem;padding:0 .5rem;display:grid}.calendar-week-header span{text-align:center;color:var(--text-secondary);padding:.5rem;font-weight:600}.calendar-days{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid}.calendar-day{aspect-ratio:1;cursor:pointer;transition:var(--transition);border:2px solid #0000;border-radius:8px;justify-content:center;align-items:center;font-weight:500;display:flex}.calendar-day.today{background:var(--primary-color);color:#fff}.calendar-day.completed{color:#166534;background:#dcfce7}.calendar-day.training{background:var(--light-gray);color:var(--text-primary)}.calendar-day.training:hover{background:var(--medium-gray)}.calendar-day.rest{color:#92400e;background:#fef3c7}.calendar-legend{background:var(--white);box-shadow:var(--shadow);border-radius:12px;justify-content:center;gap:2rem;padding:1rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.legend-color{border-radius:4px;width:16px;height:16px}.legend-color.today{background:var(--primary-color)}.legend-color.completed{background:#dcfce7}.legend-color.training{background:var(--light-gray)}.legend-color.rest{background:#fef3c7}@media (max-width:768px){.program-header,.calendar-header{padding:1.5rem}.program-header h2,.calendar-header h2{font-size:1.5rem}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem 1.5rem}.exercises-grid{padding:1.5rem}.calendar-controls{text-align:center;flex-direction:column;gap:1rem}.calendar-legend{flex-wrap:wrap;gap:1rem}.calendar-grid{padding:1rem}}.training-program-manager .container{background:var(--white);box-shadow:var(--shadow);border:1px solid #e5e7eb;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.training-program-manager .section-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.training-program-manager .section-header h3{color:var(--text-primary);margin-bottom:.25rem;font-size:1.5rem;font-weight:600}.training-program-manager .section-header p{color:var(--text-secondary);margin:0;font-size:.875rem}.table{border-collapse:collapse;background:var(--white);border-radius:8px;width:100%;overflow:hidden;box-shadow:0 1px 3px #0000001a}.table thead{background:#f8fafc}.table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;font-size:.75rem;font-weight:600}.table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:1rem 1.5rem}.table tbody tr:hover{background:#f8fafc;transition:background-color .15s}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s}.sortable-header:hover{background:#f1f5f9}.badge{border-radius:9999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.enrollment-form{max-width:780px;margin:0 auto}.enrollment-form__title{color:var(--color-text,#1a1a2e);border-bottom:2px solid var(--color-border,#e2e8f0);margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.4rem;font-weight:700}.enrollment-banner{border-radius:8px;margin-bottom:1.25rem;padding:.85rem 1.1rem;font-size:.9rem;font-weight:500}.enrollment-banner--success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.enrollment-banner--error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.enrollment-section{border:1px solid var(--color-border,#e2e8f0);background:#f8fafc;border-radius:10px;margin-bottom:1.25rem;padding:1.25rem 1.5rem}.enrollment-section__heading{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary,#1985a0);margin-bottom:1rem;font-size:.95rem;font-weight:700}.enrollment-section__hint{color:var(--color-text-muted,#64748b);margin-top:-.5rem;margin-bottom:1rem;font-size:.85rem}.enrollment-required-star{color:#e53e3e}.enrollment-grid{gap:1rem;margin-bottom:1rem;display:grid}.enrollment-grid--2{grid-template-columns:repeat(2,1fr)}.enrollment-grid--3{grid-template-columns:repeat(3,1fr)}@media (max-width:600px){.enrollment-grid--2,.enrollment-grid--3{grid-template-columns:1fr}}.enrollment-field{flex-direction:column;gap:.3rem;margin-bottom:1rem;display:flex}.enrollment-field:last-child{margin-bottom:0}.enrollment-field label{color:var(--color-text-muted,#475569);text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;font-weight:600}.enrollment-field--required label:after{content:" *";color:#e53e3e}.enrollment-field input,.enrollment-field select,.enrollment-field textarea{border:1px solid var(--color-border,#cbd5e1);color:var(--color-text,#1a1a2e);background:#fff;border-radius:6px;width:100%;padding:.55rem .75rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.enrollment-field input:focus,.enrollment-field select:focus,.enrollment-field textarea:focus{border-color:var(--color-primary,#1985a0);outline:none;box-shadow:0 0 0 3px #1985a026}.enrollment-field textarea{resize:vertical;min-height:80px}.enrollment-flags{flex-wrap:wrap;gap:1.5rem;margin-top:.25rem;display:flex}.enrollment-checkbox{color:var(--color-text,#1a1a2e);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.875rem;display:flex}.enrollment-checkbox input[type=checkbox]{cursor:pointer;width:1rem;height:1rem;accent-color:var(--color-primary,#1985a0)}.enrollment-programs{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.enrollment-program-card{border:2px solid var(--color-border,#e2e8f0);background:#fff;border-radius:10px;padding:1rem 1.1rem;transition:border-color .2s,box-shadow .2s}.enrollment-program-card--active{border-color:var(--color-primary,#1985a0);box-shadow:0 0 0 3px #1985a01a}.enrollment-program-card__header{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--color-text,#1a1a2e);align-items:center;gap:.6rem;font-size:.95rem;font-weight:600;display:flex}.enrollment-program-card__header input[type=checkbox]{cursor:pointer;width:1.1rem;height:1.1rem;accent-color:var(--color-primary,#1985a0)}.enrollment-program-card__icon{font-size:1.2rem}.enrollment-program-card__rank{flex-direction:column;gap:.3rem;margin-top:.85rem;display:flex}.enrollment-program-card__rank label{color:var(--color-text-muted,#475569);text-transform:uppercase;letter-spacing:.03em;font-size:.78rem;font-weight:600}.enrollment-program-card__rank select{border:1px solid var(--color-border,#cbd5e1);background:#f8fafc;border-radius:6px;width:100%;padding:.5rem .7rem;font-size:.875rem}.enrollment-program-card__rank select:focus{border-color:var(--color-primary,#1985a0);outline:none;box-shadow:0 0 0 3px #1985a026}.enrollment-submit{justify-content:flex-end;margin-top:1.5rem;display:flex}.enrollment-submit__btn{background:var(--color-primary,#1985a0);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 2.5rem;font-size:.95rem;font-weight:700;transition:background .2s,transform .1s}.enrollment-submit__btn:hover:not(:disabled){background:var(--color-accent,#045870)}.enrollment-submit__btn:active:not(:disabled){transform:scale(.98)}.enrollment-submit__btn:disabled{opacity:.6;cursor:not-allowed}.student-list-layout{grid-template-columns:1fr;align-items:start;gap:1.25rem;display:grid}@media (min-width:900px){.student-list-layout:has(.enrollment-editor){grid-template-columns:1fr 380px}}.enrollment-editor{border:1px solid var(--color-border,#e2e8f0);background:#fff;border-radius:12px;padding:1.25rem 1.5rem;position:sticky;top:1.5rem;box-shadow:0 4px 16px #00000014}.enrollment-editor__header{border-bottom:1px solid var(--color-border,#e2e8f0);justify-content:space-between;align-items:flex-start;margin-bottom:1.1rem;padding-bottom:.85rem;display:flex}.enrollment-editor__name{color:var(--color-text,#1a1a2e);font-size:1.05rem;font-weight:700}.enrollment-editor__sub{color:var(--color-text-muted,#64748b);margin-top:.15rem;font-size:.8rem}.enrollment-editor__close{color:var(--color-text-muted,#94a3b8);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:1rem;line-height:1;transition:color .15s,background .15s}.enrollment-editor__close:hover{color:var(--color-text,#1a1a2e);background:var(--color-hover,#f1f5f9)}.enrollment-editor__section{margin-bottom:1.25rem}.enrollment-editor__section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary,#1985a0);margin-bottom:.75rem;font-size:.75rem;font-weight:700}.enrollment-editor__cards{flex-direction:column;gap:.75rem;display:flex}.enrollment-editor__card{border:1px solid var(--color-border,#e2e8f0);background:#f8fafc;border-radius:8px;padding:.85rem 1rem}.enrollment-editor__card--active{border-color:var(--color-primary,#1985a0);background:#f0f9ff}.enrollment-editor__card-header{align-items:center;gap:.5rem;margin-bottom:.65rem;display:flex}.enrollment-editor__card-icon{font-size:1.1rem}.enrollment-editor__card-name{color:var(--color-text,#1a1a2e);flex:1;font-size:.9rem;font-weight:600}.enrollment-editor__remove-btn{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:4px;padding:.15rem .4rem;font-size:.75rem;line-height:1.4;transition:background .15s}.enrollment-editor__remove-btn:hover:not(:disabled){background:#fee2e2}.enrollment-editor__remove-btn:disabled{opacity:.5;cursor:not-allowed}.enrollment-editor__rank-row{align-items:center;gap:.6rem;display:flex}.enrollment-editor__rank-row label{color:var(--color-text-muted,#475569);white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;min-width:38px;font-size:.75rem;font-weight:600}.enrollment-editor__rank-row select{border:1px solid var(--color-border,#cbd5e1);background:#fff;border-radius:6px;flex:1;padding:.4rem .6rem;font-size:.85rem}.enrollment-editor__rank-row select:focus{border-color:var(--color-primary,#1985a0);outline:none;box-shadow:0 0 0 2px #1985a026}.enrollment-editor__saving{color:var(--color-primary,#1985a0);white-space:nowrap;font-size:.75rem;font-style:italic}.enrollment-editor__add-btn{background:var(--color-primary,#1985a0);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:.65rem;padding:.5rem;font-size:.85rem;font-weight:600;transition:background .2s}.enrollment-editor__add-btn:hover:not(:disabled){background:var(--color-accent,#045870)}.enrollment-editor__add-btn:disabled{opacity:.5;cursor:not-allowed}.badge-blue{color:#1d4ed8;background:#dbeafe;border:1px solid #bfdbfe}.badge-gray{color:#6b7280;background:#f3f4f6;border:1px solid #d1d5db}.action-buttons{align-items:center;gap:.5rem;display:flex}.btn-sm{border-radius:.375rem;padding:.375rem .75rem;font-size:.875rem}.btn-outline{color:#374151;background:0 0;border:1px solid #d1d5db}.btn-outline:hover{background:#f9fafb;border-color:#9ca3af}.goals-tab-section{padding:0}.student-goals-section{flex-direction:column;gap:1.5rem;display:flex}.goals-last-updated{color:var(--dark-gray);text-align:right;margin-bottom:-.5rem;font-size:.8rem}.goals-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (min-width:700px){.goals-grid{grid-template-columns:repeat(2,1fr)}.goals-card-span{grid-column:1/-1}}.goals-card{background:var(--white);border:1px solid var(--medium-gray);box-shadow:var(--shadow-light);border-radius:.75rem;padding:1.25rem}.goals-card-full{width:100%}.goals-card-header{align-items:center;gap:.6rem;margin-bottom:1rem;display:flex}.goals-card-icon{font-size:1.25rem;line-height:1}.goals-card-header h3{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.goals-list{flex-direction:column;gap:.6rem;display:flex}.goals-input{width:100%;box-shadow:none;border:1px solid #cbd5e1;padding:.5rem .75rem}.goals-input::placeholder{color:#cbd5e1;font-style:italic}.goals-textarea{width:100%;box-shadow:none;border:1px solid #cbd5e1;padding:.625rem .75rem}.goals-textarea::placeholder{color:#cbd5e1;font-style:italic}.goals-empty{color:var(--dark-gray);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:4rem 2rem;display:flex}.goals-empty p:first-child{font-size:2.5rem}.goals-empty p{margin:0;line-height:1.5}.goals-edit-hint{color:var(--dark-gray);background:#f0f9ff;border:1px solid #bae6fd;border-radius:.5rem;margin-bottom:.25rem;padding:.5rem .75rem;font-size:.8rem}.goals-editable-row{align-items:center;gap:.4rem;display:flex}.goals-input-display-wrap{flex:1;align-items:center;display:flex;position:relative}.goals-input-display-wrap .goals-input{flex:1}.goals-input-editing{outline:none;flex:1;border-color:#6366f1!important;box-shadow:0 0 0 2px #c7d2fe!important}.goals-input-pending{color:#92400e;background:#fffbeb;font-style:italic;border-color:#f59e0b!important}.goals-pending-badge{color:#92400e;pointer-events:none;white-space:nowrap;background:#fef3c7;border:1px solid #fcd34d;border-radius:.25rem;padding:.1rem .35rem;font-size:.65rem;font-weight:600;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.goals-icon-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;width:1.75rem;height:1.75rem;padding:0;transition:background .15s,border-color .15s;display:inline-flex}.goals-edit-btn{color:#64748b;border-color:#e2e8f0}.goals-edit-btn:hover{color:#334155;background:#f1f5f9}.goals-submit-btn{color:#fff;background:#22c55e;border-color:#16a34a}.goals-submit-btn:hover:not(:disabled){background:#16a34a}.goals-submit-btn:disabled{opacity:.6;cursor:not-allowed}.goals-cancel-btn{color:#ef4444;border-color:#fca5a5}.goals-cancel-btn:hover:not(:disabled){background:#fee2e2}.goals-withdraw-btn{color:#b45309;background:#fef3c7;border-color:#fcd34d}.goals-withdraw-btn:hover:not(:disabled){background:#fde68a}.goals-withdraw-btn:disabled{opacity:.5;cursor:not-allowed}.goals-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:.75rem;height:.75rem;animation:.6s linear infinite goals-spin;display:inline-block}.goals-spinner--dark{border-color:#b45309 #b453094d #b453094d}@keyframes goals-spin{to{transform:rotate(360deg)}}.goals-toast{border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;animation:.2s goals-fade-in}.goals-toast-ok{color:#166534;background:#dcfce7;border:1px solid #86efac}.goals-toast-err{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}@keyframes goals-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (min-width:900px){.student-list-layout:has(.ig-panel){grid-template-columns:1fr 400px}}.ig-panel{border:1px solid var(--color-border,#e2e8f0);background:#fff;border-radius:12px;flex-direction:column;max-height:calc(100vh - 3rem);display:flex;position:sticky;top:1.5rem;overflow:hidden;box-shadow:0 4px 16px #00000014}.ig-panel-header{border-bottom:1px solid var(--color-border,#e2e8f0);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:1.1rem 1.4rem 1rem;display:flex}.ig-panel-title{color:var(--color-text,#1a1a2e);margin:0;font-size:1rem;font-weight:700}.ig-panel-subtitle{color:var(--color-text-muted,#64748b);margin:.15rem 0 0;font-size:.8rem}.ig-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:1rem;line-height:1;transition:color .15s,background .15s}.ig-close-btn:hover{color:#1a1a2e;background:#f1f5f9}.ig-loading{text-align:center;color:#94a3b8;padding:1.5rem;font-size:.9rem}.ig-body{flex-direction:column;gap:1.1rem;padding:1.1rem 1.4rem;display:flex;overflow-y:auto}.ig-banner{border-radius:6px;padding:.6rem .9rem;font-size:.85rem;font-weight:500}.ig-banner--success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.ig-banner--error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.ig-field-group{flex-direction:column;gap:.45rem;display:flex}.ig-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary,#1985a0);align-items:center;gap:.4rem;margin-bottom:.1rem;font-size:.75rem;font-weight:700;display:flex}.ig-input{color:#1a1a2e;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:.45rem .75rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.ig-input:focus{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd4d}.ig-input::placeholder{color:#cbd5e1}.ig-textarea{color:#1a1a2e;resize:vertical;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.ig-textarea:focus{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd4d}.ig-textarea::placeholder{color:#cbd5e1}.ig-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:.6rem;padding-top:.5rem;display:flex}.ig-cancel-btn{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;transition:background .15s}.ig-cancel-btn:hover{background:#f8fafc}.ig-save-btn{color:#fff;cursor:pointer;background:#059669;border:none;border-radius:6px;padding:.5rem 1.2rem;font-size:.875rem;font-weight:600;transition:background .15s}.ig-save-btn:hover{background:#047857}.ig-save-btn:disabled{cursor:not-allowed;background:#a7f3d0}.ig-proposals-section{background:#fffbeb;border:1px solid #fcd34d;border-radius:.5rem;overflow:hidden}.ig-proposals-header{color:#92400e;background:#fef3c7;border-bottom:1px solid #fcd34d;align-items:center;gap:.5rem;padding:.625rem .875rem;font-size:.875rem;font-weight:600;display:flex}.ig-proposals-badge{color:#fff;background:#f59e0b;border-radius:999px;margin-left:auto;padding:.1rem .5rem;font-size:.7rem;font-weight:700}.ig-proposals-list{flex-direction:column;gap:0;display:flex}.ig-proposal-row{border-bottom:1px solid #fde68a;flex-direction:column;gap:.35rem;padding:.75rem .875rem;font-size:.825rem;display:flex}.ig-proposal-row:last-child{border-bottom:none}.ig-proposal-meta{justify-content:space-between;align-items:center;display:flex}.ig-proposal-field{color:#78350f;font-weight:600}.ig-proposal-date{color:#a16207;font-size:.75rem}.ig-proposal-values{color:#44403c;flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.ig-proposal-current{background:#f5f5f4;border-radius:.25rem;padding:.15rem .4rem}.ig-proposal-arrow{color:#a16207;font-weight:700}.ig-proposal-proposed{color:#065f46;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:.25rem;padding:.15rem .4rem}.ig-proposal-empty{color:#9ca3af;font-style:italic}.ig-proposal-actions{gap:.5rem;margin-top:.25rem;display:flex}.ig-proposal-approve-btn,.ig-proposal-reject-btn{cursor:pointer;border:none;border-radius:.375rem;padding:.3rem .75rem;font-size:.8rem;font-weight:600;transition:background .15s}.ig-proposal-approve-btn{color:#fff;background:#22c55e}.ig-proposal-approve-btn:hover:not(:disabled){background:#16a34a}.ig-proposal-reject-btn{color:#fff;background:#ef4444}.ig-proposal-reject-btn:hover:not(:disabled){background:#dc2626}.ig-proposal-approve-btn:disabled,.ig-proposal-reject-btn:disabled{opacity:.5;cursor:not-allowed}.gpp-panel{flex-direction:column;gap:1.25rem;display:flex}.gpp-toast{margin-bottom:0}.gpp-toolbar{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.gpp-filter-group{gap:.375rem;display:flex}.gpp-filter-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:.35rem;padding:.4rem .875rem;font-size:.8rem;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.gpp-filter-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.gpp-filter-btn--active{color:#fff;background:#1d4ed8;border-color:#1d4ed8}.gpp-filter-btn--active:hover{background:#1e40af}.gpp-badge{color:#fff;background:#ef4444;border-radius:999px;margin-left:.1rem;padding:.1rem .45rem;font-size:.65rem;font-weight:700}.gpp-refresh-btn{cursor:pointer;color:#64748b;background:0 0;border:1px solid #e2e8f0;border-radius:.375rem;padding:.35rem .6rem;font-size:.9rem;transition:background .15s}.gpp-refresh-btn:hover:not(:disabled){background:#f1f5f9}.gpp-refresh-btn:disabled{opacity:.4;cursor:not-allowed}.gpp-state{color:#64748b;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.gpp-state--error{color:#b91c1c}.gpp-empty-icon{font-size:2.5rem;line-height:1}.gpp-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:2rem;height:2rem;animation:.7s linear infinite goals-spin}.gpp-retry-btn{color:#b91c1c;cursor:pointer;background:#fff;border:1px solid #fca5a5;border-radius:.375rem;padding:.4rem 1rem;font-size:.875rem}.gpp-retry-btn:hover{background:#fee2e2}.gpp-groups{flex-direction:column;gap:1.5rem;display:flex}.gpp-student-group{border:1px solid #e2e8f0;border-radius:.75rem;overflow:hidden}.gpp-student-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.gpp-student-avatar{color:#fff;background:#3b82f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.875rem;font-weight:700;display:flex}.gpp-student-name{color:#1e293b;font-size:.9rem;font-weight:600}.gpp-student-count{color:#94a3b8;margin-left:auto;font-size:.75rem}.gpp-proposals{flex-direction:column;display:flex}.gpp-proposal-card{border-bottom:1px solid #f1f5f9;flex-direction:column;gap:.625rem;padding:.875rem 1rem;display:flex}.gpp-proposal-card:last-child{border-bottom:none}.gpp-proposal-card--approved{background:#f0fdf4}.gpp-proposal-card--rejected{background:#fef2f2}.gpp-proposal-card--pending{background:#fff}.gpp-proposal-top{justify-content:space-between;align-items:center;display:flex}.gpp-field-label{color:#334155;font-size:.825rem;font-weight:600}.gpp-proposal-date{color:#94a3b8;font-size:.75rem}.gpp-proposal-diff{flex-wrap:wrap;align-items:center;gap:.625rem;display:flex}.gpp-diff-block{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.gpp-diff-label{text-transform:uppercase;letter-spacing:.04em;color:#94a3b8;font-size:.65rem;font-weight:600}.gpp-diff-value{color:#1e293b;word-break:break-word;border-radius:.375rem;padding:.3rem .5rem;font-size:.85rem}.gpp-diff-block--current .gpp-diff-value{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0}.gpp-diff-block--proposed .gpp-diff-value{color:#166534;background:#f0fdf4;border:1px solid #86efac}.gpp-diff-empty{color:#cbd5e1;font-style:italic}.gpp-diff-arrow{color:#94a3b8;flex-shrink:0;font-size:1rem}.gpp-proposal-actions{gap:.5rem;margin-top:.125rem;display:flex}.gpp-approve-btn,.gpp-reject-btn{cursor:pointer;border:none;border-radius:.375rem;padding:.35rem .875rem;font-size:.8rem;font-weight:600;transition:background .15s}.gpp-approve-btn{color:#fff;background:#22c55e}.gpp-approve-btn:hover:not(:disabled){background:#16a34a}.gpp-reject-btn{color:#fff;background:#ef4444}.gpp-reject-btn:hover:not(:disabled){background:#dc2626}.gpp-approve-btn:disabled,.gpp-reject-btn:disabled{opacity:.5;cursor:not-allowed}.gpp-proposal-status-badge{border-radius:999px;align-self:flex-start;padding:.2rem .6rem;font-size:.775rem;font-weight:600;display:inline-block}.gpp-proposal-status-badge--approved{color:#166534;background:#dcfce7}.gpp-proposal-status-badge--rejected{color:#991b1b;background:#fee2e2}.te-root{flex-direction:column;gap:1.25rem;display:flex}.te-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.te-title{color:var(--text-primary);margin:0 0 .25rem;font-size:1.25rem;font-weight:700}.te-subtitle{color:var(--text-secondary);margin:0;font-size:.875rem}.te-category-bar{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.te-label{color:var(--text-primary);font-size:.8125rem;font-weight:600}.te-select{border:1px solid var(--medium-gray);color:var(--text-primary);cursor:pointer;background:#fff;border-radius:6px;min-width:220px;padding:.45rem .75rem;font-size:.875rem}.te-select:focus{border-color:var(--primary-color);outline:none}.te-success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0;border-radius:6px;padding:.6rem 1rem;font-size:.875rem}.te-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;padding:.6rem 1rem;font-size:.875rem}.te-empty{text-align:center;color:var(--text-secondary);padding:3rem 1rem;font-size:.9rem}.te-content{align-items:flex-start;gap:1.5rem;display:flex}.te-content--split .te-list-panel{flex:0 0 420px;min-width:0}.te-content:not(.te-content--split) .te-list-panel{flex:1}.te-list-panel{flex-direction:column;gap:.75rem;display:flex}.te-list-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.te-list-count{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.te-search{border:1px solid var(--medium-gray);background:#fff;border-radius:6px;min-width:180px;padding:.4rem .75rem;font-size:.875rem}.te-search:focus{border-color:var(--primary-color);outline:none}.te-loading,.te-empty-list{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:.875rem}.te-list{flex-direction:column;gap:.5rem;max-height:620px;display:flex;overflow-y:auto}.te-item{border:1px solid var(--medium-gray);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .9rem;transition:border-color .15s;display:flex}.te-item:hover{border-color:var(--primary-color)}.te-item--active{border-color:var(--primary-color);background:#f0f4ff}.te-item-info{flex-direction:column;gap:.15rem;min-width:0;display:flex}.te-item-ename{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.te-item-kname{color:var(--text-secondary);font-size:.8rem}.te-item-rank{color:var(--primary-color);font-size:.75rem;font-weight:500}.te-item-actions{flex-shrink:0;gap:.4rem;display:flex}.te-form-panel{border:1px solid var(--medium-gray);background:#fff;border-radius:10px;flex-direction:column;flex:1;gap:1rem;min-width:0;padding:1.5rem;display:flex}.te-form-title{color:var(--text-primary);margin:0 0 .25rem;font-size:1rem;font-weight:700}.te-form-grid{grid-template-columns:1fr 1fr;gap:.9rem;display:grid}.te-field{flex-direction:column;gap:.3rem;display:flex}.te-field--full{grid-column:1/-1}.te-required{color:#dc2626}.te-optional{color:var(--text-secondary);font-size:.75rem;font-weight:400}.te-input{border:1px solid var(--medium-gray);color:var(--text-primary);box-sizing:border-box;background:#fff;border-radius:6px;width:100%;padding:.45rem .75rem;font-size:.875rem}.te-input:focus{border-color:var(--primary-color);outline:none}.te-textarea{border:1px solid var(--medium-gray);color:var(--text-primary);box-sizing:border-box;resize:vertical;background:#fff;border-radius:6px;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;line-height:1.5}.te-textarea:focus{border-color:var(--primary-color);outline:none}.te-form-actions{justify-content:flex-end;gap:.6rem;margin-top:.25rem;display:flex}.te-btn-primary{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;transition:background .15s}.te-btn-primary:hover:not(:disabled){background:var(--primary-dark)}.te-btn-primary:disabled{opacity:.6;cursor:not-allowed}.te-btn-secondary{color:var(--text-primary);border:1px solid var(--medium-gray);cursor:pointer;background:#fff;border-radius:6px;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;transition:background .15s}.te-btn-secondary:hover:not(:disabled){background:var(--light-gray)}.te-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.te-btn-edit{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:5px;padding:.3rem .7rem;font-size:.8rem;font-weight:600;transition:background .15s}.te-btn-edit:hover:not(:disabled){background:#dbeafe}.te-btn-edit:disabled{opacity:.5;cursor:not-allowed}.te-btn-delete{color:#c53030;cursor:pointer;background:#fff5f5;border:1px solid #feb2b2;border-radius:5px;padding:.3rem .7rem;font-size:.8rem;font-weight:600;transition:background .15s}.te-btn-delete:hover:not(:disabled){background:#fed7d7}.te-btn-delete:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.te-content,.te-content--split{flex-direction:column}.te-content--split .te-list-panel{flex:unset;width:100%}.te-form-grid{grid-template-columns:1fr}}.file\:mr-4::file-selector-button{margin-right:1rem}.file\:rounded-full::file-selector-button{border-radius:9999px}.file\:border-0::file-selector-button{border-width:0}.file\:bg-blue-50::file-selector-button{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.file\:px-4::file-selector-button{padding-left:1rem;padding-right:1rem}.file\:py-2::file-selector-button{padding-top:.5rem;padding-bottom:.5rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-semibold::file-selector-button{font-weight:600}.file\:text-blue-700::file-selector-button{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:rotate-1:hover{--tw-rotate:1deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-blue-400:hover{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.hover\:border-gray-300:hover{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.hover\:border-gray-400:hover{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity,1))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-emerald-50:hover{--tw-bg-opacity:1;background-color:rgb(236 253 245/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.hover\:bg-gray-400:hover{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-green-700:hover{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:rgb(254 202 202/var(--tw-bg-opacity,1))}.hover\:bg-violet-50:hover{--tw-bg-opacity:1;background-color:rgb(245 243 255/var(--tw-bg-opacity,1))}.hover\:from-green-600:hover{--tw-gradient-from:#16a34a var(--tw-gradient-from-position);--tw-gradient-to:#16a34a00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-green-700:hover{--tw-gradient-to:#15803d var(--tw-gradient-to-position)}.hover\:text-blue-500:hover{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.hover\:text-red-500:hover{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.hover\:text-yellow-300:hover{--tw-text-opacity:1;color:rgb(253 224 71/var(--tw-text-opacity,1))}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--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)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--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)}.hover\:file\:bg-blue-100::file-selector-button:hover{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:border-indigo-500:focus{--tw-border-opacity:1;border-color:rgb(99 102 241/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:#0000}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.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-2: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(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)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-green-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(34 197 94/var(--tw-ring-opacity,1))}.focus\:ring-indigo-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(99 102 241/var(--tw-ring-opacity,1))}.focus\:ring-yellow-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(250 204 21/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.active\:cursor-grabbing:active{cursor:grabbing}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:640px){.sm\:order-1{order:1}.sm\:order-2{order:2}.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1280px){.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
