/*! 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}.inline{display:inline}.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:14px;margin-bottom:24px;display:flex}.login-buttons button{color:#fff;-webkit-backdrop-filter:blur(20px)saturate(1.5);cursor:pointer;background:#ffffff2e;border:1px solid #ffffff73;border-radius:999px;justify-content:center;align-items:center;gap:0;min-width:260px;padding:13px 28px;font-family:Noto Sans TC,sans-serif;font-size:.95rem;font-weight:600;transition:all .25s;display:flex;box-shadow:inset 0 1px #ffffff59,0 8px 28px #0000002e,0 2px 6px #0000001a}.login-buttons button:hover{background:#ffffff47;border-color:#ffffffa6;transform:translateY(-2px);box-shadow:inset 0 1px #ffffff73,0 12px 36px #00000038,0 3px 8px #0000001f}.login-buttons button:active{transform:translateY(0)}.login-btn-facebook{background:#1877f247;border-color:#1877f28c}.login-btn-facebook:hover{background:#1877f266!important;border-color:#1877f2bf!important}.login-btn-line{background:#06c75547;border-color:#06c7558c}.login-btn-line:hover{background:#06c75566!important;border-color:#06c755bf!important}.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}.role-loading{color:#fff;opacity:.8;font-size:1.2rem}.role-badge-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-bottom:16px;display:flex}.role-chip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #ffffff59;border-radius:999px;padding:4px 14px;font-size:.82rem;font-weight:700}.role-chip.role-principal{color:#fde68a;background:#f6ad554d;border-color:#f6ad5580}.role-chip.role-supervisor{color:#bfdbfe;background:#63b3ed4d;border-color:#63b3ed80}.role-chip.role-teacher{color:#d1fae5;background:#68d39133;border-color:#68d39166}.email-small{color:#fff9;font-size:.8rem}.class-selector{text-align:center;margin-bottom:20px}.selector-label{opacity:.75;letter-spacing:.05em;margin-bottom:10px;font-size:.85rem}.class-tabs-wrap{flex-wrap:wrap;justify-content:center;gap:8px;max-width:600px;margin:0 auto;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:7px 18px;font-size:.85rem;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,.gen-progress-text{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;-webkit-backdrop-filter:blur(16px)saturate(1.5);color:#fff;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff73;border-radius:999px;align-items:center;gap:6px;padding:8px 18px;font-size:.82rem;font-weight:600;transition:all .25s;display:inline-flex;position:absolute;top:20px;right:20px;box-shadow:inset 0 1px #ffffff4d,0 4px 16px #00000026}.download-report-btn:before{content:"";background:currentColor;flex-shrink:0;width:14px;height:14px;display:inline-block;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v13M5 14l7 7 7-7'/%3E%3Cpath d='M4 21h16'/%3E%3C/svg%3E") 50%/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v13M5 14l7 7 7-7'/%3E%3Cpath d='M4 21h16'/%3E%3C/svg%3E") 50%/contain no-repeat}.download-report-btn:hover{background:#ffffff47;border-color:#ffffffa6;transform:translateY(-1px);box-shadow:inset 0 1px #fff6,0 6px 20px #0003}.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}.tag-removable{align-items:center;gap:5px;padding-right:6px;display:inline-flex}.tag-remove-btn{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;padding:0 1px;font-size:.9rem;line-height:1;transition:all .15s}.tag-remove-btn:hover{opacity:1;transform:scale(1.2)}.tag-editor{flex-direction:column;gap:8px;display:flex}.preset-tags{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.preset-label{color:#ffffff73;white-space:nowrap;font-size:.75rem}.preset-tag-btn{cursor:pointer;color:#ffffffa6;background:#ffffff0f;border:1px dashed #ffffff4d;border-radius:999px;padding:3px 10px;font-size:.75rem;transition:all .2s}.preset-tag-btn:hover{color:#fff;background:#ffffff26;border-style:solid}.editable-hover{cursor:pointer;border-radius:6px;margin:-4px -6px;padding:4px 6px;transition:background .2s;position:relative}.editable-hover:hover{background:#ffffff14}.edit-icon{opacity:0;margin-left:6px;font-size:.7rem;transition:all .2s}.editable-hover:hover .edit-icon{opacity:.6}.edit-hint{color:#ffffff59;margin-left:6px;font-size:.72rem;font-weight:400}.editable-textarea{color:#fff;resize:vertical;background:#ffffff14;border:1px solid #ffffff4d;border-radius:8px;width:100%;padding:8px 10px;font-family:Noto Sans TC,sans-serif;font-size:.88rem;line-height:1.7}.editable-textarea:focus{background:#ffffff1f;border-color:#ffffff8c;outline:none}.placeholder-hint{color:#ffffff4d;font-style:italic}.principal-only-badge{color:#fde68a;vertical-align:middle;background:#f6ad554d;border:1px solid #f6ad5580;border-radius:999px;margin-left:10px;padding:2px 10px;font-size:.72rem}.principal-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.principal-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.principal-input{-moz-appearance:textfield}.principal-stats-row{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.principal-stat-card{text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid;border-radius:14px;flex:1;min-width:120px;padding:16px}.pstat-icon{margin-bottom:4px;font-size:1.6rem}.pstat-count{font-size:2rem;font-weight:800;line-height:1}.pstat-label{color:#ffffffa6;margin-top:4px;font-size:.8rem}.principal-filter-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.principal-search{color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:10px;flex:1;min-width:200px;padding:8px 14px;font-size:.9rem}.principal-search:focus{border-color:#ffffff80;outline:none}.principal-search::-moz-placeholder{color:#fff6}.principal-search::placeholder{color:#fff6}.filter-tabs{flex-wrap:wrap;gap:8px;display:flex}.filter-tab{cursor:pointer;color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:999px;padding:6px 14px;font-size:.82rem;transition:all .2s}.filter-tab.active{color:#333;background:#ffffff59}.filter-tab:hover:not(.active){background:#fff3}.principal-guide{color:#ffffff8c;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:.82rem;line-height:1.6}.principal-guide strong{color:#fffc}.principal-loading{text-align:center;color:#fff9;padding:40px;font-size:1.1rem}.no-users{text-align:center;color:#fff6;padding:40px}.user-list{flex-direction:column;gap:12px;display:flex}.user-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff12;border:1px solid #ffffff1f;border-radius:14px;align-items:center;gap:16px;padding:16px;transition:all .2s;display:flex}.user-card:hover{background:#ffffff1a}.user-card.self-card{background:#f6ad5514;border-color:#f6ad5566}.user-avatar{flex-shrink:0}.user-photo{-o-object-fit:cover;object-fit:cover;border:2px solid #fff3;border-radius:50%;width:44px;height:44px}.user-initials{color:#fff;background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.2rem;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:#fff;align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.user-email{color:#ffffff8c;margin-top:2px;font-size:.8rem}.user-joined{color:#fff6;margin-top:2px;font-size:.75rem}.self-badge{color:#fde68a;background:#f6ad554d;border:1px solid #f6ad5580;border-radius:999px;padding:1px 8px;font-size:.7rem}.user-role-control{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.user-role-chip{white-space:nowrap;border:1px solid;border-radius:999px;padding:4px 12px;font-size:.8rem;font-weight:700}.role-select-row{gap:6px;display:flex}.role-btn{cursor:pointer;color:#fff;white-space:nowrap;background:#ffffff1a;border:1px solid #ffffff40;border-radius:8px;padding:4px 10px;font-size:.75rem;transition:all .2s}.role-btn:hover:not(:disabled){background:#ffffff40}.role-btn.active,.role-btn:disabled{opacity:.45;cursor:default}.onboarding-overlay{z-index:200;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a1980;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.onboarding-card{text-align:center;background:#ffffff1a;border:1px solid #fff3;border-radius:28px;width:100%;max-width:480px;padding:40px 36px;box-shadow:0 30px 80px #0006}.onboarding-logo{-o-object-fit:contain;object-fit:contain;width:100px;height:100px;margin:0 auto 16px;display:block}.onboarding-title{color:#fff;margin-bottom:8px;font-size:1.5rem;font-weight:800}.onboarding-sub{color:#ffffffa6;margin-bottom:28px;font-size:.9rem;line-height:1.6}.onboarding-choices{flex-direction:column;gap:14px;display:flex}.choice-btn{cursor:pointer;text-align:left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff40;border-radius:16px;flex-direction:column;align-items:flex-start;gap:4px;padding:18px 20px;transition:all .25s;display:flex}.choice-btn:hover{background:#fff3;transform:translateY(-2px)}.choice-icon{margin-bottom:2px;font-size:1.8rem}.choice-label{color:#fff;font-size:1rem;font-weight:700}.choice-desc{color:#fff9;font-size:.8rem;line-height:1.4}.create-btn:hover{border-color:#f6ad5580}.join-btn:hover{border-color:#63b3ed80}.onboarding-form{text-align:left}.form-label{color:#ffffffb3;margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.form-input{color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:10px;width:100%;margin-bottom:14px;padding:12px 14px;font-family:Noto Sans TC,sans-serif;font-size:1rem}.form-input:focus{background:#ffffff26;border-color:#fff9;outline:none}.form-input::-moz-placeholder{color:#ffffff59}.form-input::placeholder{color:#ffffff59}.invite-input{text-align:center;letter-spacing:.2em;font-size:1.4rem;font-weight:800}.invite-hint{color:#ffffff73;margin:-8px 0 16px;font-size:.78rem}.role-preview{color:#fff9;background:#ffffff0f;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:8px 12px;font-size:.82rem;display:flex}.role-preview-badge{border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:700}.role-preview-badge.principal{color:#fde68a;background:#f6ad554d;border:1px solid #f6ad5580}.form-error{color:#fc8181;margin-bottom:12px;font-size:.82rem}.form-actions{justify-content:flex-end;gap:10px;display:flex}.form-back-btn{cursor:pointer;color:#ffffffb3;background:#ffffff1a;border:1px solid #ffffff40;border-radius:10px;padding:10px 18px;font-size:.9rem;transition:all .2s}.form-back-btn:hover{background:#fff3}.form-submit-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#a78bfa,#60a5fa);border:none;border-radius:10px;padding:10px 22px;font-family:Noto Sans TC,sans-serif;font-size:.9rem;font-weight:700;transition:all .2s}.form-submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.form-submit-btn:disabled{opacity:.5;cursor:default}.form-submit-btn.small{padding:7px 16px;font-size:.82rem}.role-guide-box{background:#ffffff12;border:1px solid #ffffff1f;border-radius:16px;margin-bottom:20px;padding:20px}.role-guide-title{color:#fff9;margin-bottom:14px;font-size:.85rem;font-weight:700}.role-guide-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px;display:grid}.role-guide-item{text-align:center;background:#ffffff0d;border:1px solid;border-radius:12px;padding:12px}.role-guide-icon{margin-bottom:4px;font-size:1.4rem}.role-guide-label{margin-bottom:4px;font-size:.85rem;font-weight:700}.role-guide-count{color:#fff;font-size:1.3rem;font-weight:800}.role-guide-max{color:#ffffff73;margin-top:2px;font-size:.72rem}.role-guide-note{color:#ffffff80;font-size:.78rem;line-height:1.7}.role-guide-note b{color:#ffffffbf}.mgmt-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.mgmt-tab{cursor:pointer;color:#ffffffb3;background:#ffffff14;border:1px solid #ffffff40;border-radius:999px;padding:8px 20px;font-size:.88rem;font-weight:600;transition:all .2s}.mgmt-tab:hover{color:#fff;background:#ffffff26}.mgmt-tab.active{color:#fff;background:#ffffff40;border-color:#ffffff80}.invite-panel-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-subtitle{color:#fff;font-size:1rem;font-weight:700}.gen-invite-btn{cursor:pointer;color:#fff;background:#ffffff1f;border:1px solid #ffffff59;border-radius:999px;padding:7px 16px;font-size:.82rem;font-weight:600;transition:all .2s}.gen-invite-btn:hover{background:#ffffff40}.invite-form{background:#ffffff12;border:1px solid #ffffff1f;border-radius:14px;margin-bottom:16px;padding:16px}.invite-form-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.invite-form-row label{color:#ffffffa6;min-width:60px;font-size:.82rem}.invite-select{color:#fff;background:#ffffff1a;border:1px solid #ffffff40;border-radius:8px;flex:1;padding:7px 10px;font-family:Noto Sans TC,sans-serif;font-size:.85rem}.invite-num-row{align-items:center;gap:8px;display:flex}.invite-num-input{text-align:center;color:#fff;background:#ffffff1a;border:1px solid #ffffff40;border-radius:8px;width:64px;padding:6px 10px;font-size:.9rem}.invite-num-input::-webkit-outer-spin-button{-webkit-appearance:none}.invite-num-input::-webkit-inner-spin-button{-webkit-appearance:none}.invite-list{flex-direction:column;gap:10px;display:flex}.no-invites{color:#fff6;text-align:center;padding:24px;font-size:.85rem}.invite-item{background:#ffffff12;border:1px solid #ffffff1f;border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex}.invite-item.invite-inactive{opacity:.5}.invite-code-block{align-items:center;gap:8px;display:flex}.invite-code{color:#fff;letter-spacing:.12em;font-family:monospace;font-size:1.1rem;font-weight:800}.copy-btn{cursor:pointer;color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;padding:3px 10px;font-size:.75rem;transition:all .2s}.copy-btn:hover{background:#ffffff38}.invite-meta{flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.invite-role-chip{border-radius:999px;padding:2px 10px;font-size:.75rem;font-weight:600}.invite-status{border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:600}.invite-status.active{color:#68d391;background:#68d39133}.invite-status.expired{color:#fc8181;background:#fc818133}.invite-status.full{color:#f6ad55;background:#f6ad5533}.invite-uses{color:#ffffff80;font-size:.75rem}.invite-expiry{color:#ffffff73;font-size:.75rem}.invite-delete-btn{cursor:pointer;color:#fff6;background:0 0;border:none;padding:4px;font-size:1rem;transition:all .2s}.invite-delete-btn:hover{color:#fc8181}.setup-guide-box{background:#06c7550f;border:1px solid #06c75540;border-radius:16px;overflow:hidden}.setup-guide-toggle{cursor:pointer;color:#fff;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:16px 20px;font-family:Noto Sans TC,sans-serif;font-size:1rem;font-weight:700;display:flex}.setup-guide-toggle:hover{background:#ffffff0d}.setup-guide-content{padding:0 20px 20px}.setup-guide-intro{color:#ffffffa6;margin-bottom:16px;font-size:.85rem;line-height:1.6}.setup-step{margin-bottom:18px}.setup-step-title{color:#fff;align-items:center;gap:12px;margin-bottom:8px;font-size:.9rem;font-weight:700;display:flex}.setup-step-link{color:#6ee7b7;background:#06c75533;border:1px solid #06c7554d;border-radius:6px;padding:3px 10px;font-size:.78rem;text-decoration:none;transition:all .2s}.setup-step-link:hover{background:#06c75559}.setup-step-list{padding-left:20px;list-style:decimal}.setup-step-list li{color:#ffffffb3;margin-bottom:6px;font-size:.82rem;line-height:1.6}.setup-code-block{color:#a5f3fc;word-break:break-all;background:#0000004d;border-radius:6px;margin-top:4px;padding:6px 10px;font-family:monospace;font-size:.8rem;display:block}@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}
