@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";:root{--color-primary: #0A2E5D;--color-accent: #D86532;--color-bg: #F8FAFC;--color-card: #FFFFFF;--color-card-hover: #F1F5F9;--color-border: #E2E8F0;--color-text-primary: #1E293B;--color-text-secondary: #475569;--color-text-inverse: #FFFFFF;--color-success: #16A34A;--color-warning: #F59E0B;--color-error: #DC2626;--color-success-bg: #DCFCE7;--color-warning-bg: #FEF3C7;--color-error-bg: #FEE2E2;--font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-h1: clamp(1.75rem, 2vw + 1rem, 2.25rem);--font-size-h2: clamp(1.25rem, 1.5vw + .6rem, 1.75rem);--font-size-h3: clamp(1.125rem, 1.2vw + .4rem, 1.5rem);--font-size-body: clamp(.95rem, .8vw + .4rem, 1rem);--font-size-primary-text: clamp(1rem, 1vw + .4rem, 1.125rem);--font-size-secondary-text: clamp(.875rem, .6vw + .3rem, .95rem);--font-size-label: clamp(.75rem, .5vw + .3rem, .875rem);--font-size-table: clamp(.85rem, .6vw + .35rem, .95rem);--font-size-button: clamp(.875rem, .6vw + .35rem, 1rem);--font-size-caption: clamp(.75rem, .5vw + .3rem, .85rem);--font-size-tiny: clamp(.65rem, .4vw + .25rem, .75rem);--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-loose: 1.8;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-card: 0 2px 6px rgba(0, 0, 0, .05)}.teacher-login-container{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;position:relative;font-family:var(--font-family)}.teacher-login-overlay{position:absolute;inset:0;background:#0a2e5d8c;-webkit-backdrop-filter:brightness(.8);backdrop-filter:brightness(.8);z-index:0}.teacher-login-card{position:relative;z-index:1;width:100%;max-width:400px;padding:2.5rem;border-radius:var(--radius-lg);background:#ffffff26;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.25);box-shadow:0 8px 40px #00000040;text-align:center;color:var(--color-text-inverse);transition:transform .3s ease,box-shadow .3s ease}.teacher-login-logo{width:110px;margin-bottom:1rem}.teacher-login-title{font-size:var(--font-size-h2);color:var(--color-text-inverse);margin-bottom:.4rem;font-weight:700}.teacher-login-subtitle{font-size:var(--font-size-secondary-text);color:#ffffffd9;margin-bottom:2rem}.teacher-login-form{display:flex;flex-direction:column;gap:1rem}.input-group{text-align:left}.input-group label{display:block;font-size:var(--font-size-label);color:#ffffffe6;margin-bottom:.3rem}.input-group input{width:360px;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:var(--color-text-inverse);font-size:var(--font-size-body);transition:all .3s ease}.input-group input::placeholder{color:#ffffffb3}.input-group input:focus{border-color:var(--color-accent);background:#ffffff40;outline:none}.password-wrapper{position:relative;display:flex;align-items:center}.toggle-password{position:absolute;right:.9rem;background:none;border:none;color:#ffffffbf;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.toggle-password:hover{color:var(--color-accent)}.login-options{text-align:right;margin-top:.25rem}.forgot-password{background:none;border:none;color:var(--color-accent);font-size:var(--font-size-tiny);cursor:pointer;text-decoration:underline;transition:color .2s ease}.forgot-password:hover{color:var(--color-text-inverse)}.teacher-login-button{width:100%;margin-top:1.5rem;padding:.9rem;border:none;border-radius:var(--radius-md);font-size:var(--font-size-button);font-weight:600;cursor:pointer;background-color:var(--color-accent);color:var(--color-text-inverse);box-shadow:0 4px 15px #d865324d;transition:all .3s ease}.teacher-login-button:hover:not(:disabled){background-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 6px 18px #0a2e5d66}.teacher-login-button:disabled{background:#ffffff4d;color:#ffffffb3;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:480px){.teacher-login-card{padding:1.75rem;width:90%}.teacher-login-title{font-size:var(--font-size-h3)}.teacher-login-subtitle{font-size:var(--font-size-label)}.teacher-login-button{padding:.75rem}}html,body{margin:0;padding:0;overflow-x:hidden}: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)}}.sidebar{position:fixed;top:0;left:0;height:100vh;width:240px;background-color:var(--color-card);border-right:1px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;z-index:100;transition:all .3s ease;font-family:var(--font-family)}.sidebar.sidebar-closed{width:80px}.sidebar-header{padding:20px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--color-border)}.sidebar-logo{width:160px;height:auto;object-fit:contain}.sidebar-nav{flex:1;display:flex;flex-direction:column;padding:20px 12px;overflow-y:auto;gap:6px}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-md);color:var(--color-primary);font-weight:500;font-size:var(--font-size-body);text-decoration:none;transition:all .25s ease;background-color:transparent;box-shadow:none;border:1px solid transparent}.nav-item:hover{color:var(--color-text-primary);background-color:var(--color-card-hover);box-shadow:0 2px 6px #0000000f;transform:translate(2px)}.nav-item.active{background-color:var(--color-bg);border:1px solid var(--color-border);box-shadow:0 2px 6px #00000014;color:var(--color-text-primary);font-weight:600;transform:translate(2px)}.nav-icon{display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:color .2s ease,transform .2s ease;flex-shrink:0}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{color:var(--color-text-primary);transform:scale(1.05)}.nav-label{color:var(--color-primary);transition:color .2s ease;white-space:nowrap}.sidebar-closed .nav-label{display:none}.sidebar-closed .nav-item{justify-content:center;padding:12px}.sidebar-closed .sidebar-logo{display:none}.sidebar-toggle{position:absolute;top:28px;right:-14px;background:var(--color-accent);color:var(--color-text-inverse);border:none;border-radius:50%;padding:8px;cursor:pointer;box-shadow:0 4px 8px #d8653266;transition:all .2s ease;z-index:10}.sidebar-toggle:hover{transform:scale(1.1);box-shadow:0 6px 12px #d8653280}@media(max-width:768px){.sidebar{left:-100%;transition:left .3s ease;width:260px}.sidebar.mobile-open{left:0}.sidebar-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99}.mobile-close-btn{position:absolute;top:18px;right:18px;background:var(--color-card-hover);border:1px solid var(--color-border);color:var(--color-primary);border-radius:var(--radius-sm);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-close-btn:hover{background:var(--color-bg)}.sidebar-toggle.desktop-only{display:none}}@media(min-width:769px){.mobile-close-btn{display:none}}.header{position:fixed;top:0;left:260px;right:0;height:64px;background-color:var(--color-card);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:90;transition:left .3s ease;font-family:var(--font-family)}.header-left .header-title{color:var(--color-primary);font-size:var(--font-size-h3);font-weight:600;margin:0}.header-right{display:flex;align-items:center;gap:16px}.language-switcher{position:relative;display:flex;align-items:center;gap:6px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 10px;color:var(--color-primary)}.lang-select{background:transparent;border:none;color:var(--color-primary);font-size:var(--font-size-label);outline:none;cursor:pointer;font-weight:500}.lang-select option{color:var(--color-text-primary)}.globe-icon{color:var(--color-primary)}.notif-btn{background:var(--color-bg);border:1px solid var(--color-border);border-radius:50%;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);cursor:pointer;transition:all .2s ease}.notif-btn:hover{background:var(--color-card-hover);color:var(--color-text-primary);box-shadow:0 2px 6px #00000014}.user-profile{display:flex;align-items:center;gap:10px;background:var(--color-bg);padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.user-profile:hover{background:var(--color-card-hover);box-shadow:0 2px 6px #0000000f}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-weight:600;font-size:var(--font-size-body);color:var(--color-primary)}.user-role{font-size:var(--font-size-caption);color:var(--color-text-secondary)}.menu-btn{display:none;background:none;border:none;color:var(--color-primary);cursor:pointer;margin-right:12px}.header.collapsed{left:80px}@media(max-width:768px){.menu-btn{display:inline-flex;align-items:center;justify-content:center}}@media(max-width:768px){.header{left:0;padding:0 16px}.header-title{font-size:1rem}.user-info{display:none}}.lang-btn{display:flex;align-items:center;gap:6px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 10px;color:var(--color-primary);font-weight:500;font-size:var(--font-size-label);cursor:pointer;position:relative;transition:all .2s ease}.lang-btn:hover{background:var(--color-card-hover)}.flag-icon{font-size:18px;line-height:1}.lang-chevron{color:var(--color-text-secondary);margin-left:2px}.lang-dropdown{position:absolute;top:42px;right:0;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-card);display:flex;flex-direction:column;min-width:140px;z-index:100;overflow:hidden}.lang-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:none;color:var(--color-primary);font-size:var(--font-size-label);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.lang-option:hover{background:var(--color-card-hover);color:var(--color-text-primary)}.lang-option.active{background:var(--color-bg);font-weight:600;color:var(--color-text-primary)}.dashboard-container{display:flex;height:100vh;width:100%;background-color:var(--color-bg);overflow:hidden}.dashboard-content{flex:1;margin-left:240px;margin-top:64px;height:calc(100vh - 64px);overflow-y:auto;overflow-x:hidden;transition:margin-left .3s ease;padding:24px}.dashboard-content.sidebar-collapsed{margin-left:80px}.page-wrapper{min-height:calc(100vh - 120px);background-color:var(--color-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card)}@media(max-width:768px){.dashboard-content{margin-left:0;margin-top:64px;height:calc(100vh - 64px)}.page-wrapper{border-radius:0;box-shadow:none}}.courses-container{font-family:var(--font-family);background-color:var(--color-bg);min-height:100vh;padding:2.5rem;color:var(--color-text-primary);transition:background-color .3s ease;max-width:1400px;margin:0 auto}.courses-header{margin-bottom:2rem}.courses-title{font-size:var(--font-size-h2);font-weight:700;color:var(--color-text-primary);margin-bottom:1.5rem;margin-top:0%;letter-spacing:-.02em}.courses-tabs{display:flex;gap:.75rem;flex-wrap:wrap}.tab-button{padding:.625rem 1.5rem;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background-color:var(--color-card);color:var(--color-text-primary);font-size:var(--font-size-button);font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.tab-button:hover{background-color:var(--color-card-hover);border-color:var(--color-accent);transform:translateY(-1px)}.tab-button.active{background-color:var(--color-accent);color:var(--color-text-inverse);border:1.5px solid var(--color-accent);box-shadow:0 2px 8px #0000001a}.courses-loading,.no-courses-text{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-primary-text);padding:4rem 0}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem}.course-card{background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease;border:1px solid transparent}.course-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--color-border)}.courses-banner{height:120px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.courses-banner:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);opacity:.5}.courses-banner-text{color:var(--color-text-inverse);font-size:2.5rem;font-weight:700;letter-spacing:.05em;position:relative;z-index:1}.course-content{padding:1.25rem 1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.course-level{display:inline-block;padding:.3rem .85rem;border-radius:var(--radius-sm);font-size:var(--font-size-label);font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.03em;width:fit-content}.course-level.beginner{background-color:var(--color-success-bg);color:var(--color-success)}.course-level.intermediate{background-color:var(--color-warning-bg);color:var(--color-warning)}.course-level.master{background-color:var(--color-error-bg);color:var(--color-error)}.course-name{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:.25rem 0 .5rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.course-category{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin-bottom:.75rem;margin-top:0%;font-weight:500}.progress-bar{height:8px;border-radius:var(--radius-sm);background-color:var(--color-border);overflow:hidden;margin-top:.5rem;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-primary) 100%);transition:width .4s ease;border-radius:var(--radius-sm);position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{font-size:var(--font-size-tiny);color:var(--color-text-secondary);margin-top:0%;font-weight:500}.course-dates{font-size:var(--font-size-caption);color:var(--color-text-secondary);margin:0%;padding-top:.75rem;border-top:1px solid var(--color-border);font-weight:500;display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.courses-container{padding:1.5rem}.courses-grid{grid-template-columns:1fr;gap:1.25rem}.courses-title{font-size:1.75rem}}@media(max-width:480px){.tab-button{padding:.5rem 1rem;font-size:.875rem}.courses-banner{height:120px}.courses-banner-text{font-size:2rem}}.course-details-container{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-primary);min-height:100vh;display:flex;flex-direction:column}.course-back-nav{display:flex;align-items:center;gap:.75rem;padding-bottom:1.5rem;background-color:var(--color-card);border-bottom:1px solid var(--color-border);z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.back-btn{padding:.625rem 1.25rem;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background-color:var(--color-bg);color:var(--color-text-primary);cursor:pointer}.course-header{display:flex;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;margin:1.5rem 0;background:#fff}.header-left{flex:1;min-width:300px}.course-title{font-size:2.2rem;font-weight:700;color:var(--color-primary);margin-bottom:.75rem;letter-spacing:-.02em;line-height:1.2}.course-meta{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.meta-label{font-weight:600;color:var(--color-text-primary)}.header-right{display:flex;align-items:center}.date-pill{background-color:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1.25rem;font-size:var(--font-size-label);color:var(--color-text-secondary);box-shadow:0 2px 4px #0000000a;display:flex;align-items:center;gap:.5rem;font-weight:500}.course-tabs{display:flex;gap:.5rem;padding:0 2.5rem 1rem;border-bottom:2px solid var(--color-border);background-color:var(--color-card);position:sticky;top:73px;z-index:9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tab-btn{padding:.75rem 1.75rem;border:none;border-radius:var(--radius-md);background-color:transparent;font-size:var(--font-size-button);color:var(--color-text-secondary);cursor:pointer;transition:all .25s ease;font-weight:500;position:relative}.tab-btn:hover{background-color:var(--color-card-hover);color:var(--color-text-primary)}.tab-btn.active{background-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 2px 8px #0000001a}.course-tab-content{display:flex;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;margin:1.5rem 0;background:#fff}.fade-in{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.fade-out{opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}.tab-section{animation:fadeIn .3s ease}.section-header{display:flex;gap:1rem;align-items:center;margin-bottom:2rem;padding-bottom:1rem}.tab-section h2{font-size:var(--font-size-h2);font-weight:700;color:var(--color-primary);margin:0;letter-spacing:-.02em}.group-count,.resource-count,.homework-count{background-color:var(--color-bg);padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:var(--font-size-label);font-weight:600;color:var(--color-text-secondary);border:1px solid var(--color-border)}.course-description{font-size:var(--font-size-primary-text);line-height:1.7;color:var(--color-text-secondary);margin-bottom:3rem}.teacher-section{margin-top:2rem}.teacher-section h3{font-size:var(--font-size-h3);margin-bottom:1.5rem;color:var(--color-primary);font-weight:600}.teacher-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.teacher-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background-color:var(--color-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all .2s ease}.teacher-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:var(--color-accent)}.teacher-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;flex-shrink:0}.teacher-info{flex:1}.teacher-name{font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem;font-size:var(--font-size-primary-text)}.teacher-email{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin:0}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.group-card{background-color:var(--color-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;transition:all .25s ease;box-shadow:0 2px 4px #0000000a}.group-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:var(--color-accent)}.group-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.group-avatar{width:52px;height:52px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;flex-shrink:0}.group-title-section{flex:1}.group-name{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-id{font-size:var(--font-size-caption);color:var(--color-text-secondary);font-family:monospace}.mode-badge{padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:var(--font-size-label);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.mode-badge.online{background-color:var(--color-success-bg);color:var(--color-success)}.mode-badge.offline{background-color:var(--color-warning-bg);color:var(--color-warning)}.group-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background-color:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.stat-label{font-size:var(--font-size-tiny);color:var(--color-text-secondary);font-weight:600;letter-spacing:.05em;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.card-actions{display:flex;gap:.75rem}.action-btn{flex:1;padding:.75rem 1.25rem;border-radius:var(--radius-md);border:none;font-size:var(--font-size-button);font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn-primary{background-color:transparent;color:var(--color-text-primary);border:1.5px solid var(--color-border)}.action-btn-primary:hover{background-color:var(--color-card-hover);border-color:var(--color-accent);color:var(--color-accent)}.action-btn-secondary{background-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 2px 4px #0000001a}.action-btn-secondary:hover{background-color:var(--color-accent);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.empty-state{color:var(--color-text-secondary);font-style:italic;margin:0}.course-details-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;gap:1rem}.course-details-loading p{font-size:var(--font-size-primary-text);color:var(--color-text-secondary)}.course-details-error{text-align:center;padding:5rem 2rem;font-size:var(--font-size-primary-text);color:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.course-back-nav,.course-tabs{padding:1rem 1.5rem}.course-header{padding:2rem 1.5rem;flex-direction:column}.course-title{font-size:1.5rem}.course-tab-content{padding:1.5rem}.groups-grid,.teacher-grid{grid-template-columns:1fr}.group-stats{grid-template-columns:repeat(3,1fr)}.homework-header{flex-direction:column;align-items:flex-start}}.profile-container{max-width:1000px;margin:0 auto;padding:24px;background-color:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-family)}.profile-container *,.profile-container *:before,.profile-container *:after{box-sizing:border-box}.profile-heading{font-size:var(--font-size-h2);font-weight:600;color:var(--color-primary);margin-bottom:24px;text-align:left}.profile-form.two-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:24px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:var(--color-text-secondary);margin-bottom:6px;font-size:var(--font-size-label)}.form-group input,.form-group select{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-body);background:var(--color-bg);color:var(--color-text-primary);transition:border-color .2s ease,background-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-accent);background-color:var(--color-card-hover)}.form-group input[disabled],.form-group select[disabled]{background:#f1f5f9;color:var(--color-text-secondary);cursor:not-allowed}.full-width{grid-column:span 2;display:flex;justify-content:flex-end;margin-top:12px}.edit-profile-button,.save-profile-button{background-color:var(--color-accent);color:var(--color-text-inverse);padding:10px 20px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:600;font-size:var(--font-size-button);transition:all .25s ease;box-shadow:var(--shadow-card)}.edit-profile-button:hover,.save-profile-button:hover{background-color:#b24f26;transform:translateY(-1px)}.save-profile-button{background-color:var(--color-primary)}.save-profile-button:hover{background-color:#072549}.profile-loading,.profile-error{text-align:center;font-size:var(--font-size-body);color:var(--color-text-secondary);padding:40px 0}@media(max-width:768px){.profile-container{padding:16px}.profile-form.two-columns{grid-template-columns:1fr;gap:16px;padding:16px}.full-width{grid-column:span 1;justify-content:center}.profile-heading{font-size:var(--font-size-h3);text-align:center}}@media(max-width:480px){.form-group input,.form-group select{font-size:var(--font-size-secondary-text);padding:8px 10px}.edit-profile-button,.save-profile-button{width:100%;padding:12px;font-size:var(--font-size-body)}}.group-details-container{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-primary);min-height:100vh;padding:0}.group-header-section{background-color:var(--color-card);border-bottom:1px solid var(--color-border);padding:1.5rem 2.5rem;display:flex;align-items:center;gap:1.5rem}.back-to-groups-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1rem;border-radius:var(--radius-md);border:none;background-color:var(--color-text-secondary);color:var(--color-text-inverse);font-size:var(--font-size-button);font-weight:500;cursor:pointer;transition:all .2s ease}.back-to-groups-btn:hover{background-color:var(--color-text-primary);transform:translate(-2px)}.group-title-info{display:flex;flex-direction:column;gap:.5rem}.group-page-title{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.02em}.group-meta-info{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin:0}.group-tabs{display:flex;gap:0;background-color:var(--color-card);border-bottom:1px solid var(--color-border);padding:1rem 2.5rem;overflow-x:auto;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.group-tab-btn{padding:.75rem 1.75rem;border:none;background-color:transparent;border-radius:var(--radius-md);font-size:var(--font-size-button);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;font-weight:500;border-bottom:3px solid transparent;white-space:nowrap;position:relative}.group-tab-btn:hover{color:var(--color-text-primary);background-color:var(--color-card-hover)}.group-tab-btn.active{color:var(--color-text-inverse);background-color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.group-tab-content{padding:2.5rem;max-width:1400px;margin:0 auto;animation:fadeIn .3s ease}.tab-section{background-color:var(--color-card);border-radius:var(--radius-lg);padding:2rem;box-shadow:0 1px 3px #0000000d}.section-header-with-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.section-title{font-size:var(--font-size-h2);font-weight:700;color:var(--color-text-primary);margin:0;display:flex;align-items:center;gap:.75rem}.count-badge{font-size:var(--font-size-secondary-text);font-weight:500;color:var(--color-text-secondary)}.add-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);border:none;background-color:#10b981;color:#fff;font-size:var(--font-size-button);font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #10b98133}.add-btn:hover{background-color:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.student-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background-color:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all .2s ease;cursor:pointer}.student-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:var(--color-accent)}.student-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;flex-shrink:0;text-transform:uppercase}.student-info{flex:1;min-width:0}.student-name{font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem;font-size:var(--font-size-primary-text)}.student-email{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center}.empty-icon{color:#9ca3af;margin-bottom:1.5rem;opacity:.6}.empty-state-section h3{font-size:var(--font-size-h2);font-weight:700;color:var(--color-text-primary);margin:0 0 .75rem}.empty-state-section p{font-size:var(--font-size-primary-text);color:var(--color-text-secondary);margin:0 0 2rem;max-width:400px}.add-first-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;border-radius:var(--radius-md);border:none;background-color:#10b981;color:#fff;font-size:var(--font-size-button);font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #10b98140}.add-first-btn:hover{background-color:#059669;transform:translateY(-2px);box-shadow:0 6px 16px #10b98159}.subjects-list{display:flex;flex-direction:column;gap:1rem}.subject-item{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background-color:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all .2s ease;cursor:pointer}.subject-item:hover{transform:translate(4px);box-shadow:0 4px 12px #00000014;border-color:var(--color-accent)}.subject-icon{width:56px;height:56px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;flex-shrink:0;text-transform:uppercase}.subject-details{flex:1}.subject-details h3{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);margin:0 0 .5rem}.subject-details p{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin:0}.group-details-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;gap:1rem}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.group-details-loading p{font-size:var(--font-size-primary-text);color:var(--color-text-secondary)}.group-details-error{text-align:center;padding:5rem 2rem;font-size:var(--font-size-primary-text);color:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.group-header-section,.group-tabs,.group-tab-content{padding-left:1.5rem;padding-right:1.5rem}.group-page-title{font-size:1.5rem}.students-grid{grid-template-columns:1fr}.section-header-with-action{flex-direction:column;align-items:flex-start}.add-btn{width:100%;justify-content:center}.group-tabs{padding:0 1rem}.group-tab-btn{padding:.875rem 1rem;font-size:.875rem}}.timetable-wrapper{width:100%;overflow-x:auto;border-radius:8px;box-sizing:border-box;box-shadow:0 2px 4px #02020233}.timetable-table{width:100%;border-collapse:collapse;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;background:#fff;border-radius:8px;overflow:hidden}.timetable-table thead{background:#022b5f;color:#fff}.timetable-table th{padding:12px 8px;text-align:left;font-weight:600;border-right:1px solid rgba(255,255,255,.08);white-space:nowrap;text-align:center}.timetable-table th:last-child{border-right:none}.time-col{width:110px}.day-col{text-align:center}.day-name{font-size:13px;font-weight:600}.timetable-table tbody tr:nth-child(2n){background:#f9fbff}.timetable-table td{border-top:1px solid #e4e8f0;border-right:1px solid #e4e8f0;padding:8px;vertical-align:middle;text-align:center;height:2rem;max-height:2rem;overflow:hidden}.timetable-table td:last-child{border-right:none}.time-cell{font-weight:500;font-size:12px;color:#4b5563;background:#f3f4f6;position:sticky;left:0;z-index:2}.session-cell.empty{background:#f7fafc}.session-cell.break{background:#ffe4e4;color:#b91c1c;text-align:center}.session-cell.break .break-title{font-size:12px;font-weight:600}.session-cell.break.lunch{background:#ffe6d9}.session-cell.break.short{background:#ffe4e4}.session-cell.session{background:#eef4ff;border-radius:4px}.session-cell.session .session-title{font-size:12px;font-weight:600;color:#0f172a;margin-bottom:2px}.session-cell.session .session-meta{font-size:11px;color:#6b7280}.session-cell.session .session-topic{font-size:11px;color:#4b5563;margin-top:2px}@media(max-width:768px){.timetable-wrapper{padding:8px}.timetable-table th,.timetable-table td{padding:6px}.time-col{width:90px}}.homework-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.homework-card{background-color:var(--color-bg);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0f172a14;transition:all .18s ease;display:flex;flex-direction:column;justify-content:space-between;gap:.75rem}.homework-card:hover{border-color:var(--color-accent);box-shadow:0 6px 18px #0f172a29;transform:translateY(-2px)}.homework-card-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.hw-title-block{display:flex;flex-direction:column;gap:.15rem}.hw-id{font-size:var(--font-size-tiny);font-weight:600;color:var(--color-text-secondary);letter-spacing:.08em;text-transform:uppercase}.hw-title{margin:0;font-size:calc(var(--font-size-h3) * .9);font-weight:700;color:var(--color-text-primary);max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.hw-badges{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}.hw-type-badge,.hw-status-badge,.hw-grade-badge{padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.hw-type-badge{border:1px solid rgba(148,163,184,.7);color:var(--color-text-secondary);background-color:var(--color-card-hover)}.hw-type-exam{background-color:#ef444414;border-color:#ef4444b3;color:#b91c1c}.hw-type-quiz{background-color:#3b82f614;border-color:#3b82f6b3;color:#1d4ed8}.hw-type-assignment,.hw-type-homework{background-color:#10b98114;border-color:#10b981b3;color:#047857}.hw-status-badge{background-color:#94a3b814;border:1px solid rgba(148,163,184,.7);color:#4b5563}.hw-status-active{background-color:#10b98114;border-color:#10b981b3;color:#047857}.hw-status-closed{background-color:#f8717114;border-color:#f87171b3;color:#b91c1c}.hw-status-graded{background-color:#818cf81f;border-color:#818cf8b3;color:#4f46e5}.hw-grade-badge{background-color:#facc151a;border:1px solid rgba(234,179,8,.8);color:#92400e}.homework-desc{margin:0;font-size:var(--font-size-primary-text);color:var(--color-text-secondary)}.hw-meta-row{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:.5rem}.hw-meta-item{display:flex;flex-direction:column;gap:.15rem}.hw-meta-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.hw-meta-value{font-size:var(--font-size-secondary-text);font-weight:500;color:var(--color-text-primary)}@media(max-width:768px){.homework-grid{grid-template-columns:1fr}.homework-card{padding:1rem 1.1rem}}.hw-more-link{margin-top:.25rem;padding:0;border:none;background:transparent;color:var(--color-accent);font-size:var(--font-size-secondary-text);font-weight:500;cursor:pointer}.hw-more-link:hover{text-decoration:underline}.hw-attachments{flex:1 1 100%}.hw-attachments-list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.hw-attachment-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;color:var(--color-text-primary);background-color:var(--color-card-hover);border:1px solid var(--color-border);text-decoration:none}.hw-attachment-pill:hover{border-color:var(--color-accent);color:var(--color-accent)}.hw-card-actions{margin-top:.9rem;display:flex;justify-content:flex-end;gap:.5rem}.hw-action-btn{padding:.45rem .95rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-card-hover);font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease}.hw-action-btn:hover{background-color:var(--color-border);border-color:var(--color-accent)}.hw-view-btn{border-color:var(--color-accent);color:var(--color-accent)}.hw-view-btn:hover{background-color:#2563eb0f}.hw-edit-btn{background-color:var(--color-card-hover)}.hw-edit-btn:hover{background-color:var(--color-border)}.hw-modal-backdrop{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:40;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.hw-modal{width:100%;max-width:42rem;max-height:80vh;overflow:hidden;background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000059,0 0 0 1px #ffffff0d;padding:2rem 2rem 1.75rem;box-sizing:border-box;animation:slideUp .25s cubic-bezier(.16,1,.3,1)}.hw-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.hw-modal-header h3{font-size:var(--font-size-h2);font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.01em}.hw-modal-close{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;border-radius:var(--radius-md);transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.hw-modal-close:hover{color:var(--color-text-primary);background-color:var(--color-card-hover);transform:rotate(90deg)}.hw-form{display:flex;flex-direction:column;gap:1.25rem;margin-top:.5rem;overflow-y:auto;max-height:calc(85vh - 200px);padding-right:6px;scrollbar-width:thin}.hw-form::-webkit-scrollbar{width:6px}.hw-form::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:8px}.hw-form::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.hw-form-group{display:flex;flex-direction:column;gap:.5rem}.hw-form-group label{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary);letter-spacing:-.01em}.hw-form-group textarea{resize:vertical;min-height:90px;font-family:inherit;line-height:1.5}.hw-form-group input[type=text],.hw-form-group input[type=date],.hw-form-group textarea,.hw-form-group select{border-radius:var(--radius-md);border:1.5px solid var(--color-border);padding:.65rem .85rem;font-size:var(--font-size-primary-text);background-color:var(--color-bg);color:var(--color-text-primary);outline:none;transition:all .2s ease}.hw-form-group input[type=text]:hover,.hw-form-group input[type=date]:hover,.hw-form-group textarea:hover,.hw-form-group select:hover{border-color:var(--color-accent)}.hw-form-group input[type=text]:focus,.hw-form-group input[type=date]:focus,.hw-form-group textarea:focus,.hw-form-group select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb1a;background-color:var(--color-card)}.hw-form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:grayscale(.2);opacity:.85}.hw-form-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.hw-form-group input[type=file]{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);padding:.5rem 0;cursor:pointer}.hw-form-group input[type=file]::file-selector-button{padding:.5rem 1rem;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background-color:var(--color-bg);color:var(--color-text-primary);font-weight:500;cursor:pointer;transition:all .2s ease;margin-right:.75rem}.hw-form-group input[type=file]::file-selector-button:hover{background-color:var(--color-card-hover);border-color:var(--color-accent)}.hw-form-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-top:.25rem;padding:1rem;background-color:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.hw-checkbox{display:flex;align-items:center;gap:.65rem;font-size:var(--font-size-primary-text);font-weight:500;color:var(--color-text-primary);cursor:pointer}.hw-checkbox input{width:18px;height:18px;cursor:pointer;accent-color:#10b981}.hw-grade-select{display:flex;flex-direction:column;gap:.4rem}.hw-grade-select label{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary)}.hw-grade-select select{border-radius:var(--radius-md);border:1.5px solid var(--color-border);padding:.5rem .8rem;font-size:var(--font-size-primary-text);background-color:var(--color-card);color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;min-width:80px}.hw-grade-select select:hover{border-color:var(--color-accent)}.hw-grade-select select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb1a}.hw-modal-actions{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.75rem}.hw-btn-secondary,.hw-btn-primary{padding:.65rem 1.5rem;border-radius:var(--radius-md);font-size:var(--font-size-button);font-weight:600;border:none;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);letter-spacing:-.01em}.hw-btn-primary{background-color:#10b981;color:#fff;box-shadow:0 2px 8px #10b98140}.hw-btn-primary:hover{background-color:#059669;transform:translateY(-2px);box-shadow:0 6px 16px #10b98159}.hw-btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #10b98140}.hw-btn-secondary{background-color:var(--color-card-hover);color:var(--color-text-primary);border:1.5px solid var(--color-border)}.hw-btn-secondary:hover{background-color:var(--color-border);border-color:var(--color-text-secondary)}.hw-btn-secondary:active{transform:scale(.98)}.hw-btn-primary:disabled,.hw-btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;pointer-events:none}@media(max-width:640px){.hw-modal{margin:0 1rem;padding:1.5rem 1.5rem 1.25rem;max-width:calc(100% - 2rem)}.hw-modal-header{margin-bottom:1.25rem;padding-bottom:.85rem}.hw-form{gap:1rem}.hw-form-row{flex-direction:column;align-items:flex-start;gap:1rem;padding:.85rem}.hw-grade-select,.hw-grade-select select{width:100%}.hw-modal-actions{flex-direction:row;justify-content:flex-end;gap:.65rem;margin-top:1.25rem;padding-top:1rem}.hw-btn-secondary,.hw-btn-primary{padding:.6rem 1.25rem}}.submissions-container{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-primary);min-height:100vh}.submissions-header{background-color:var(--color-card);border-bottom:1px solid var(--color-border);padding:1.5rem 2.5rem;display:flex;align-items:center;gap:1.5rem}.submissions-title-info{display:flex;flex-direction:column;gap:.4rem}.submissions-page-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text-primary);letter-spacing:-.02em}.submissions-meta-info{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin:0}.submissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.submission-card{background-color:var(--color-bg);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);padding:1.25rem 1.5rem;box-shadow:0 1px 3px #0f172a14;transition:all .18s ease;display:flex;flex-direction:column;justify-content:space-between;gap:.75rem}.submission-card:hover{border-color:var(--color-accent);box-shadow:0 6px 18px #0f172a29;transform:translateY(-2px)}.submission-card-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.submission-title-block{display:flex;flex-direction:column;gap:.15rem}.submission-id{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-secondary);letter-spacing:.08em;text-transform:uppercase}.submission-student{margin:0;font-size:calc(var(--font-size-h3) * .9);font-weight:700;color:var(--color-text-primary)}.submission-email{margin:0;font-size:var(--font-size-secondary-text);color:var(--color-text-secondary)}.submission-badges{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}.submission-status-badge,.submission-score-badge{padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.submission-status-badge{background-color:#94a3b814;border:1px solid rgba(148,163,184,.7);color:#4b5563}.submission-status-submitted{background-color:#3b82f614;border-color:#3b82f6b3;color:#1d4ed8}.submission-status-graded{background-color:#10b98114;border-color:#10b981b3;color:#047857}.submission-status-late{background-color:#f973161a;border-color:#f97316cc;color:#c2410c}.submission-status-pending{background-color:#94a3b814;border-color:#94a3b8b3;color:#4b5563}.submission-score-badge{background-color:#facc151a;border:1px solid rgba(234,179,8,.8);color:#92400e}.submission-meta-row{display:flex;flex-wrap:wrap;gap:1.25rem;margin-top:.25rem}.submission-meta-item{display:flex;flex-direction:column;gap:.15rem}.submission-meta-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.submission-meta-value{font-size:var(--font-size-secondary-text);font-weight:500;color:var(--color-text-primary)}.submission-attachments{flex:1 1 100%}.submission-attachments-list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.submission-attachment-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;color:var(--color-text-primary);background-color:var(--color-card-hover);border:1px solid var(--color-border);text-decoration:none}.submission-attachment-pill:hover{border-color:var(--color-accent);color:var(--color-accent)}.submission-card-actions{margin-top:.85rem;display:flex;justify-content:flex-end;gap:.5rem}.submission-action-btn{padding:.45rem .95rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-card-hover);font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease}.submission-action-btn:hover{background-color:var(--color-border);border-color:var(--color-accent)}.submission-view-btn{border-color:var(--color-accent);color:var(--color-accent)}.submission-view-btn:hover{background-color:#2563eb0f}.submission-grade-btn{background-color:#10b981;border-color:#10b981;color:#fff;box-shadow:0 2px 8px #10b98140}.submission-grade-btn:hover{background-color:#059669;border-color:#059669;box-shadow:0 6px 16px #10b98159}.back-to-groups-btn{border:none;border-radius:var(--radius-md);padding:.5rem .9rem;background-color:var(--color-card-hover);color:var(--color-text-primary);font-size:var(--font-size-secondary-text);font-weight:500;cursor:pointer;transition:all .15s ease}.back-to-groups-btn:hover{background-color:var(--color-border)}@media(max-width:768px){.submissions-header{padding:1.1rem 1.25rem;flex-direction:column;align-items:flex-start;gap:.75rem}.submissions-grid{grid-template-columns:1fr}.submission-card{padding:1rem 1.15rem}.submission-card-header{flex-direction:column;align-items:flex-start;gap:.6rem}.submission-card-actions{justify-content:flex-start}}.ts-page{font-family:var(--font-family);min-height:100vh;background-color:var(--color-bg);display:flex;flex-direction:column;gap:1.25rem}.ts-header{background:linear-gradient(90deg,#7f1d1d,#b45309);border-radius:1rem;padding:2rem;color:#f9fafb;display:flex;align-items:center;justify-content:space-between}.ts-header-title{margin:0;font-size:var(--font-size-h2);font-weight:700}.ts-header-subtitle{margin:.25rem 0 0;font-size:.9rem;opacity:.9}.ts-refresh-btn{border:none;border-radius:.6rem;padding:.55rem 1.3rem;background-color:var(--color-success);color:#fff;font-weight:600;font-size:var(--font-size-button);cursor:pointer;box-shadow:0 8px 18px #22c55e59;display:flex;align-items:center;gap:.4rem}.ts-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:1.25rem}.ts-groups-panel{background-color:var(--color-card);border-radius:1rem;padding:.9rem;border:1px solid var(--color-border);box-shadow:0 10px 30px #0f172a1f;display:flex;flex-direction:column;gap:.75rem}.ts-groups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.ts-groups-title{margin:0;font-size:var(--font-size-primary-text);font-weight:700}.ts-groups-count{padding:.3rem .7rem;border-radius:999px;font-size:.75rem;background-color:#e7c9ab;color:var(--color-text-primary)}.ts-groups-list{display:flex;flex-direction:column;gap:.4rem;max-height:calc(100vh - 260px);overflow-y:auto}.ts-group-item{width:100%;text-align:left;border-radius:.9rem;border:1px solid transparent;background-color:#f9fafb;padding:.6rem .7rem;cursor:pointer;transition:all .15s ease}.ts-group-item:hover{background-color:#eef2ff}.ts-group-item-active{border-color:var(--color-primary);background-color:#eef3ff;box-shadow:0 0 0 1px #2563eb40}.ts-group-name{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ts-group-course{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ts-main-panel{background-color:#fff;border-radius:1rem;padding:.9rem;border:1px solid var(--color-border);box-shadow:0 10px 30px #0f172a1f;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.ts-main-header{display:flex;justify-content:space-between;align-items:center}.ts-main-title{margin:0;font-size:var(--font-size-primary-text);font-weight:700}.ts-main-subtitle{margin:.25rem 0 0;font-size:.8rem;color:var(--color-text-secondary)}.ts-timetable-wrapper{margin-top:.5rem;border-radius:1rem;overflow:auto;border:1px solid var(--color-border)}.ts-timetable{width:100%;border-collapse:collapse;min-width:780px;font-size:.8rem}.ts-timetable thead{background-color:#0f172a;color:#f9fafb}.ts-timetable th,.ts-timetable td{padding:.6rem .4rem;text-align:center;border-right:1px solid rgba(148,163,184,.3)}.ts-timetable th:last-child,.ts-timetable td:last-child{border-right:none}.ts-time-col{width:120px;background-color:#0f172a}.ts-day-col{min-width:110px}.ts-day-name{font-weight:600}.ts-day-short{font-size:.7rem;opacity:.8}.ts-time-cell{background-color:#f9fafb;font-weight:600}.ts-session-cell{height:64px;background-color:#fff}.ts-session-filled{background-color:#eff6ff}.ts-session-subject{font-weight:600}.ts-session-teacher{font-size:.7rem;color:var(--color-text-secondary)}.ts-break-cell{background:linear-gradient(180deg,#fee2e2,#fecaca);position:relative}.ts-break-dot{width:10px;height:10px;border-radius:999px;background-color:#ef4444;margin:0 auto .25rem}.ts-break-title{font-size:.8rem;color:#b91c1c}.ts-main-empty{flex:1;display:flex;align-items:center;justify-content:center}.ts-muted{color:var(--color-text-secondary);font-size:.85rem}@media(max-width:960px){.ts-layout{grid-template-columns:1fr}}
