:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--fluent-neutral-foreground-1: #242424;--fluent-neutral-foreground-2: #424242;--fluent-neutral-foreground-3: #616161;--fluent-neutral-background-1: #ffffff;--fluent-neutral-background-2: #f5f5f5;--fluent-neutral-background-3: #f0f0f0;--fluent-neutral-stroke-1: #d1d1d1;--fluent-neutral-stroke-2: #e0e0e0;--fluent-brand-primary: #0078d4;--fluent-brand-primary-hover: #106ebe;--fluent-brand-primary-pressed: #005a9e;--fluent-brand-background-1: #e6f2ff;--fluent-brand-foreground-1: #0078d4;--fluent-success: #0f7b0f;--fluent-warning: #f7630c;--fluent-danger: #d13438;--fluent-info: #0078d4;--fluent-surface-primary: #ffffff;--fluent-surface-secondary: #fafafa;--fluent-overlay-background: rgba(0, 0, 0, .4);--fluent-font-family: "Segoe UI", -apple-system, BlinkMacSystemFont, "Roboto", "Helvetica Neue", sans-serif;--fluent-font-size-base: 14px;--fluent-font-size-200: 12px;--fluent-font-size-300: 14px;--fluent-font-size-400: 16px;--fluent-font-size-500: 20px;--fluent-font-size-600: 24px;--fluent-font-size-700: 28px;--fluent-font-size-800: 32px;--fluent-space-xs: 4px;--fluent-space-sm: 8px;--fluent-space-md: 12px;--fluent-space-lg: 16px;--fluent-space-xl: 20px;--fluent-space-2xl: 24px;--fluent-space-3xl: 32px;--fluent-radius-none: 0;--fluent-radius-sm: 2px;--fluent-radius-md: 4px;--fluent-radius-lg: 8px;--fluent-radius-xl: 12px;--fluent-radius-circular: 50%;--fluent-shadow-2: 0 0 2px rgba(0,0,0,.12), 0 2px 4px rgba(0,0,0,.14);--fluent-shadow-4: 0 0 2px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.14);--fluent-shadow-8: 0 0 2px rgba(0,0,0,.12), 0 8px 16px rgba(0,0,0,.14);--fluent-shadow-16: 0 0 2px rgba(0,0,0,.12), 0 16px 32px rgba(0,0,0,.14);--fluent-duration-faster: .1s;--fluent-duration-fast: .15s;--fluent-duration-normal: .2s;--fluent-duration-slow: .3s;--fluent-curve-easy-ease: cubic-bezier(.33, 0, .67, 1)}[data-theme=dark]{--fluent-neutral-foreground-1: #ffffff;--fluent-neutral-foreground-2: #e0e0e0;--fluent-neutral-foreground-3: #c7c7c7;--fluent-neutral-background-1: #1f1f1f;--fluent-neutral-background-2: #2b2b2b;--fluent-neutral-background-3: #333333;--fluent-neutral-stroke-1: #424242;--fluent-neutral-stroke-2: #383838;--fluent-surface-primary: #1f1f1f;--fluent-surface-secondary: #2b2b2b}body{font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-base);color:var(--fluent-neutral-foreground-1);background:var(--fluent-neutral-background-2);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fluent-card{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);box-shadow:var(--fluent-shadow-2);transition:all var(--fluent-duration-normal) var(--fluent-curve-easy-ease)}.fluent-card:hover{box-shadow:var(--fluent-shadow-4);border-color:var(--fluent-neutral-stroke-1)}.fluent-card-elevated{box-shadow:var(--fluent-shadow-8);border:none}.fluent-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--fluent-space-sm);padding:var(--fluent-space-sm) var(--fluent-space-lg);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);font-weight:600;line-height:20px;border-radius:var(--fluent-radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--fluent-duration-fast) var(--fluent-curve-easy-ease);-webkit-user-select:none;user-select:none;outline:none}.fluent-btn:focus-visible{outline:2px solid var(--fluent-brand-primary);outline-offset:2px}.fluent-btn-primary{background:var(--fluent-brand-primary);color:#fff;border-color:var(--fluent-brand-primary)}.fluent-btn-primary:hover{background:var(--fluent-brand-primary-hover);border-color:var(--fluent-brand-primary-hover)}.fluent-btn-primary:active{background:var(--fluent-brand-primary-pressed);border-color:var(--fluent-brand-primary-pressed)}.fluent-btn-subtle{background:transparent;color:var(--fluent-neutral-foreground-1)}.fluent-btn-subtle:hover{background:var(--fluent-neutral-background-3)}.fluent-btn-subtle:active{background:var(--fluent-neutral-background-2)}.fluent-btn-outline{background:transparent;color:var(--fluent-neutral-background-1);border-color:var(--fluent-neutral-stroke-1)}.fluent-btn-outline:hover{background:var(--fluent-neutral-background-1);border-color:var(--fluent-brand-primary)}.fluent-btn-success{background:var(--fluent-success);color:#fff}.fluent-btn-success:hover{background:#0d6b0d}.fluent-btn-danger{background:var(--fluent-danger);color:#fff}.fluent-btn-danger:hover{background:#b02e31;transform:translateY(-1px);border-color:var(--fluent-neutral-stroke-2);box-shadow:var(--fluent-shadow-4)}.fluent-btn-icon{width:32px;height:32px;padding:0;min-width:32px}.fluent-input{font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-1);background:var(--fluent-neutral-background-1);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);padding:var(--fluent-space-sm) var(--fluent-space-md);outline:none;transition:all var(--fluent-duration-fast) var(--fluent-curve-easy-ease);width:100%}.fluent-input:hover{border-color:var(--fluent-neutral-foreground-3)}.fluent-input:focus{border-color:var(--fluent-brand-primary);border-width:2px;padding:calc(var(--fluent-space-sm) - 1px) calc(var(--fluent-space-md) - 1px)}.fluent-badge{display:inline-flex;align-items:center;padding:2px var(--fluent-space-sm);font-size:var(--fluent-font-size-200);font-weight:600;border-radius:var(--fluent-radius-md);line-height:16px}.fluent-badge-primary{background:var(--fluent-brand-background-1);color:var(--fluent-brand-primary)}.fluent-badge-success{background:#dff6dd;color:var(--fluent-success)}.fluent-badge-danger{background:#fde7e9;color:var(--fluent-danger)}.fluent-badge-warning{background:#fff4ce;color:#bc4b09}.fluent-divider{border:none;border-top:1px solid var(--fluent-neutral-stroke-2);margin:var(--fluent-space-lg) 0}.fluent-avatar{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--fluent-radius-circular);background:var(--fluent-brand-background-1);color:var(--fluent-brand-primary);font-weight:600;overflow:hidden}.fluent-avatar-sm{width:24px;height:24px;font-size:var(--fluent-font-size-200)}.fluent-avatar-lg{width:48px;height:48px;font-size:var(--fluent-font-size-400)}.fluent-menu{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);box-shadow:var(--fluent-shadow-8);padding:var(--fluent-space-xs);min-width:160px}.fluent-menu-item{display:flex;align-items:center;gap:var(--fluent-space-sm);padding:var(--fluent-space-sm) var(--fluent-space-md);border-radius:var(--fluent-radius-md);cursor:pointer;transition:background var(--fluent-duration-faster)}.fluent-menu-item:hover{background:var(--fluent-neutral-background-3)}.fluent-table{width:100%;border-collapse:collapse;background:var(--fluent-surface-primary)}.fluent-table th{text-align:left;padding:var(--fluent-space-md);font-weight:600;font-size:var(--fluent-font-size-200);color:var(--fluent-neutral-foreground-2);border-bottom:2px solid var(--fluent-neutral-stroke-2)}.fluent-table td{padding:var(--fluent-space-md);border-bottom:1px solid var(--fluent-neutral-stroke-2)}.fluent-table tr:hover{background:var(--fluent-neutral-background-2)}.fluent-alert{display:flex;gap:var(--fluent-space-md);padding:var(--fluent-space-md);border-radius:var(--fluent-radius-md);border:1px solid}.fluent-alert-info{background:#e6f2ff;border-color:#0078d4;color:#004578}.fluent-alert-success{background:#dff6dd;border-color:#0f7b0f;color:#0e5c0e}.fluent-alert-warning{background:#fff4ce;border-color:#f7630c;color:#8a3707}.fluent-alert-danger{background:#fde7e9;border-color:#d13438;color:#8d2528}.fluent-spinner{width:20px;height:20px;border:2px solid var(--fluent-neutral-stroke-2);border-top-color:var(--fluent-brand-primary);border-radius:var(--fluent-radius-circular);animation:fluent-spin .8s linear infinite}@keyframes fluent-spin{to{transform:rotate(360deg)}}.fluent-dialog-overlay{position:fixed;inset:0;background:var(--fluent-overlay-background);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fluent-dialog{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);max-width:90vw;max-height:90vh;display:flex;flex-direction:column;animation:fluent-dialog-in var(--fluent-duration-slow) var(--fluent-curve-easy-ease)}@keyframes fluent-dialog-in{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.fluent-dialog-header{padding:var(--fluent-space-2xl);padding-bottom:var(--fluent-space-lg);font-size:var(--fluent-font-size-600);font-weight:600}.fluent-dialog-body{padding:0 var(--fluent-space-2xl);padding-bottom:var(--fluent-space-2xl);overflow-y:auto}.fluent-dialog-footer{padding:var(--fluent-space-lg) var(--fluent-space-2xl);border-top:1px solid var(--fluent-neutral-stroke-2);display:flex;gap:var(--fluent-space-sm);justify-content:flex-end}.fluent-elevation-2{box-shadow:var(--fluent-shadow-2)}.fluent-elevation-4{box-shadow:var(--fluent-shadow-4)}.fluent-elevation-8{box-shadow:var(--fluent-shadow-8)}.fluent-elevation-16{box-shadow:var(--fluent-shadow-16)}.fluent-text-caption{font-size:var(--fluent-font-size-200)}.fluent-text-body{font-size:var(--fluent-font-size-300)}.fluent-text-subtitle{font-size:var(--fluent-font-size-400);font-weight:600}.fluent-text-title{font-size:var(--fluent-font-size-600);font-weight:600}.fluent-text-display{font-size:var(--fluent-font-size-800);font-weight:600}@media(max-width:768px){:root{--fluent-font-size-base: 12px}}html{height:100%}body{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100%;display:flex;align-items:center;justify-content:center;padding:var(--fluent-space-lg)}#root{width:100%;display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-container{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);width:100%;max-width:440px;padding:var(--fluent-space-3xl);animation:slide-in .4s var(--fluent-curve-easy-ease)}.auth-header{text-align:center;margin-bottom:var(--fluent-space-3xl)}.auth-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--fluent-brand-primary),#667eea);border-radius:var(--fluent-radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--fluent-space-lg);color:#fff;font-size:32px}.auth-title{font-size:var(--fluent-font-size-700);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.auth-subtitle{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.auth-tabs{display:flex;gap:var(--fluent-space-sm);margin-bottom:var(--fluent-space-2xl);padding:4px;background:var(--fluent-neutral-background-2);border-radius:var(--fluent-radius-lg)}.auth-tab{flex:1;padding:var(--fluent-space-sm) var(--fluent-space-lg);border:none;background:transparent;border-radius:var(--fluent-radius-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-2);cursor:pointer;transition:all var(--fluent-duration-fast)}.auth-tab.active{background:var(--fluent-surface-primary);color:var(--fluent-brand-primary);box-shadow:var(--fluent-shadow-2)}.form-input{width:100%;padding:var(--fluent-space-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);outline:none;transition:all var(--fluent-duration-fast);box-sizing:border-box}.form-input:hover{border-color:var(--fluent-neutral-foreground-3)}.form-input:focus{border-color:var(--fluent-brand-primary);border-width:2px;padding:calc(var(--fluent-space-md) - 1px)}.form-message{margin-top:var(--fluent-space-md);padding:var(--fluent-space-md);border-radius:var(--fluent-radius-md);font-size:var(--fluent-font-size-200)}.form-message.error{background:#fde7e9;color:var(--fluent-danger);border:1px solid var(--fluent-danger)}.form-link{display:block;text-align:center;margin-top:var(--fluent-space-lg);color:var(--fluent-brand-primary);font-size:var(--fluent-font-size-300);text-decoration:none;cursor:pointer;font-weight:600}.form-link:hover{text-decoration:underline}.role-selector{display:flex;gap:var(--fluent-space-sm);margin-bottom:var(--fluent-space-lg)}.role-option{flex:1;padding:var(--fluent-space-md);border:2px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);display:flex;flex-direction:column;align-items:center;gap:var(--fluent-space-xs);cursor:pointer;transition:all var(--fluent-duration-fast);background:var(--fluent-surface-primary)}.role-option:hover,.role-option.selected{border-color:var(--fluent-brand-primary);background:var(--fluent-brand-background-1)}.role-option input[type=radio]{display:none}.role-icon{font-size:24px}.role-label{font-size:var(--fluent-font-size-200);font-weight:600;color:var(--fluent-neutral-foreground-2)}.form-view{display:none}.form-view.active{display:block;animation:fade-in .3s ease}body:has(.admin-layout){background:var(--fluent-neutral-background-2)!important;min-height:100vh;display:block!important;align-items:unset!important;justify-content:unset!important;padding:0!important;margin:0!important}#root:has(.admin-layout){height:100vh;width:100vw}.admin-layout{display:grid;grid-template-areas:"sidebar header" "sidebar main";grid-template-columns:280px 1fr;grid-template-rows:64px 1fr;height:100vh;width:100vw;overflow:hidden;font-family:var(--fluent-font-family);position:fixed;top:0;left:0}.app-header{grid-area:header;background:var(--fluent-surface-primary);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;align-items:center;justify-content:space-between;padding:0 var(--fluent-space-2xl);gap:var(--fluent-space-lg)}.header-title{font-size:var(--fluent-font-size-500);font-weight:600;margin:0;color:var(--fluent-neutral-foreground-1)}.header-actions{display:flex;gap:var(--fluent-space-sm);align-items:center}.app-sidebar{grid-area:sidebar;background:var(--fluent-surface-secondary);border-right:1px solid var(--fluent-neutral-stroke-2);display:flex;flex-direction:column;overflow-y:auto}.sidebar-brand{padding:var(--fluent-space-2xl);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;align-items:center;gap:var(--fluent-space-md)}.brand-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--fluent-brand-primary),#667eea);border-radius:var(--fluent-radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}.brand-name{font-size:var(--fluent-font-size-400);font-weight:600;color:var(--fluent-neutral-foreground-1)}.sidebar-nav{flex:1;padding:var(--fluent-space-lg)}.nav-section-title{font-size:var(--fluent-font-size-200);font-weight:600;color:var(--fluent-neutral-foreground-3);text-transform:uppercase;letter-spacing:.5px;margin:var(--fluent-space-lg) 0 var(--fluent-space-sm)}.nav-item{display:flex;align-items:center;gap:var(--fluent-space-md);padding:var(--fluent-space-sm) var(--fluent-space-md);border-radius:var(--fluent-radius-md);color:var(--fluent-neutral-foreground-2);text-decoration:none;font-size:var(--fluent-font-size-300);font-weight:500;cursor:pointer;transition:all var(--fluent-duration-fast);margin-bottom:var(--fluent-space-xs)}.nav-item:hover{background:var(--fluent-neutral-background-3);color:var(--fluent-neutral-foreground-1)}.nav-item.active{background:var(--fluent-brand-background-1);color:var(--fluent-brand-primary);font-weight:600}.nav-icon{font-size:20px}.sidebar-footer{padding:var(--fluent-space-lg);border-top:1px solid var(--fluent-neutral-stroke-2)}.user-profile{display:flex;align-items:center;gap:var(--fluent-space-md);padding:var(--fluent-space-sm);border-radius:var(--fluent-radius-md);cursor:pointer;transition:background var(--fluent-duration-fast)}.user-profile:hover{background:var(--fluent-neutral-background-3)}.user-avatar{width:36px;height:36px;border-radius:var(--fluent-radius-circular);background:linear-gradient(135deg,var(--fluent-brand-primary),#667eea);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600}.user-info{flex:1}.user-name{font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0}.user-role{font-size:var(--fluent-font-size-200);color:var(--fluent-neutral-foreground-3);margin:0}.app-main{grid-area:main;overflow-y:auto;background:var(--fluent-neutral-background-2);padding:var(--fluent-space-2xl)}.content-header{margin-bottom:var(--fluent-space-2xl)}.content-title{font-size:var(--fluent-font-size-700);font-weight:600;margin:0 0 var(--fluent-space-xs);color:var(--fluent-neutral-foreground-1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--fluent-space-lg);margin-bottom:var(--fluent-space-2xl)}.stat-card{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-2xl);transition:all var(--fluent-duration-normal)}.stat-card:hover{box-shadow:var(--fluent-shadow-4);transform:translateY(-2px)}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--fluent-space-lg)}.stat-icon{width:48px;height:48px;border-radius:var(--fluent-radius-lg);display:flex;align-items:center;justify-content:center;font-size:24px}.stat-icon.primary{background:var(--fluent-brand-background-1);color:var(--fluent-brand-primary)}.stat-icon.success{background:#dff6dd;color:var(--fluent-success)}.stat-icon.warning{background:#fff4ce;color:#bc4b09}.stat-icon.danger{background:#fde7e9;color:var(--fluent-danger)}.stat-value{font-size:var(--fluent-font-size-800);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.stat-label{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.card{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);margin-bottom:var(--fluent-space-2xl)}.card-header{padding:var(--fluent-space-2xl);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;justify-content:space-between;align-items:center}.card-title{font-size:var(--fluent-font-size-500);font-weight:600;margin:0;color:var(--fluent-neutral-foreground-1)}.card-body{padding:var(--fluent-space-2xl)}.list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--fluent-space-lg);border-bottom:1px solid var(--fluent-neutral-stroke-2);transition:background var(--fluent-duration-fast)}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--fluent-neutral-background-2)}.list-item-content{display:flex;align-items:center;gap:var(--fluent-space-md);flex:1}.list-item-info{flex:1}.list-item-title{font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-1);margin-bottom:var(--fluent-space-xs)}.list-item-subtitle{font-size:var(--fluent-font-size-200);color:var(--fluent-neutral-foreground-3)}.list-item-actions{display:flex;gap:var(--fluent-space-sm);align-items:center}.empty-state{text-align:center;padding:var(--fluent-space-3xl)}.empty-icon{font-size:48px;margin-bottom:var(--fluent-space-lg)}.empty-title{font-size:var(--fluent-font-size-500);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.empty-subtitle{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.form-input,.form-select,.form-textarea{width:100%;padding:var(--fluent-space-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);outline:none;transition:all var(--fluent-duration-fast);box-sizing:border-box}.toast{position:fixed;top:var(--fluent-space-2xl);right:var(--fluent-space-2xl);min-width:300px;padding:var(--fluent-space-lg);border-radius:var(--fluent-radius-lg);box-shadow:var(--fluent-shadow-8);display:flex;align-items:center;gap:var(--fluent-space-md);z-index:2000;animation:slideInRight .3s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.info{background:#e6f2ff;color:var(--fluent-info);border:1px solid var(--fluent-info)}.scheduler-layout{display:grid;grid-template-areas:"sidebar header" "sidebar main";grid-template-columns:280px 1fr;grid-template-rows:64px 1fr;height:100vh;width:100vw;overflow:hidden;font-family:var(--fluent-font-family);position:fixed;top:0;left:0;background:var(--fluent-neutral-background-2)}.scheduler-main{grid-area:main;display:flex;flex-direction:column;overflow:hidden}.content-header-scheduler{padding:var(--fluent-space-2xl);padding-bottom:var(--fluent-space-lg);display:flex;justify-content:space-between;align-items:flex-start}.content-info{display:flex;flex-direction:column;gap:var(--fluent-space-xs)}.content-title{font-size:var(--fluent-font-size-600);font-weight:600;margin:0;color:var(--fluent-neutral-foreground-1)}.content-subtitle{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.scheduler-container{flex:1;display:flex;overflow:hidden;padding:var(--fluent-space-2xl);padding-top:0;gap:var(--fluent-space-lg)}.history-panel{width:240px;flex-shrink:0;background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);display:flex;flex-direction:column;overflow:hidden}.history-header{padding:var(--fluent-space-lg);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;justify-content:space-between;align-items:center}.history-title{font-size:var(--fluent-font-size-400);font-weight:600;margin:0;color:var(--fluent-neutral-foreground-1)}.history-body{flex:1;overflow-y:auto;padding:var(--fluent-space-lg)}.history-body::-webkit-scrollbar{width:8px}.history-body::-webkit-scrollbar-track{background:var(--fluent-neutral-background-2)}.history-body::-webkit-scrollbar-thumb{background:var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md)}.history-footer{padding:var(--fluent-space-lg);border-top:1px solid var(--fluent-neutral-stroke-2);display:flex;flex-direction:column;gap:var(--fluent-space-sm)}.history-entry{margin-bottom:var(--fluent-space-md);padding-bottom:var(--fluent-space-md);border-bottom:1px solid var(--fluent-neutral-stroke-2);font-size:var(--fluent-font-size-200)}.history-entry:last-child{border-bottom:none}.history-time{font-weight:600;color:var(--fluent-brand-primary);margin-bottom:var(--fluent-space-xs)}.history-message{color:var(--fluent-neutral-foreground-2);line-height:1.4}.history-empty{text-align:center;padding:var(--fluent-space-2xl) var(--fluent-space-md);color:var(--fluent-neutral-foreground-3);font-size:var(--fluent-font-size-200)}.grid-wrapper{flex:1;background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);overflow:auto;padding:var(--fluent-space-lg)}.grid-wrapper::-webkit-scrollbar{width:12px;height:12px}.grid-wrapper::-webkit-scrollbar-track{background:var(--fluent-neutral-background-2)}.grid-wrapper::-webkit-scrollbar-thumb{background:var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md)}.grid-wrapper::-webkit-scrollbar-thumb:hover{background:var(--fluent-neutral-foreground-3)}.scheduler-grid{display:grid;gap:1px;background-color:var(--fluent-neutral-stroke-2);font-size:11px;min-width:min-content}.scheduler-grid>div{padding:6px 4px;text-align:center;background-color:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);min-height:40px;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--fluent-duration-fast)}.cell-header{background:var(--fluent-brand-background-1);color:var(--fluent-brand-primary);font-weight:600;font-size:12px}.cell-shift-label{background:var(--fluent-neutral-background-3);font-weight:600;color:var(--fluent-neutral-foreground-2);font-size:10px}.cell-teacher{background:var(--fluent-neutral-background-3);font-weight:600;color:var(--fluent-neutral-foreground-1);justify-content:flex-start;padding-left:var(--fluent-space-sm);font-size:11px}.cell-has-class{background:#dff6dd!important;color:var(--fluent-success);cursor:move;font-weight:600}.cell-has-class:hover{background:#c5edc1!important;transform:scale(1.05);box-shadow:var(--fluent-shadow-4);z-index:10}.cell-empty{color:var(--fluent-neutral-foreground-3);font-style:italic}.cell-empty:hover{background:var(--fluent-neutral-background-2);cursor:move}.cell-dragging{opacity:.5}.cell-drag-over{outline:2px dashed var(--fluent-brand-primary);outline-offset:-2px;background:var(--fluent-brand-background-1)!important}.cell-tooltip{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--fluent-neutral-foreground-1);color:#fff;padding:var(--fluent-space-xs) var(--fluent-space-sm);font-size:11px;border-radius:var(--fluent-radius-md);white-space:nowrap;z-index:100;box-shadow:var(--fluent-shadow-8);pointer-events:none}.cell-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--fluent-neutral-foreground-1)}.cell-has-class:hover .cell-tooltip{display:block}.loading-overlay{position:fixed;inset:0;background:var(--fluent-overlay-background);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner{width:48px;height:48px;border:4px solid var(--fluent-neutral-stroke-2);border-top-color:var(--fluent-brand-primary);border-radius:var(--fluent-radius-circular);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shifts-list{display:flex;flex-direction:column;gap:var(--fluent-space-sm);margin-bottom:var(--fluent-space-lg)}.shift-item{display:flex;gap:var(--fluent-space-sm);align-items:center}.shift-item input{flex:1}.shift-item button{flex-shrink:0}html:has(.profile-page-container){height:100%}body:has(.profile-page-container){background:linear-gradient(135deg,#667eea,#764ba2)!important;min-height:100%;display:flex!important;align-items:center!important;justify-content:center!important;padding:var(--fluent-space-lg)!important;margin:0!important}#root:has(.profile-page-container){width:100%;display:flex;align-items:center;justify-content:center;min-height:100vh}.profile-page-container{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);width:100%;max-width:500px;padding:var(--fluent-space-3xl);animation:slide-in .4s var(--fluent-curve-easy-ease);box-sizing:border-box;margin:0 auto;position:relative}.profile-header{text-align:center;margin-bottom:var(--fluent-space-3xl)}.profile-title{font-size:var(--fluent-font-size-700);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.profile-subtitle{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.photo-section{text-align:center;margin-bottom:var(--fluent-space-2xl)}.profile-pic{width:150px;height:150px;object-fit:cover;border-radius:var(--fluent-radius-circular);border:3px solid var(--fluent-brand-primary);background:var(--fluent-neutral-background-2);margin-bottom:var(--fluent-space-lg);box-shadow:var(--fluent-shadow-4);display:block;margin-left:auto;margin-right:auto}.photo-upload-btn{position:relative;overflow:hidden;display:inline-block}.photo-upload-btn input[type=file]{position:absolute;left:-9999px}.form-input,.form-textarea{width:100%;padding:var(--fluent-space-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);outline:none;transition:all var(--fluent-duration-fast);box-sizing:border-box}.form-textarea{min-height:80px;resize:vertical}.form-input:hover,.form-textarea:hover{border-color:var(--fluent-neutral-foreground-3)}.form-input:focus,.form-textarea:focus{border-color:var(--fluent-brand-primary);border-width:2px;padding:calc(var(--fluent-space-md) - 1px)}.form-message{margin-top:var(--fluent-space-md);padding:var(--fluent-space-md);border-radius:var(--fluent-radius-md);font-size:var(--fluent-font-size-300);animation:fade-in .3s ease}.form-message.success{background:#dff6dd;color:var(--fluent-success);border:1px solid var(--fluent-success)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.btn-submit{width:100%;padding:var(--fluent-space-md) var(--fluent-space-lg);background:var(--fluent-brand-primary);color:#fff;border:none;border-radius:var(--fluent-radius-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);font-weight:600;cursor:pointer;transition:all var(--fluent-duration-fast)}.btn-submit:hover{background:var(--fluent-brand-primary-hover);transform:translateY(-1px);box-shadow:var(--fluent-shadow-4)}.btn-submit:active{background:var(--fluent-brand-primary-pressed);transform:translateY(0)}body:has(.student-layout){background:linear-gradient(135deg,#667eea,#764ba2)!important;height:100vh!important;overflow:hidden!important;margin:0!important;padding:0!important;display:block!important}#root:has(.student-layout){height:100vh;width:100vw}.student-layout{display:grid;grid-template-columns:auto 1fr;height:100vh;width:100vw;overflow:hidden;font-family:var(--fluent-font-family)}.student-sidebar{grid-column:1;display:flex;flex-direction:column;width:250px;transition:width var(--fluent-duration-slow);background:var(--fluent-surface-primary);border-right:1px solid var(--fluent-neutral-stroke-2);overflow:hidden;box-shadow:var(--fluent-shadow-4)}.student-sidebar.collapsed{width:80px}.student-sidebar .toggle-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;padding:8px;transition:background var(--fluent-duration-fast);color:var(--fluent-neutral-foreground-1);width:100%;text-align:left}.student-sidebar .toggle-btn:hover{background:var(--fluent-neutral-background-2)}.student-sidebar .sidebar-header{display:flex;align-items:center;padding:8px;gap:8px;border-bottom:1px solid var(--fluent-neutral-stroke-2)}.student-sidebar .profile-pic{width:40px;height:40px;border-radius:var(--fluent-radius-circular);cursor:pointer;border:2px solid var(--fluent-brand-primary);object-fit:cover;margin:0}.student-sidebar .username{font-weight:600;white-space:nowrap;color:var(--fluent-neutral-foreground-1);font-size:var(--fluent-font-size-300)}.student-sidebar.collapsed .username{display:none}.student-sidebar .signout-btn{margin:auto 8px 8px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--fluent-radius-md);padding:8px 12px;font-weight:600}.student-sidebar .signout-btn .text{white-space:wrap}.student-sidebar.collapsed .signout-btn .text{display:none}.student-sidebar hr{border:none;border-top:1px solid var(--fluent-neutral-stroke-2);margin:0}.student-main{grid-column:2;overflow-y:auto;padding:var(--fluent-space-2xl)}.card-header-icons{display:flex;gap:var(--fluent-space-sm);font-size:18px;cursor:pointer;align-items:center}.card-header-icons span{cursor:pointer;transition:transform var(--fluent-duration-fast);color:var(--fluent-brand-primary)}.card-header-icons span:hover{transform:scale(1.1)}.modal{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);max-width:800px;width:90vw;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s var(--fluent-curve-easy-ease)}.modal-header{padding:var(--fluent-space-2xl);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;justify-content:space-between;align-items:center;background:var(--fluent-neutral-background-2)}.class-link{color:var(--fluent-brand-primary);text-decoration:none;font-weight:600;transition:all var(--fluent-duration-fast)}.class-link:hover{text-decoration:underline;color:var(--fluent-brand-primary-hover)}.class-link-disabled{color:var(--fluent-neutral-foreground-3);pointer-events:none;font-style:italic}@media(max-width:768px){.student-sidebar{width:80px}.student-sidebar .username,.student-sidebar .signout-btn .text{display:none}.cards-container{grid-template-columns:1fr}.dashboard-header h1{font-size:var(--fluent-font-size-600)}}*{box-sizing:border-box}body:has(.teacher-layout){background:linear-gradient(135deg,#667eea,#764ba2)!important;height:100vh!important;overflow:hidden!important;margin:0!important;padding:0!important;display:block!important}#root:has(.teacher-layout){height:100vh;width:100vw}.teacher-layout{display:grid;grid-template-columns:auto 1fr;height:100vh;width:100vw;overflow:hidden;font-family:var(--fluent-font-family)}.teacher-sidebar{grid-column:1;display:flex;flex-direction:column;width:250px;transition:width var(--fluent-duration-slow);background:var(--fluent-surface-primary);border-right:1px solid var(--fluent-neutral-stroke-2);overflow:hidden;box-shadow:var(--fluent-shadow-4)}.teacher-sidebar.collapsed{width:80px}.teacher-sidebar .toggle-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;padding:8px;transition:background var(--fluent-duration-fast);color:var(--fluent-neutral-foreground-1);width:100%;text-align:left}.teacher-sidebar .toggle-btn:hover{background:var(--fluent-neutral-background-2)}.teacher-sidebar .sidebar-header{display:flex;align-items:center;padding:8px;gap:8px;border-bottom:1px solid var(--fluent-neutral-stroke-2)}.teacher-sidebar .profile-pic{width:40px;height:40px;border-radius:var(--fluent-radius-circular);cursor:pointer;border:2px solid var(--fluent-brand-primary);object-fit:cover;margin:0}.teacher-sidebar .username{font-weight:600;white-space:nowrap;color:var(--fluent-neutral-foreground-1);font-size:var(--fluent-font-size-300)}.teacher-sidebar.collapsed .username{display:none}.teacher-sidebar .signout-btn{margin:auto 8px 8px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--fluent-radius-md);padding:8px 12px;font-weight:600}.teacher-sidebar .signout-btn .text{white-space:nowrap}.teacher-sidebar.collapsed .signout-btn .text{display:none}.teacher-main{grid-column:2;overflow-y:auto;padding:var(--fluent-space-2xl)}.dashboard-header{text-align:center;color:#fff;margin-bottom:var(--fluent-space-3xl)}.dashboard-header h1{font-size:var(--fluent-font-size-800);font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.cards-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--fluent-space-2xl);max-width:1400px;margin:0 auto}.dashboard-card{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-8);overflow:hidden;min-height:300px;max-height:500px;display:flex;flex-direction:column;transition:all var(--fluent-duration-normal)}.dashboard-card:hover{box-shadow:var(--fluent-shadow-16);transform:translateY(-2px)}.card-header{padding:var(--fluent-space-lg) var(--fluent-space-2xl);background:var(--fluent-neutral-background-2);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;align-items:center;justify-content:space-between}.card-header-title{font-size:var(--fluent-font-size-500);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0}.card-header-icons{display:flex;gap:var(--fluent-space-sm);font-size:18px;cursor:pointer}.card-header-icons span{cursor:pointer;transition:transform var(--fluent-duration-fast);color:var(--fluent-neutral-foreground-2)}.card-header-icons span:hover{transform:scale(1.1);color:var(--fluent-brand-primary)}.card-body{flex:1;overflow-y:auto;padding:var(--fluent-space-lg)}.card-body::-webkit-scrollbar{width:8px}.card-body::-webkit-scrollbar-track{background:var(--fluent-neutral-background-2)}.card-body::-webkit-scrollbar-thumb{background:var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md)}.dashboard-card table{width:100%;border-collapse:collapse}.dashboard-card thead{background:var(--fluent-neutral-background-2);position:sticky;top:0;z-index:1}.dashboard-card th{text-align:left;padding:var(--fluent-space-md);font-weight:600;font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-2);border-bottom:2px solid var(--fluent-neutral-stroke-2)}.dashboard-card td{padding:var(--fluent-space-md);border-bottom:1px solid var(--fluent-neutral-stroke-2);color:var(--fluent-neutral-foreground-1);font-size:var(--fluent-font-size-300)}.dashboard-card tr:hover{background:var(--fluent-neutral-background-2)}.empty-state{text-align:center;padding:var(--fluent-space-3xl);color:var(--fluent-neutral-foreground-3)}.empty-state p{margin:0;font-size:var(--fluent-font-size-300)}.fluent-btn-sm{padding:4px var(--fluent-space-sm);font-size:var(--fluent-font-size-200)}.modal-overlay{position:fixed;inset:0;background:var(--fluent-overlay-background);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);max-width:540px;width:90vw;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s var(--fluent-curve-easy-ease)}.modal-header{padding:var(--fluent-space-2xl);border-bottom:1px solid var(--fluent-neutral-stroke-2);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:var(--fluent-font-size-600);font-weight:600;margin:0;color:var(--fluent-neutral-foreground-1)}.modal-close{width:32px;height:32px;border:none;background:transparent;border-radius:var(--fluent-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--fluent-neutral-foreground-2);transition:all var(--fluent-duration-fast)}.modal-close:hover{background:var(--fluent-neutral-background-3)}.modal-body{padding:var(--fluent-space-2xl);overflow-y:auto;flex:1}.modal-body p{margin:0 0 var(--fluent-space-md);color:var(--fluent-neutral-foreground-2)}.modal-footer{padding:var(--fluent-space-lg) var(--fluent-space-2xl);border-top:1px solid var(--fluent-neutral-stroke-2);display:flex;gap:var(--fluent-space-sm);justify-content:flex-end}.form-group{margin-bottom:var(--fluent-space-lg)}.form-label{display:block;font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-2);margin-bottom:var(--fluent-space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--fluent-space-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);outline:none;transition:all var(--fluent-duration-fast);box-sizing:border-box;background:var(--fluent-surface-primary);color:var(--fluent-neutral-foreground-1)}.form-textarea{resize:vertical;min-height:100px}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--fluent-neutral-foreground-3)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--fluent-brand-primary);border-width:2px;padding:calc(var(--fluent-space-md) - 1px)}.quiz-selection{display:flex;align-items:center;gap:var(--fluent-space-sm);margin-bottom:var(--fluent-space-xs)}.quiz-selection input[type=checkbox]{cursor:pointer}.quiz-selection label{flex:1;cursor:pointer;font-size:var(--fluent-font-size-300)}.quiz-selection select{width:100px;padding:4px var(--fluent-space-sm);font-size:var(--fluent-font-size-200);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md)}@media(max-width:1024px){.cards-container{grid-template-columns:1fr}}@media(max-width:768px){.teacher-sidebar{width:80px}.teacher-sidebar .username,.teacher-sidebar .signout-btn .text{display:none}.cards-container{grid-template-columns:1fr}.dashboard-header h1{font-size:var(--fluent-font-size-600)}}.expanded-card-overlay{display:flex;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:9999;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.expanded-card-content{background:var(--fluent-surface-primary);max-width:90vw;max-height:90vh;min-height:400px;min-width:800px;overflow:auto;padding:var(--fluent-space-2xl);border-radius:var(--fluent-radius-xl);position:relative;box-shadow:var(--fluent-shadow-16);animation:slideUp .3s var(--fluent-curve-easy-ease)}.expanded-card-content::-webkit-scrollbar{width:12px;height:12px}.expanded-card-content::-webkit-scrollbar-track{background:var(--fluent-neutral-background-2)}.expanded-card-content::-webkit-scrollbar-thumb{background:var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md)}.expanded-card-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;background:var(--fluent-danger);color:#fff;border-radius:var(--fluent-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;z-index:10;transition:all var(--fluent-duration-fast)}.expanded-card-close:hover{background:#b02e31;transform:scale(1.1)}.dashboard-card.expanded{max-height:none;min-height:auto;box-shadow:none;border:none}.dashboard-card.expanded .card-body{max-height:70vh}.expanded-card-content table th,.expanded-card-content table td{display:table-cell!important}html:has(.upload-container){height:100%}body:has(.upload-container){background:linear-gradient(135deg,#667eea,#764ba2)!important;min-height:100%;display:flex!important;align-items:center!important;justify-content:center!important;padding:var(--fluent-space-2xl)!important;margin:0!important}#root:has(.upload-container){width:100%;display:flex;align-items:center;justify-content:center;min-height:100vh}.upload-container{width:100%;max-width:1200px;background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);box-shadow:var(--fluent-shadow-16);overflow:hidden;animation:slide-in .4s var(--fluent-curve-easy-ease)}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-header{padding:var(--fluent-space-3xl);background:var(--fluent-neutral-background-2);border-bottom:1px solid var(--fluent-neutral-stroke-2);text-align:center}.upload-header h1{font-size:var(--fluent-font-size-700);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.upload-header p{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-3);margin:0}.iframe-container{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;background:var(--fluent-neutral-background-2)}.iframe-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.back-button{position:fixed;top:var(--fluent-space-2xl);left:var(--fluent-space-2xl);z-index:100;box-shadow:var(--fluent-shadow-8)}@media(max-width:768px){body:has(.upload-container){padding:var(--fluent-space-lg)!important}.upload-container{max-width:100%}.upload-header h1{font-size:var(--fluent-font-size-500)}.back-button{top:var(--fluent-space-lg);left:var(--fluent-space-lg)}}body:has(.quiz-page){background:linear-gradient(135deg,#667eea,#764ba2)!important;min-height:100vh!important;margin:0!important;padding:var(--fluent-space-2xl)!important}#root:has(.quiz-page){min-height:100vh}.quiz-page{min-height:100vh}.quiz-container{width:600px;max-width:800px;margin:0 auto}.quiz-header{text-align:center;color:#fff;margin-bottom:var(--fluent-space-2xl)}.quiz-header h1{font-size:var(--fluent-font-size-800);font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}#timerDisplay{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-lg);text-align:center;font-size:var(--fluent-font-size-500);font-weight:600;color:var(--fluent-brand-primary);margin-bottom:var(--fluent-space-lg);box-shadow:var(--fluent-shadow-4)}.control-buttons{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-lg);margin-bottom:var(--fluent-space-lg);display:flex;align-items:center;justify-content:center;gap:var(--fluent-space-md);flex-wrap:wrap;box-shadow:var(--fluent-shadow-4)}.control-buttons label{font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-2)}.control-buttons select{font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);padding:var(--fluent-space-sm) var(--fluent-space-md);border:1px solid var(--fluent-neutral-stroke-1);border-radius:var(--fluent-radius-md);background:var(--fluent-neutral-background-1);outline:none}.question-card{background:var(--fluent-surface-primary);border:1px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-2xl);margin-bottom:var(--fluent-space-lg);box-shadow:var(--fluent-shadow-4);transition:all var(--fluent-duration-normal)}.question-card:hover{box-shadow:var(--fluent-shadow-8)}.question-number{font-size:var(--fluent-font-size-200);font-weight:600;color:var(--fluent-brand-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--fluent-space-xs)}.question-text{font-size:var(--fluent-font-size-400);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-lg)}.choices{display:flex;flex-direction:column;gap:var(--fluent-space-sm)}.choice-option{display:flex;align-items:center;padding:var(--fluent-space-md);border:2px solid var(--fluent-neutral-stroke-2);border-radius:var(--fluent-radius-md);cursor:pointer;transition:all var(--fluent-duration-fast)}.choice-option:hover{background:var(--fluent-neutral-background-2);border-color:var(--fluent-brand-primary)}.choice-option.selected{background:var(--fluent-brand-background-1);border-color:var(--fluent-brand-primary)}.choice-option input[type=radio]{margin-right:var(--fluent-space-md);cursor:pointer}.choice-option label{flex:1;cursor:pointer;color:var(--fluent-neutral-foreground-1)}.submit-btn{width:100%;max-width:300px;margin:var(--fluent-space-2xl) auto 0;display:block;padding:var(--fluent-space-md) var(--fluent-space-lg);background:var(--fluent-success);color:#fff;border:none;border-radius:var(--fluent-radius-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);font-weight:600;cursor:pointer;transition:all var(--fluent-duration-fast)}.submit-btn:hover:not(:disabled){background:#0d6b0d}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.fluent-btn{padding:var(--fluent-space-sm) var(--fluent-space-lg);background:var(--fluent-brand-primary);color:#fff;border:none;border-radius:var(--fluent-radius-md);font-family:var(--fluent-font-family);font-size:var(--fluent-font-size-300);font-weight:600;cursor:pointer;transition:all var(--fluent-duration-fast)}.fluent-btn:hover:not(:disabled){background:var(--fluent-brand-primary-hover)}.fluent-btn:disabled{opacity:.5;cursor:not-allowed}.fluent-btn-subtle{background:var(--fluent-neutral-background-3);color:var(--fluent-neutral-foreground-1)}.warning-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000f2;z-index:10000;display:none;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.warning-overlay.active{display:flex}.warning-content{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);padding:var(--fluent-space-3xl);max-width:500px;text-align:center;box-shadow:var(--fluent-shadow-16)}.warning-content h2{color:var(--fluent-danger);font-size:var(--fluent-font-size-600);margin:0 0 var(--fluent-space-lg)}.warning-content p{color:var(--fluent-neutral-foreground-2);font-size:var(--fluent-font-size-300);margin:0}.results-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--fluent-overlay-background);z-index:9999;display:none;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;padding:var(--fluent-space-2xl)}.results-modal.active{display:flex}.results-content{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-xl);padding:var(--fluent-space-3xl);max-width:800px;width:100%;box-shadow:var(--fluent-shadow-16);max-height:90vh;overflow-y:auto;animation:slideUp .3s var(--fluent-curve-easy-ease)}@keyframes slideUp{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.results-header{text-align:center;margin-bottom:var(--fluent-space-2xl)}.results-header h2{font-size:var(--fluent-font-size-700);font-weight:700;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-md)}.score-display{font-size:var(--fluent-font-size-800);font-weight:700;color:var(--fluent-brand-primary);margin:var(--fluent-space-lg) 0}.score-message{font-size:var(--fluent-font-size-400);color:var(--fluent-neutral-foreground-2);margin:0 0 var(--fluent-space-2xl)}.detailed-results{margin-bottom:var(--fluent-space-2xl)}.result-item{background:var(--fluent-neutral-background-2);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-lg);margin-bottom:var(--fluent-space-md);border-left:4px solid}.result-item.correct{border-left-color:var(--fluent-success);background:#dff6dd}.result-item.incorrect{border-left-color:var(--fluent-danger);background:#fde7e9}.result-item h5{font-size:var(--fluent-font-size-300);font-weight:600;color:var(--fluent-neutral-foreground-1);margin:0 0 var(--fluent-space-xs)}.result-item p{font-size:var(--fluent-font-size-300);color:var(--fluent-neutral-foreground-2);margin:var(--fluent-space-xs) 0}.result-item strong{color:var(--fluent-neutral-foreground-1)}.results-actions{display:flex;gap:var(--fluent-space-md);justify-content:center}.toast-container{position:fixed;top:var(--fluent-space-2xl);right:var(--fluent-space-2xl);z-index:10001;display:flex;flex-direction:column;gap:var(--fluent-space-sm)}.toast{background:var(--fluent-surface-primary);border-radius:var(--fluent-radius-lg);padding:var(--fluent-space-lg);box-shadow:var(--fluent-shadow-8);min-width:300px;font-size:var(--fluent-font-size-300);font-weight:600;opacity:0;transform:scale(.95);transition:all .3s var(--fluent-curve-easy-ease)}.toast.success{background:#dff6dd;color:var(--fluent-success);border:1px solid var(--fluent-success)}.toast.danger{background:#fde7e9;color:var(--fluent-danger);border:1px solid var(--fluent-danger)}.error-container{text-align:center;color:#fff;padding:var(--fluent-space-3xl)}.error-container h2{font-size:var(--fluent-font-size-700);margin:0 0 var(--fluent-space-lg)}.error-container p{font-size:var(--fluent-font-size-400);margin:0 0 var(--fluent-space-2xl)}@media(max-width:768px){.quiz-container{padding:var(--fluent-space-md)}.quiz-header h1{font-size:var(--fluent-font-size-600)}.results-content{padding:var(--fluent-space-lg)}.control-buttons{flex-direction:column}}
