/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-red-500:oklch(63.7% .237 25.331);--color-red-700:oklch(50.5% .213 27.518);--color-orange-500:oklch(70.5% .213 47.604);--color-orange-600:oklch(64.6% .222 41.116);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-cyan-50:oklch(98.4% .019 200.873);--color-cyan-500:oklch(71.5% .143 215.221);--color-cyan-600:oklch(60.9% .126 221.723);--color-blue-50:oklch(97% .014 254.604);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-purple-50:oklch(97.7% .014 308.299);--color-purple-200:oklch(90.2% .063 306.703);--color-purple-500:oklch(62.7% .265 303.9);--color-purple-600:oklch(55.8% .288 302.321);--color-pink-50:oklch(97.1% .014 343.198);--color-pink-500:oklch(65.6% .241 354.308);--color-pink-600:oklch(59.2% .249 .584);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-white:#fff;--spacing:.25rem;--container-4xl:56rem;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--font-weight-semibold:600;--font-weight-bold:700;--leading-relaxed:1.625;--radius-lg:.5rem;--radius-xl:.75rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--animate-spin:spin 1s linear infinite;--blur-lg:16px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.absolute{position:absolute}.inset-0{inset:calc(var(--spacing)*0)}.z-10{z-index:10}.mx-auto{margin-inline:auto}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-8{margin-top:calc(var(--spacing)*8)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.flex{display:flex}.h-10{height:calc(var(--spacing)*10)}.h-48{height:calc(var(--spacing)*48)}.w-10{width:calc(var(--spacing)*10)}.w-full{width:100%}.max-w-4xl{max-width:var(--container-4xl)}.animate-spin{animation:var(--animate-spin)}.resize{resize:both}.resize-none{resize:none}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-blue-200{border-color:var(--color-blue-200)}.border-gray-600{border-color:var(--color-gray-600)}.border-purple-200{border-color:var(--color-purple-200)}.border-red-200{border-color:var(--color-red-200)}.border-red-500\/50{border-color:#fb2c3680}@supports (color:color-mix(in lab,red,red)){.border-red-500\/50{border-color:color-mix(in oklab,var(--color-red-500)50%,transparent)}}.bg-gray-600{background-color:var(--color-gray-600)}.bg-gray-700{background-color:var(--color-gray-700)}.bg-gray-700\/50{background-color:#36415380}@supports (color:color-mix(in lab,red,red)){.bg-gray-700\/50{background-color:color-mix(in oklab,var(--color-gray-700)50%,transparent)}}.bg-gray-800\/90{background-color:#1e2939e6}@supports (color:color-mix(in lab,red,red)){.bg-gray-800\/90{background-color:color-mix(in oklab,var(--color-gray-800)90%,transparent)}}.bg-green-600{background-color:var(--color-green-600)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-500\/20{background-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/20{background-color:color-mix(in oklab,var(--color-red-500)20%,transparent)}}.bg-white\/90{background-color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.bg-white\/90{background-color:color-mix(in oklab,var(--color-white)90%,transparent)}}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from:var(--color-blue-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-blue-500{--tw-gradient-from:var(--color-blue-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-purple-50{--tw-gradient-from:var(--color-purple-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-purple-500{--tw-gradient-from:var(--color-purple-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-yellow-400{--tw-gradient-from:var(--color-yellow-400);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-yellow-500{--tw-gradient-from:var(--color-yellow-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-cyan-50{--tw-gradient-to:var(--color-cyan-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-cyan-500{--tw-gradient-to:var(--color-cyan-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-orange-500{--tw-gradient-to:var(--color-orange-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-pink-50{--tw-gradient-to:var(--color-pink-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-pink-500{--tw-gradient-to:var(--color-pink-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-8{padding-block:calc(var(--spacing)*8)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-pre-wrap{white-space:pre-wrap}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-red-200{color:var(--color-red-200)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.opacity-85{opacity:.85}.mix-blend-screen{mix-blend-mode:screen}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.backdrop-blur-lg{--tw-backdrop-blur:blur(var(--blur-lg));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.hover\:bg-gray-600:hover{background-color:var(--color-gray-600)}.hover\:bg-gray-700:hover{background-color:var(--color-gray-700)}.hover\:bg-green-700:hover{background-color:var(--color-green-700)}.hover\:from-blue-600:hover{--tw-gradient-from:var(--color-blue-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.hover\:from-purple-600:hover{--tw-gradient-from:var(--color-purple-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.hover\:from-yellow-600:hover{--tw-gradient-from:var(--color-yellow-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.hover\:to-cyan-600:hover{--tw-gradient-to:var(--color-cyan-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.hover\:to-orange-600:hover{--tw-gradient-to:var(--color-orange-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.hover\:to-pink-600:hover{--tw-gradient-to:var(--color-pink-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}}.focus\:border-yellow-500:focus{border-color:var(--color-yellow-500)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-yellow-500\/50:focus{--tw-ring-color:#edb20080}@supports (color:color-mix(in lab,red,red)){.focus\:ring-yellow-500\/50:focus{--tw-ring-color:color-mix(in oklab,var(--color-yellow-500)50%,transparent)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;font-family:Noto Sans TC,sans-serif;overflow:hidden}.app-container{background-size:300% 300%;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100vh;transition:background 2s;animation:10s infinite alternate bgFlow;display:flex;position:relative;overflow:hidden}.app-container.transitioning{transition:background 1s ease-in-out}@keyframes bgFlow{0%{background-position:0%}to{background-position:100%}}.wave-layer{z-index:5;mix-blend-mode:overlay;pointer-events:none;position:absolute;inset:0}@keyframes waveShift1{0%{transform:translate(0)}to{transform:translate(50px)}}@keyframes waveShift2{0%{transform:translateY(0)}to{transform:translateY(40px)}}@keyframes waveShift3{0%{transform:translate(-50px)translateY(20px)}to{transform:translate(30px)translateY(-20px)}}.top-glow{z-index:15;mix-blend-mode:overlay;pointer-events:none;filter:blur(60px);background:radial-gradient(circle at 30% 30%,#ffffff40,#0000 60%),radial-gradient(circle at 70% 70%,#fff3,#0000 70%);width:200%;height:200%;animation:12s ease-in-out infinite alternate glowShift;position:absolute;top:0;left:0}@keyframes glowShift{0%{transform:translate(-50px,-50px)rotate(0)}to{transform:translate(50px,50px)rotate(10deg)}}canvas{pointer-events:none;inset:0;z-index:10!important;position:absolute!important}.content-box{z-index:50;text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;width:100%;animation:1s forwards fadeIn;display:flex;position:relative}.content-box img{-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 0 20px #ffdc32b3);width:220px;height:220px;margin:0 auto 32px;animation:3s ease-in-out infinite floating;display:block}.login-buttons{flex-direction:column;justify-content:center;align-items:center;gap:16px;margin-bottom:24px;display:flex}.login-buttons button{color:#333;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;background:#ffffff4d;border:1px solid #fff6;border-radius:999px;padding:12px 32px;font-weight:600;transition:all .3s;box-shadow:0 8px 30px #0000001f}.login-buttons button:hover{background:#ffffff40;transform:translateY(2px)}.theme-dots{z-index:60;justify-content:center;align-items:center;gap:16px;margin-top:40px;position:relative;flex-direction:row!important;display:flex!important}.theme-dot{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;border:1px solid #fff6;border-radius:50%;width:36px;height:36px;transition:all .4s;box-shadow:inset 0 2px 8px #ffffff73,0 6px 18px #00000026}.theme-dot:hover{filter:brightness(1.3);transform:scale(1.15)}.theme-dot.active{outline:3px solid #ffffffbf}.theme-dot.pink{background:linear-gradient(135deg,#f9a8d4,#f472b6,#fbcfe8)}.theme-dot.blue{background:linear-gradient(135deg,#60a5fa,#3b82f6,#93c5fd)}.theme-dot.green{background:linear-gradient(135deg,#4ade80,#22c55e,#a7f3d0)}.theme-dot.yellow{background:linear-gradient(135deg,#fde047,#facc15,#fef08a)}.theme-dot.purple{background:linear-gradient(135deg,#a78bfa,#8b5cf6,#c4b5fd)}.slogan{text-shadow:0 2px 3px #00000040;margin-top:40px;font-size:1.2rem;font-weight:500;line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes floating{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dashboard{flex-direction:column;justify-content:center;align-items:center;display:flex}.welcome-title{text-shadow:0 2px 6px #0000004d;margin-bottom:10px;font-size:2rem;font-weight:700}.email{opacity:.9;margin-bottom:30px;font-size:1rem}.button-group{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:30px;display:flex}.button-group button{color:#333;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;background:#ffffff4d;border:1px solid #ffffff80;border-radius:999px;padding:12px 24px;font-weight:600;transition:all .3s;box-shadow:0 4px 20px #0000001a}.button-group button:hover{background:#ffffff73;transform:scale(1.05)}.logout-btn{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;background:#ffffff26;border:1px solid #fff9;border-radius:999px;margin-top:30px;padding:10px 24px;font-weight:600;transition:all .3s}.logout-btn:hover{background:#ffffff40}.slogan.small{opacity:.9;margin-top:20px;font-size:1rem}.class-selector{text-align:center;margin-bottom:20px}.selector-label{opacity:.75;letter-spacing:.05em;margin-bottom:10px;font-size:.85rem}.class-tabs{justify-content:center;gap:10px;display:flex}.class-tab{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff6;border-radius:999px;padding:8px 22px;font-size:.9rem;font-weight:600;transition:all .25s}.class-tab:hover{background:#ffffff47}.class-tab.active{color:#333;background:#ffffff73;box-shadow:0 4px 18px #00000026}.upload-hint{opacity:.65;text-align:center;color:#fff;margin-top:-10px;margin-bottom:16px;font-size:.82rem}.upload-overlay{z-index:9999;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0a19bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upload-modal{text-align:center;background:#ffffff12;border:1px solid #ffffff2e;border-radius:24px;padding:48px 56px;box-shadow:0 30px 80px #0006}.upload-spinner{width:80px;height:80px;margin:0 auto 24px;position:relative}.spinner-ring{border:3px solid #0000;border-top-color:#fffc;border-radius:50%;animation:1s linear infinite spin;position:absolute;inset:0}.spinner-ring.delay1{border-top-color:#a78bfab3;animation-duration:1.4s;inset:10px}.spinner-ring.delay2{border-top-color:#63b3ed99;animation-duration:1.8s;inset:20px}@keyframes spin{to{transform:rotate(360deg)}}.upload-stage-text{color:#fff;margin-bottom:20px;font-size:1.1rem;font-weight:600}.upload-progress-track{background:#ffffff26;border-radius:3px;width:240px;height:6px;margin:0 auto 8px;overflow:hidden}.upload-progress-fill{background:linear-gradient(90deg,#a78bfa,#60a5fa);border-radius:3px;height:100%;transition:width .4s}.upload-progress-pct{color:#ffffffa6;font-size:.85rem}.results-container{background-size:300% 300%;width:100%;min-height:100vh;animation:10s infinite alternate bgFlow;position:relative;overflow-y:auto}.results-page{z-index:50;max-width:1200px;margin:0 auto;padding:24px 24px 80px;position:relative}.results-topbar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;display:flex}.back-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #fff6;border-radius:999px;padding:8px 20px;font-weight:600;transition:all .25s}.back-btn:hover{background:#ffffff47}.results-title{color:#fff;align-items:center;gap:12px;font-size:1.4rem;font-weight:700;display:flex}.results-count{opacity:.7;font-size:.9rem;font-weight:400}.gen-progress{background:#ffffff26;border-radius:4px;flex:1;align-items:center;min-width:120px;height:8px;display:flex;position:relative;overflow:hidden}.gen-progress-bar{background:linear-gradient(90deg,#a78bfa,#60a5fa);border-radius:4px;height:100%;transition:width .5s}.gen-progress span{color:#fff;white-space:nowrap;font-size:.75rem;position:absolute;right:0}.teacher-kpi-box{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;margin-bottom:32px;padding:28px;box-shadow:0 8px 32px #00000026}.teacher-kpi-title{color:#fff;margin-bottom:20px;font-size:1.2rem;font-weight:700}.teacher-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;display:grid}.teacher-kpi-item{text-align:center;background:#ffffff14;border:1px solid #ffffff26;border-radius:14px;padding:16px}.teacher-kpi-item.highlight{background:#a78bfa33;border-color:#a78bfa66}.teacher-kpi-item.final{background:#63b3ed33;border-color:#63b3ed66}.tkpi-label{color:#ffffffa6;margin-bottom:8px;font-size:.8rem}.tkpi-value{color:#fff;font-size:2rem;font-weight:800;line-height:1}.tkpi-value.final-score{color:#93c5fd}.tkpi-sub{color:#ffffff80;margin-top:4px;font-size:.72rem}.tkpi-level-badge{color:#fff;background:#fff3;border-radius:999px;margin:6px 0;padding:3px 12px;font-size:.8rem;font-weight:600;display:inline-block}.principal-input-row{justify-content:center;gap:8px;margin-top:8px;display:flex}.principal-input{color:#fff;text-align:center;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:8px;width:72px;padding:6px 10px;font-size:1rem}.principal-input:focus{border-color:#fff9;outline:none}.principal-submit-btn{cursor:pointer;color:#fff;background:#fff3;border:1px solid #fff6;border-radius:8px;padding:6px 14px;font-weight:600;transition:all .2s}.principal-submit-btn:hover{background:#ffffff59}.reset-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;margin-top:6px;font-size:.75rem;text-decoration:underline}.teacher-kpi-note{color:#ffffff8c;margin-top:16px;font-size:.8rem;line-height:1.6}.student-reports-grid{flex-direction:column;gap:24px;display:flex}.report-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;padding:28px;animation:.5s forwards fadeIn;position:relative;box-shadow:0 8px 32px #00000026}.report-card.loading-card{opacity:.6}.download-report-btn{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #fff6;border-radius:999px;padding:7px 16px;font-size:.8rem;font-weight:600;transition:all .25s;position:absolute;top:20px;right:20px}.download-report-btn:hover{background:#ffffff4d;transform:scale(1.03)}.report-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.student-name{color:#fff;font-size:1.5rem;font-weight:800}.student-meta{color:#fff9;margin-top:2px;font-size:.85rem}.level-badge{border-radius:999px;padding:6px 20px;font-size:.95rem;font-weight:700;box-shadow:0 2px 12px #0003}.generating-badge{color:#ffffff80;font-size:.9rem;animation:1.5s infinite pulse}@keyframes pulse{50%{opacity:.5}}.report-body{grid-template-columns:260px 1fr;gap:24px;display:grid}@media (max-width:700px){.report-body{grid-template-columns:1fr}}.report-left{flex-direction:column;gap:16px;display:flex}.radar-wrap{background:#ffffff0a;border-radius:16px;justify-content:center;align-items:center;padding:12px;display:flex}.kpi-list{flex-direction:column;gap:8px;display:flex}.kpi-row{border-bottom:1px solid #ffffff0f;align-items:center;gap:8px;padding:4px 0;display:flex}.kpi-name{color:#fffc;flex:1;font-size:.8rem}.kpi-bar-wrap{background:#ffffff1a;border-radius:3px;width:80px;height:5px;overflow:hidden}.kpi-bar{border-radius:3px;height:100%;transition:width .6s}.kpi-score{color:#fff;text-align:right;min-width:24px;font-size:.8rem;font-weight:700}.report-right{flex-direction:column;gap:16px;display:flex}.ai-section-title{color:#ffffffb3;margin-bottom:8px;font-size:.85rem;font-weight:700}.ai-text{color:#ffffffd9;font-size:.88rem;line-height:1.7}.tag-list{flex-wrap:wrap;gap:8px;display:flex}.tag{color:#fff;background:#ffffff1a;border-radius:999px;padding:4px 12px;font-size:.78rem}.strength-tag{background:#68d39140;border:1px solid #68d39166}.improve-tag{background:#f6ad5533;border:1px solid #f6ad5559}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
