@import"https://fonts.googleapis.com/css2?family=Inter+Tight:ital,wght@0,100..900;1,100..900&display=swap";: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)}}.header{background-color:var(--color-card);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-card);position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:1rem 2rem;gap:2rem}.logo-container{display:flex;align-items:center;gap:.75rem;text-decoration:none}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-inverse);font-weight:600;font-size:var(--font-size-h3)}.logo{font-size:var(--font-size-h2);font-weight:700;color:var(--color-primary);margin:0;letter-spacing:-.02em}.lang-dropdown{position:relative;display:inline-block}.lang-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-size:var(--font-size-body);color:var(--color-text-secondary)}.lang-trigger:hover{background:var(--color-card-hover);border-color:var(--color-primary)}.current-flag{width:20px;height:15px;border-radius:var(--radius-sm)}.chevron{width:16px;height:16px;transition:transform .2s ease;opacity:.7}.lang-dropdown.open .chevron{transform:rotate(180deg)}.lang-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;min-width:140px;z-index:1001;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.lang-dropdown.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}.lang-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background-color .2s ease;border:none;background:none;width:100%;text-align:left;font-size:var(--font-size-body);color:var(--color-text-primary)}.lang-option:hover{background-color:var(--color-card-hover)}.lang-option:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.lang-option:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.lang-flag{width:20px;height:15px;border-radius:var(--radius-sm)}.lang-name{font-size:var(--font-size-body);color:var(--color-text-primary)}@media(max-width:768px){.header-content{padding:.875rem 1.5rem;gap:1rem}.logo{font-size:var(--font-size-h3)}.logo-icon{width:28px;height:28px;font-size:var(--font-size-body)}.lang-trigger{padding:.375rem .625rem;font-size:var(--font-size-secondary-text)}.lang-name{display:none}}@media(max-width:480px){.header-content{padding:.75rem 1rem}.logo{font-size:var(--font-size-h3)}.logo-text{display:none}}.login-container{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background-image:radial-gradient(circle at 25% 25%,rgba(10,46,93,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(216,101,50,.03) 0%,transparent 50%)}.login-box{background:var(--color-card);padding:3rem 2.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 20px #00000014,0 0 0 1px #00000005;width:100%;max-width:440px;border:1px solid var(--color-border)}.login-header{text-align:center;margin-bottom:2.5rem}.login-title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem;position:relative}.form-label{font-size:var(--font-size-label);font-weight:500;color:var(--color-text-primary);margin:0}.form-input{padding:.875rem 1rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-body);color:var(--color-text-primary);background:var(--color-card);transition:all .2s ease;font-family:var(--font-family);width:100%;box-sizing:border-box}.password-input-container{position:relative;display:flex;align-items:center}.password-toggle{position:absolute;right:1rem;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:color .2s ease;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--color-primary);background:var(--color-card-hover)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0a2e5d1a}.form-input::placeholder{color:var(--color-text-secondary);opacity:.6}.remember-forgot-container{display:flex;justify-content:space-between;align-items:center;margin:.5rem 0 1rem}.remember-me{display:flex;align-items:center;gap:.5rem;cursor:pointer}.remember-checkbox{width:18px;height:18px;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-card);cursor:pointer;position:relative;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.remember-checkbox.checked{background:var(--color-primary);border-color:var(--color-primary)}.remember-checkbox.checked:after{content:"✓";color:var(--color-text-inverse);font-size:var(--font-size-tiny);font-weight:700}.remember-label{font-size:var(--font-size-secondary-text);color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.remember-me:hover .remember-checkbox:not(.checked){border-color:var(--color-primary)}.forgot-password{margin:0}.forgot-link{color:var(--color-accent);text-decoration:none;font-size:var(--font-size-secondary-text);font-weight:500;transition:color .2s ease;background:none;border:none;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm)}.forgot-link:hover:not(:disabled){color:#c55a2d;text-decoration:underline}.forgot-link:disabled{opacity:.6;cursor:not-allowed}.login-button{background:var(--color-primary);color:var(--color-text-inverse);border:none;padding:1rem 2rem;border-radius:var(--radius-md);font-size:var(--font-size-button);font-weight:600;cursor:pointer;transition:all .2s ease;font-family:var(--font-family);width:100%}.login-button:hover:not(:disabled){background:#08305c;transform:translateY(-1px);box-shadow:0 4px 12px #0a2e5d33}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.error{background:var(--color-error-bg);color:var(--color-error);padding:.875rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-error);font-size:var(--font-size-secondary-text);margin:0;text-align:center}@media(max-width:768px){.login-container{padding:1rem}.login-box{padding:2.5rem 2rem;margin:1rem}.login-title{font-size:var(--font-size-h2)}.remember-forgot-container{flex-direction:column;align-items:flex-start;gap:1rem}.forgot-password{align-self:flex-end}}@media(max-width:480px){.login-box{padding:2rem 1.5rem}.login-title{font-size:var(--font-size-h3)}.remember-forgot-container{flex-direction:column;align-items:flex-start;gap:.75rem}}:root{--dashboard-bg: #f8fafc;--card-bg: #ffffff;--header-bg: #ffffff;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--accent-blue: #3b82f6;--accent-green: #10b981;--accent-orange: #f59e0b;--accent-red: #ef4444;--accent-cyan: #06b6d4;--accent-teal: #14b8a6;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}.modern-dashboard{min-height:100vh;background:var(--dashboard-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text-primary);padding:0;margin:0}.dashboard-header{background:var(--header-bg);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2}.dashboard-header-content{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;max-width:1600px;margin:0 auto}.dashboard-header-left h1{margin:0;font-size:1.875rem;font-weight:700;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-header-subtitle{margin:.5rem 0 0;font-size:.875rem;color:var(--text-secondary);font-weight:400}.header-actions{display:flex;gap:.75rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.125rem;border-radius:.5rem;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.action-btn:hover{background:var(--dashboard-bg);border-color:var(--accent-blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}.refresh-btn:hover{color:var(--accent-blue)}.export-btn:hover{color:var(--accent-green)}.dashboard-filters{padding:1rem 2rem;max-width:1600px;margin:0 auto;border-top:1px solid var(--border-color)}.filters-row{display:flex;gap:1rem}.filter-group{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.filter-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.modern-dropdown{position:relative;min-width:180px}.dropdown-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem;text-transform:uppercase;letter-spacing:.05em}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.625rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:var(--transition);font-size:.875rem;color:var(--text-primary)}.dropdown-trigger:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-sm)}.dropdown-text{font-weight:500}.dropdown-caret{transition:transform .2s ease;display:flex;align-items:center;color:var(--text-muted)}.dropdown-caret.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow-lg);max-height:320px;overflow:hidden;z-index:50;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);background:var(--dashboard-bg);font-size:.8125rem;font-weight:600;color:var(--text-primary)}.clear-btn{background:none;border:none;color:var(--accent-blue);cursor:pointer;font-size:.8125rem;font-weight:500;padding:0;transition:var(--transition)}.clear-btn:hover{text-decoration:underline}.dropdown-options{max-height:240px;overflow-y:auto;padding:.5rem}.dropdown-option{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;cursor:pointer;border-radius:.375rem;transition:var(--transition);font-size:.875rem}.dropdown-option:hover{background:var(--dashboard-bg)}.checkbox-wrapper{position:relative;display:flex;align-items:center}.checkbox-input{opacity:0;position:absolute;cursor:pointer}.checkbox-custom{width:18px;height:18px;border:2px solid var(--border-color);border-radius:.25rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.checkbox-input:checked~.checkbox-custom{background:var(--accent-blue);border-color:var(--accent-blue)}.checkbox-input:checked~.checkbox-custom:after{content:"";width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}.option-label{font-weight:500;color:var(--text-primary)}.dashboard-content{max-width:1600px;margin:0 auto;padding:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem}.modern-stat-card{position:relative;background:var(--card-bg);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;overflow:hidden;transition:var(--transition)}.modern-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--card-accent)}.stat-card-backdrop{position:absolute;top:-50%;right:-20%;width:200px;height:200px;background:var(--card-accent);opacity:.05;border-radius:50%;pointer-events:none}.stat-card-content{position:relative;z-index:1}.stat-icon-wrapper{position:relative;width:48px;height:48px;margin-bottom:1rem}.stat-icon-bg{position:absolute;inset:0;background:var(--card-accent);opacity:.1;border-radius:.75rem}.stat-icon{position:relative;color:var(--card-accent);width:100%;height:100%;padding:.75rem}.stat-main{margin-bottom:1rem}.stat-value{font-size:2rem;font-weight:700;margin:0;color:var(--text-primary);line-height:1}.stat-title{font-size:.875rem;font-weight:500;margin:.5rem 0 0;color:var(--text-secondary)}.stat-trend{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border-color)}.trend-indicator{display:flex;align-items:center;gap:.375rem}.trend-value{font-size:.875rem;font-weight:600}.trend-value.positive{color:var(--accent-green)}.trend-value.negative{color:var(--accent-red)}.trend-label{font-size:.75rem;color:var(--text-muted)}.chart-type-toggle{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.75rem;margin-bottom:1.5rem}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-primary)}.toggle-buttons{display:flex;gap:.5rem;background:var(--dashboard-bg);padding:.25rem;border-radius:.5rem}.toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:var(--transition)}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:var(--card-bg);color:var(--accent-blue);box-shadow:var(--shadow-sm)}.graphs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.5rem;margin-bottom:2rem}.modern-graph-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;transition:var(--transition)}.modern-graph-card:hover{box-shadow:var(--shadow-lg);border-color:#3b82f64d}.graph-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.graph-title-section h3{margin:0 0 .75rem;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.graph-stats{display:flex;align-items:center;gap:.75rem}.total-count{font-size:.8125rem;color:var(--text-muted);font-weight:500}.trend-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:.375rem;font-size:.75rem;font-weight:600}.trend-badge.up{background:#10b9811a;color:var(--accent-green)}.trend-badge.down{background:#ef44441a;color:var(--accent-red)}.current-value{text-align:right}.value-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.05em}.value-number{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.graph-container{height:260px;margin:1rem 0}.graph-placeholder{height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:.75rem}.no-data-badge{padding:.25rem .75rem;background:#ef44441a;color:var(--accent-red);border-radius:.375rem;font-size:.75rem;font-weight:600}.graph-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-color)}.period-info{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-muted)}.view-link{display:flex;align-items:center;gap:.25rem;color:var(--accent-blue);text-decoration:none;font-size:.8125rem;font-weight:500;transition:var(--transition)}.view-link:hover{gap:.5rem}.side-by-side-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.5rem;margin-bottom:2rem}.modern-data-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;transition:var(--transition)}.modern-data-card:hover{box-shadow:var(--shadow-lg)}.modern-data-card.wide{grid-column:1 / -1}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.header-content{display:flex;align-items:center;gap:1rem}.attendance-rate-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#10b9811a;color:var(--accent-green);border-radius:.5rem;font-size:.875rem;font-weight:600}.total-badge{padding:.375rem .75rem;background:var(--dashboard-bg);color:var(--text-secondary);border-radius:.5rem;font-size:.8125rem;font-weight:600}.action-link{display:flex;align-items:center;gap:.25rem;color:var(--accent-blue);text-decoration:none;font-size:.875rem;font-weight:500;transition:var(--transition)}.action-link:hover{gap:.5rem}.no-data-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-muted);gap:.75rem}.attendance-pie-grid{display:grid;gap:2rem;align-items:center}.attendance-pie{height:220px}.attendance-legend{display:flex;gap:.875rem;margin:auto}.attendance-legend-row{display:flex;align-items:center;gap:.75rem}.legend-badge{width:40px;height:40px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#fff}.legend-info{flex:1}.legend-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.legend-meta{font-size:.8125rem;color:var(--text-muted)}.homework-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat-item{padding:1rem;background:var(--dashboard-bg);border-radius:.75rem;transition:var(--transition)}.stat-item:hover{background:#3b82f60d;transform:translateY(-2px)}.stat-item .stat-icon{width:32px;height:32px;margin-bottom:.75rem}.stat-details{margin-bottom:.75rem}.stat-item .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.25rem}.stat-item .stat-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.stat-progress{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-track{height:100%;border-radius:2px;transition:width .6s ease}.time-filters{display:flex;gap:.5rem}.time-filter{padding:.5rem 1rem;background:var(--dashboard-bg);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);transition:var(--transition)}.time-filter:hover{background:var(--card-bg);border-color:var(--accent-blue);color:var(--accent-blue)}.performer-tabs{display:inline-flex;gap:8px;background:linear-gradient(135deg,#eef2ff,#e0f2fe);padding:6px;border-radius:999px;border:1px solid #cbd5e1;box-shadow:0 8px 20px #4f46e51f}.performer-tab{border:none;background:transparent;padding:6px 12px;border-radius:999px;font-weight:600;color:#475569;cursor:pointer;transition:var(--transition);min-width:80px}.performer-tab.active{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;box-shadow:0 8px 18px #6366f140}.performers-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem}.performers-section{background:linear-gradient(135deg,#6366f10f,#0ea5e90a);padding:1.25rem;border-radius:.9rem;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;padding-bottom:20px}.performers-list{display:flex;flex-direction:column;gap:.65rem}.performer-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.75rem .9rem;background:#fff;border-radius:.65rem;border:1px solid var(--border-color);transition:var(--transition)}.performer-item:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.performer-rank{width:30px;height:30px;display:grid;place-items:center;background:linear-gradient(135deg,#0ea5e9,#3b82f6);color:#fff;border-radius:.75rem;font-weight:800;font-size:.85rem}.performer-info{flex:1}.performer-name{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.performer-email{font-size:.8125rem;color:var(--text-muted)}.performer-score{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#3b82f61a;color:#1d4ed8;border-radius:.375rem;font-weight:600;font-size:.875rem}.performer-item.rank-1{border-color:#fbbf24;background:linear-gradient(135deg,#fbbf241f,#fbbf240d)}.performer-item.rank-1 .performer-rank{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.performer-item.rank-2{border-color:#cbd5e1;background:linear-gradient(135deg,#94a3b81f,#94a3b80d)}.performer-item.rank-2 .performer-rank{background:linear-gradient(135deg,#94a3b8,#cbd5e1)}.performer-item.rank-3{border-color:#fb923c;background:linear-gradient(135deg,#f973161f,#f973160d)}.performer-item.rank-3 .performer-rank{background:linear-gradient(135deg,#f97316,#fb923c)}.performer-item.rank-other .performer-rank{background:linear-gradient(135deg,#0ea5e9,#3b82f6)}.system-summary{margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,#0ea5e9,#3b82f6);border-radius:1rem;padding:2rem;color:#fff}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.summary-header h3{margin:0;font-size:1.25rem;font-weight:600}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.summary-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;border:1px solid rgba(255,255,255,.2);transition:var(--transition)}.summary-item:hover{background:#ffffff40;transform:translateY(-2px)}.summary-item .item-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:.75rem}.item-content{flex:1}.summary-item .item-value{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.375rem}.summary-item .item-label{font-size:.875rem;opacity:.9;font-weight:500}.modern-tooltip{background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:.5rem;padding:.75rem;box-shadow:var(--shadow-xl)}.tooltip-header{display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.5rem;color:#fff;font-size:.875rem}.tooltip-content{display:flex;flex-direction:column;gap:.5rem}.tooltip-item{display:flex;align-items:center;gap:.5rem}.tooltip-color{width:12px;height:12px;border-radius:.25rem}.tooltip-info{display:flex;flex-direction:column;gap:.125rem}.tooltip-label{font-size:.8125rem;color:#ffffffb3}.tooltip-value{font-size:.875rem;font-weight:600;color:#fff}.tooltip-percent{color:#fff9;font-weight:500}.modern-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--dashboard-bg);gap:1.5rem}.loading-spinner{position:relative;width:80px;height:80px}.spinner-ring{position:absolute;inset:0;border:4px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modern-loading p{font-size:1rem;color:var(--text-secondary);font-weight:500}.modern-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--dashboard-bg);gap:1rem;padding:2rem;text-align:center}.modern-error svg{color:var(--accent-red)}.modern-error h3{font-size:1.5rem;font-weight:600;margin:0;color:var(--text-primary)}.modern-error p{font-size:1rem;color:var(--text-secondary);margin:0}.modern-retry-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;margin-top:1rem;background:var(--accent-blue);color:#fff;border:none;border-radius:.5rem;font-size:.9375rem;font-weight:600;cursor:pointer;transition:var(--transition)}.modern-retry-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(max-width:1200px){.graphs-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}}@media(max-width:768px){.dashboard-content{padding:1rem}.header-content{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem}.header-actions{width:100%}.action-btn{flex:1}.dashboard-filters{padding:1rem}.filter-group{flex-direction:column;align-items:flex-start;width:100%}.modern-dropdown{width:100%}.stats-grid,.graphs-grid,.side-by-side-cards,.attendance-pie-grid,.homework-stats-grid,.performers-grid,.summary-grid{grid-template-columns:1fr}.chart-type-toggle{flex-direction:column;gap:1rem}.toggle-buttons{width:100%;justify-content:space-between}}.courses-container{min-height:100vh}.courses-header{border-radius:16px;padding:1rem 2rem}.courses-header-content{display:flex;justify-content:space-between;align-items:center}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;background-color:var(--color-secondary);color:var(--color-text-primary)}.btn-secondary:hover{background-color:var(--color-secondary-dark)}.courses-table-container{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;margin:.5rem 2rem}.courses-table{width:100%;border-collapse:collapse}.courses-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.courses-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.courses-table tr:hover{background:#f8fafc;cursor:pointer}.course-id{font-weight:600;color:#667eea}.title-description{display:flex;flex-direction:column;gap:.25rem}.title{font-weight:600;color:#1e293b}.description{font-size:.875rem;color:#64748b;line-height:1.4}.category-badge,.level-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:capitalize}.duration-info,.price-info{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.course-form{flex:1;min-height:0;overflow-y:auto;max-height:calc(90vh - 180px);padding:0 1rem 1rem 0}.course-form{padding:2rem}textarea.form-input{resize:vertical;min-height:80px}.courses-table{width:100%;border-collapse:collapse;table-layout:fixed}.courses-table th:nth-child(1),.courses-table td:nth-child(1){width:120px;min-width:120px}.courses-table th:nth-child(2),.courses-table td:nth-child(2){width:280px;min-width:280px}.courses-table th:nth-child(3),.courses-table td:nth-child(3){width:120px;min-width:120px}.courses-table th:nth-child(4),.courses-table td:nth-child(4){width:120px;min-width:120px}.courses-table th:nth-child(5),.courses-table td:nth-child(5){width:120px;min-width:120px}.courses-table th:nth-child(6),.courses-table td:nth-child(6){width:100px;min-width:100px}.courses-table th:nth-child(7),.courses-table td:nth-child(7){width:120px;min-width:120px}.courses-table th:nth-child(8),.courses-table td:nth-child(8){width:100px;min-width:100px}.courses-table th:nth-child(9),.courses-table td:nth-child(9){width:120px;min-width:120px}.courses-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.courses-table td:nth-child(2){white-space:normal;overflow:visible}.clickable-row{cursor:pointer;transition:background-color .2s ease}.clickable-row:hover{background-color:#f0f4ff!important}@media(max-width:768px){.courses-container{padding:1rem}.courses-header-content{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.filters-section{flex-direction:column;align-items:stretch}.form-grid{grid-template-columns:1fr}.courses-table{min-width:800px}.form-actions{flex-direction:column}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.date-picker-bubble{right:-50px;min-width:260px}.bubble-arrow{right:70px}}.layout{display:flex;height:100vh;background-color:var(--color-bg);position:relative}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.content-area{flex:1;overflow-y:auto;background-color:var(--color-bg);position:relative}.content-container{min-height:calc(100vh - 80px);margin:0 auto}@media(min-width:1025px){.main-content{margin-left:0;border-radius:24px 0 0;background:var(--color-card);box-shadow:-2px 0 20px #00000014;min-height:calc(100vh - 2rem)}.content-area{border-radius:24px 0 0}.layout:has(.sidebar--collapsed){padding-left:80px}.layout:has(.sidebar--collapsed) .main-content{margin-left:0}}@media(max-width:1024px){.layout{padding-left:0}.main-content{margin-left:0;border-radius:0}.main-content.sidebar-open{transform:translate(280px);border-radius:24px 0 0 24px;box-shadow:-5px 0 30px #00000026}.main-content.sidebar-open .content-area{border-radius:24px 0 0 24px}}.layout *{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.content-area::-webkit-scrollbar{width:6px}.content-area::-webkit-scrollbar-track{background:var(--color-bg)}.content-area::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.content-area::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.layout.loading .main-content{opacity:.7;pointer-events:none}@media(prefers-contrast:high){.main-content{border:1px solid var(--color-border)}}@media(prefers-reduced-motion:reduce){.main-content,.layout{transition:none}}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:5px 1.5rem;background:var(--color-card);border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100;transition:all .3s ease}.header-left{display:flex;align-items:center;gap:1.5rem;flex:1}.menu-toggle{background:none;border:none;padding:.75rem;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.menu-toggle:hover{background:var(--color-card-hover);color:var(--color-text-primary)}.user-welcome .welcome-title{font-size:var(--font-body);font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.2}.user-highlight{color:var(--color-primary);font-weight:700}.datetime-info{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin-top:.25rem}.time-separator{opacity:.5}.header-right{display:flex;align-items:center;gap:.75rem}.header-action{position:relative}.header-btn{background:none;border:none;padding:.75rem;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.header-btn:hover{background:var(--color-card-hover);color:var(--color-text-primary)}.header-icon{width:20px;height:20px}.search-container{position:relative;margin-right:20px}.search-wrapper{display:flex;align-items:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all .3s ease;overflow:hidden}.search-wrapper.expanded{width:320px;border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.search-toggle{background:none;border:none;padding:.75rem;color:var(--color-text-secondary);cursor:pointer;transition:color .2s ease;box-shadow:0 10px 25px #00000026;border-radius:10px}.search-toggle:hover{color:var(--color-text-primary)}.search-input-wrapper{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;width:100%;box-shadow:0 2px 8px #0000001a;border-radius:8px}.search-input-icon{width:18px;height:18px;color:var(--color-text-secondary);flex-shrink:0}.search-input{flex:1;border:none;background:none;outline:none;font-size:var(--font-size-body);color:var(--color-text-primary);padding:.25rem 0}.search-input::placeholder{color:var(--color-text-secondary)}.search-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:.25rem;font-size:1.25rem;line-height:1;transition:color .2s ease}.search-close:hover{color:var(--color-text-primary)}.search-dropdown{position:absolute;top:100%;right:0;width:400px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #00000026;margin-top:.5rem;z-index:1000;animation:slideDown .2s ease}.search-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.search-title{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary)}.results-count{font-size:var(--font-size-caption);color:var(--color-text-secondary);background:var(--color-bg);padding:.25rem .5rem;border-radius:var(--radius-sm)}.search-results{max-height:300px;overflow-y:auto}.search-result-item{display:flex;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color .2s ease;gap:.75rem}.search-result-item:hover{background-color:var(--color-card-hover)}.search-result-item:last-child{border-bottom:none}.result-type{font-size:var(--font-size-tiny);color:var(--color-primary);font-weight:600;text-transform:uppercase;background:var(--color-primary)10;padding:.25rem .5rem;border-radius:var(--radius-sm);flex-shrink:0}.result-title{font-size:var(--font-size-body);color:var(--color-text-primary);flex:1}.result-arrow{width:16px;height:16px;color:var(--color-text-secondary);flex-shrink:0}.search-empty{display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--color-text-secondary);text-align:center;gap:.75rem}.empty-icon{width:48px;height:48px;opacity:.5}.notification-btn{position:relative}.notification-badge{position:absolute;top:4px;right:4px;background:var(--color-error);color:#fff;font-size:var(--font-size-tiny);font-weight:600;padding:.2rem 0rem;border-radius:10px;min-width:18px;text-align:center;line-height:1}.notifications-dropdown{position:absolute;top:100%;right:0;width:360px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #00000026;margin-top:.5rem;z-index:1000;animation:slideDown .2s ease}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid var(--color-border)}.dropdown-header h3{margin:0;font-size:var(--font-size-h3);color:var(--color-text-primary)}.dropdown-header .badge{background:var(--color-primary);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:var(--font-size-caption);font-weight:600}.notifications-list{max-height:400px;overflow-y:auto}.notification-item{display:flex;align-items:flex-start;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);gap:.75rem;transition:background-color .2s ease}.notification-item:hover{background-color:var(--color-card-hover)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:var(--color-primary)08}.notification-icon{position:relative;padding-top:.25rem}.notification-dot{width:8px;height:8px;background:var(--color-primary);border-radius:50%;flex-shrink:0}.notification-content{flex:1}.notification-title{font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.notification-message{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin-bottom:.25rem;line-height:1.4}.notification-time{font-size:var(--font-size-caption);color:var(--color-text-secondary);opacity:.7}.dropdown-footer{padding:1rem;border-top:1px solid var(--color-border);text-align:center}.view-all-btn{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:.5rem 1rem;border-radius:var(--radius-md);transition:background-color .2s ease}.view-all-btn:hover{background-color:var(--color-card-hover)}.language-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem}.current-flag{width:20px;height:15px;border-radius:2px;object-fit:cover}.language-dropdown{position:absolute;top:100%;right:0;width:200px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #00000026;margin-top:.5rem;z-index:1000;animation:slideDown .2s ease}.language-options{padding:.5rem}.language-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;transition:background-color .2s ease;font-size:var(--font-size-body);border-radius:var(--radius-md)}.language-option:hover{background-color:var(--color-card-hover)}.language-option.active{background-color:var(--color-primary)15;color:var(--color-primary)}.language-flag{width:20px;height:15px;border-radius:2px;object-fit:cover}.language-label{flex:1;text-align:left}.checkmark{font-weight:600;color:var(--color-primary)}.profile-container{margin-left:.5rem}.profile-trigger{display:flex;align-items:center;gap:.5rem;background:none;border:none;padding:.5rem;border-radius:var(--radius-lg);cursor:pointer;transition:background-color .2s ease}.profile-trigger:hover{background-color:var(--color-card-hover)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-body)}.chevron{transition:transform .2s ease;color:var(--color-text-secondary);width:16px;height:16px}.chevron.rotate{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:100%;right:0;width:280px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #00000026;margin-top:.5rem;z-index:1000;animation:slideDown .2s ease}.user-info-section{display:flex;align-items:center;gap:.75rem;padding:1.25rem}.user-avatar-large{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.125rem;flex-shrink:0}.user-details-large{flex:1;min-width:0}.user-name-large{font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-body);margin-bottom:.25rem}.user-email{font-size:var(--font-size-caption);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis}.dropdown-section{padding:.5rem}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s ease;font-size:var(--font-size-body);color:var(--color-text-primary)}.dropdown-item:hover{background-color:var(--color-card-hover)}.dropdown-item.logout-item{color:var(--color-error)}.dropdown-item.logout-item:hover{background-color:var(--color-error-bg)}.item-icon{width:18px;height:18px;color:inherit}.dropdown-divider{height:1px;background:var(--color-border);margin:.25rem 0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.profile-header{padding:0 1rem;height:70px}.user-welcome .welcome-title{font-size:var(--font-size-h3)}.search-wrapper.expanded{width:200px}.search-dropdown{width:300px}.notifications-dropdown{width:300px;right:-50%}.datetime-info .date,.time-separator{display:none}}@media(max-width:480px){.search-wrapper.expanded{width:150px}.language-code,.user-welcome{display:none}}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;background:var(--color-card);border-right:1px solid var(--color-border);z-index:1000;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 12px #00000014}.sidebar:after{content:"";position:absolute;top:0;right:-1px;width:1px;height:100%;background:var(--color-card);z-index:2}.sidebar--mobile{transform:translate(-100%)}.sidebar--mobile.sidebar--open{transform:translate(0)}.sidebar--desktop{position:fixed;transform:translate(0)}.sidebar--desktop.sidebar--collapsed{width:80px}.sidebar-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-card);position:relative}.sidebar-logo{display:flex;align-items:center;gap:.75rem;min-width:0;flex:1}.sidebar-logo-icon{font-size:1.5rem;color:var(--color-primary);min-width:32px;display:flex;align-items:center;justify-content:center}.logo-text{font-size:var(--font-body);font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;transition:opacity .3s ease}.sidebar-toggle{position:absolute;right:-16px;top:50%;transform:translateY(-50%);background:var(--color-accent);border:2px solid var(--color-card);color:#fff;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;width:32px;height:32px;box-shadow:0 2px 8px #00000026;z-index:1001}.sidebar-toggle:hover{background:var(--color-accent);box-shadow:0 4px 12px #0003}.toggle-icon{transition:transform .3s cubic-bezier(.4,0,.2,1);width:16px;height:16px}.toggle-icon.rotated{transform:rotate(180deg)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;background:var(--color-card)}.sidebar-menu{list-style:none;margin:0;padding:0 .75rem}.sidebar-menu-item{margin-bottom:.25rem;position:relative}.sidebar-menu-link{display:flex;align-items:center;padding:.75rem 1rem;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-lg);transition:all .2s ease;position:relative;background:transparent}.sidebar-menu-link:hover{background:var(--color-card-hover);color:var(--color-text-primary);transform:translate(4px)}.sidebar-menu-link.active{background:rgba(var(--color-primary-hover),.5);color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb),.15);box-shadow:#1d3f954d 0 0 0 1px}.sidebar-menu-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.menu-icon{margin-right:.75rem;width:24px;display:flex;align-items:center;justify-content:center;color:inherit;flex-shrink:0;transition:margin-right .3s ease}.menu-label{font-size:var(--font-size-secondary-text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s ease;flex:1;text-align:left}.menu-badge{background:var(--color-accent);color:#fff;font-size:var(--font-size-tiny);padding:.25rem .5rem;border-radius:12px;font-weight:600;margin-left:auto;flex-shrink:0}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--color-border);background:var(--color-card);display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:72px}.user-profile{display:flex;align-items:center;gap:.75rem;transition:all .3s ease;flex:1;min-width:0;position:relative;cursor:pointer;justify-content:flex-start}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex-shrink:0;transition:all .3s ease}.user-info{flex:1;min-width:0;transition:all .3s ease}.user-name{font-size:var(--font-size-secondary-text);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--font-size-caption);color:var(--color-text-secondary)}.sidebar-close{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-close:hover{background:var(--color-card-hover);border-color:var(--color-primary);color:var(--color-primary)}.sidebar--desktop.sidebar--collapsed .logo-text,.sidebar--desktop.sidebar--collapsed .menu-label,.sidebar--desktop.sidebar--collapsed .menu-badge,.sidebar--desktop.sidebar--collapsed .user-info{opacity:0;width:0;margin-left:-10px;pointer-events:none}.sidebar--desktop.sidebar--collapsed .sidebar-menu-link{justify-content:center;padding:.75rem}.sidebar--desktop.sidebar--collapsed .menu-icon{margin-right:0}.sidebar--desktop.sidebar--collapsed .sidebar-header{padding:1rem .75rem;justify-content:center}.sidebar--desktop.sidebar--collapsed .sidebar-logo{justify-content:center}.sidebar--desktop.sidebar--collapsed .sidebar-footer{padding:1rem .5rem;justify-content:center;display:flex;align-items:center}.sidebar--desktop.sidebar--collapsed .user-profile{justify-content:center!important;width:100%;margin:0 auto;flex:0 0 auto}.sidebar--desktop.sidebar--collapsed .user-avatar{margin:0 auto;display:flex;align-items:center;justify-content:center}.sidebar--desktop.sidebar--collapsed .user-info{display:none}.sidebar-tooltip-global{position:fixed;background:var(--color-text-primary);color:var(--color-text-inverse);padding:.5rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-caption);white-space:nowrap;z-index:1100;box-shadow:0 4px 12px #00000026;font-weight:500;pointer-events:none;animation:tooltipFadeIn .2s ease}.sidebar-tooltip-global:before{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:var(--color-text-primary)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(-5px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.sidebar-toggle[data-tooltip]:after{content:attr(data-tooltip);position:fixed;right:calc(100% - 80px);top:50%;transform:translateY(-50%) translate(-10px);background:var(--color-text-primary);color:var(--color-text-inverse);padding:.5rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-caption);white-space:nowrap;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1100;box-shadow:0 4px 12px #00000026;font-weight:500}.sidebar-toggle[data-tooltip]:before{content:"";position:fixed;right:calc(100% - 80px);top:50%;transform:translateY(-50%) translate(-5px);border:5px solid transparent;border-left-color:var(--color-text-primary);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1101}.sidebar-toggle:hover[data-tooltip]:after,.sidebar-toggle:hover[data-tooltip]:before{opacity:1;transform:translateY(-50%) translate(-15px)}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:var(--color-bg)}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}@media(max-width:1024px){.sidebar--mobile{width:280px}.sidebar-toggle{display:none}.sidebar-tooltip-global,[data-tooltip]:after,[data-tooltip]:before{display:none!important}}@media(min-width:1025px){.sidebar--desktop{box-shadow:4px 0 20px #00000014}.sidebar--desktop.sidebar--collapsed{box-shadow:4px 0 20px #0000000d}.sidebar-close{display:none}}:root{--PhoneInput-color--focus: #03b2cb;--PhoneInputInternationalIconPhone-opacity: .8;--PhoneInputInternationalIconGlobe-opacity: .65;--PhoneInputCountrySelect-marginRight: .35em;--PhoneInputCountrySelectArrow-width: .3em;--PhoneInputCountrySelectArrow-marginLeft: var(--PhoneInputCountrySelect-marginRight);--PhoneInputCountrySelectArrow-borderWidth: 1px;--PhoneInputCountrySelectArrow-opacity: .45;--PhoneInputCountrySelectArrow-color: currentColor;--PhoneInputCountrySelectArrow-color--focus: var(--PhoneInput-color--focus);--PhoneInputCountrySelectArrow-transform: rotate(45deg);--PhoneInputCountryFlag-aspectRatio: 1.5;--PhoneInputCountryFlag-height: 1em;--PhoneInputCountryFlag-borderWidth: 1px;--PhoneInputCountryFlag-borderColor: rgba(0,0,0,.5);--PhoneInputCountryFlag-borderColor--focus: var(--PhoneInput-color--focus);--PhoneInputCountryFlag-backgroundColor--loading: rgba(0,0,0,.1)}.PhoneInput{display:flex;align-items:center}.PhoneInputInput{flex:1;min-width:0}.PhoneInputCountryIcon{width:calc(var(--PhoneInputCountryFlag-height) * var(--PhoneInputCountryFlag-aspectRatio));height:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--square{width:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--border{background-color:var(--PhoneInputCountryFlag-backgroundColor--loading);box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor)}.PhoneInputCountryIconImg{display:block;width:100%;height:100%}.PhoneInputInternationalIconPhone{opacity:var(--PhoneInputInternationalIconPhone-opacity)}.PhoneInputInternationalIconGlobe{opacity:var(--PhoneInputInternationalIconGlobe-opacity)}.PhoneInputCountry{position:relative;align-self:stretch;display:flex;align-items:center;margin-right:var(--PhoneInputCountrySelect-marginRight)}.PhoneInputCountrySelect{position:absolute;top:0;left:0;height:100%;width:100%;z-index:1;border:0;opacity:0;cursor:pointer}.PhoneInputCountrySelect[disabled],.PhoneInputCountrySelect[readonly]{cursor:default}.PhoneInputCountrySelectArrow{display:block;content:"";width:var(--PhoneInputCountrySelectArrow-width);height:var(--PhoneInputCountrySelectArrow-width);margin-left:var(--PhoneInputCountrySelectArrow-marginLeft);border-style:solid;border-color:var(--PhoneInputCountrySelectArrow-color);border-top-width:0;border-bottom-width:var(--PhoneInputCountrySelectArrow-borderWidth);border-left-width:0;border-right-width:var(--PhoneInputCountrySelectArrow-borderWidth);transform:var(--PhoneInputCountrySelectArrow-transform);opacity:var(--PhoneInputCountrySelectArrow-opacity)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon+.PhoneInputCountrySelectArrow{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon--border{box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon .PhoneInputInternationalIconGlobe{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}.students-container{min-height:100vh}.students-header{border-radius:16px;padding:1rem 2rem}.students-header-content{display:flex;justify-content:space-between;align-items:center}.search-input{padding:.75rem 1rem .75rem 3rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.filter-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;min-width:150px}.date-range-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s;min-width:200px}.date-picker-bubble{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;min-width:280px;overflow:hidden}.bubble-arrow{position:absolute;top:-6px;right:20px;width:12px;height:12px;background:#fff;border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.date-picker-content{padding:16px;background:#fff;border-radius:8px;box-sizing:border-box}.date-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box;max-width:100%}.clear-btn{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;font-size:14px}@media(max-width:768px){.date-picker-bubble{right:-50px;min-width:260px}.bubble-arrow{right:70px}}.status-dropdown-bubble{position:relative}.status-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s;min-width:140px;font-size:14px;color:#374151}.status-trigger:hover{border-color:#9ca3af;background:#f9fafb}.status-display{flex:1;text-align:left}.status-bubble{position:absolute;top:100%;left:0;margin-top:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;min-width:160px;overflow:hidden}.status-bubble .bubble-arrow{position:absolute;top:-6px;left:20px;width:12px;height:12px;background:#fff;border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.status-options{padding:8px;background:#fff;border-radius:8px}.status-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151}.status-option:hover{background:#f3f4f6}.status-option.selected{background:#eff6ff;color:#1d4ed8}.status-dropdown-bubble,.date-range-picker{position:relative}.students-table-container{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;margin:.5rem 2rem}.students-table{width:100%;border-collapse:collapse}.students-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.students-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.students-table tr:hover{background:#f8fafc}.student-id{font-weight:600;color:#667eea}.name-avatar{display:flex;align-items:center;gap:.75rem}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.profile-upload-control input[type=file]{flex:1}.student-dob{font-size:.875rem;color:#64748b}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-header h2{margin:0;color:#1e293b}.student-form{padding:2rem}.country-select{width:100%}.country-select .rbc-country-select{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#f8fafc}.country-select .rbc-country-select:focus{outline:none;border-color:#667eea;background:#fff}@media(max-width:768px){.students-container{padding:1rem}.students-header-content{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.filters-section{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column}.form-grid{grid-template-columns:1fr}.students-table{min-width:800px}.form-actions{flex-direction:column}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}}@media(max-width:480px){.header-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}}.students-table{width:100%;border-collapse:collapse;table-layout:fixed}.students-table th:nth-child(1),.students-table td:nth-child(1){width:120px;min-width:120px}.students-table th:nth-child(2),.students-table td:nth-child(2){width:220px;min-width:220px}.students-table th:nth-child(3),.students-table td:nth-child(3){width:250px;min-width:250px}.students-table th:nth-child(4),.students-table td:nth-child(4){width:150px;min-width:150px}.students-table th:nth-child(5),.students-table td:nth-child(5){width:100px;min-width:100px}.students-table th:nth-child(6),.students-table td:nth-child(6){width:140px;min-width:140px}.students-table th:nth-child(7),.students-table td:nth-child(7){width:150px;min-width:150px}.students-table th:nth-child(8),.students-table td:nth-child(8){width:200px;min-width:180px}.students-table th:nth-child(9),.students-table td:nth-child(9){width:100px;min-width:100px}.students-table th:nth-child(10),.students-table td:nth-child(10){width:120px;min-width:120px}.students-table th:nth-child(11),.students-table td:nth-child(11){width:120px;min-width:120px}.students-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.students-table td:nth-child(8){white-space:normal;overflow:visible}.table-wrapper{overflow-x:auto;width:100%}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f8fafc}.teachers-container{padding:2rem;background:#f8fafc;min-height:100vh}.teachers-header{border-radius:1.5rem;color:#fff;margin-bottom:1rem}.teachers-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.teachers-title{font-size:1.2rem;font-weight:700;margin-bottom:.5rem;line-height:1.2}.teachers-subtitle{font-size:1.125rem;opacity:.9}.manage-teachers-btn{background:#fff;color:#2563eb;padding:.75rem 1.5rem;border-radius:.75rem;border:none;font-weight:600;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #0000001a}.manage-teachers-btn:hover{background:#eff6ff;transform:translateY(-1px);box-shadow:0 6px 8px -1px #0000001a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:1rem;padding:1.5rem;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000d;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.stat-icon{padding:.75rem;border-radius:.75rem;display:inline-flex;margin-bottom:1rem}.stat-icon.bg-blue{background:#dbeafe;color:#2563eb}.stat-icon.bg-green{background:#dcfce7;color:#16a34a}.stat-icon.bg-gray{background:#f3f4f6;color:#6b7280}.stat-icon.bg-purple{background:#f3e8ff;color:#9333ea}.stat-label{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:#1f2937;line-height:1}.message-alert{border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;border-left:4px solid}.message-alert.success{background:#f0fdf4;color:#166534;border-color:#22c55e}.message-alert.error{background:#fef2f2;color:#991b1b;border-color:#ef4444}.message-text{flex:1;font-weight:500}.message-close{padding:.5rem;border-radius:.5rem;border:none;background:transparent;cursor:pointer;transition:background-color .2s ease}.message-close:hover{background:#ffffff80}.teachers-table-container{background:#fff;border-radius:1rem;border:1px solid #f1f5f9;overflow:hidden;box-shadow:0 1px 3px #0000000d}.table-header{padding:1.5rem;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.table-title{font-size:1.25rem;font-weight:600;color:#1f2937}.table-badge{background:#dbeafe;color:#2563eb;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.empty-state{padding:3rem;text-align:center}.empty-icon{margin:0 auto 1rem;color:#9ca3af}.empty-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.empty-description{color:#6b7280;margin-bottom:1.5rem}.empty-action-btn{background:#2563eb;color:#fff;padding:.75rem 1.5rem;border-radius:.75rem;border:none;cursor:pointer;display:flex;align-items:center;gap:.5rem;margin:0 auto;transition:background-color .2s ease}.empty-action-btn:hover{background:#1d4ed8}.filters_section{display:flex;gap:10px;margin-bottom:20px}.teachers-list{divide-y:1px;divide-color:#f1f5f9}.teacher-card{padding:1.5rem;transition:background-color .2s ease}.teacher-card:hover{background:#f8fafc}.teacher-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.teacher-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.teacher-avatar{width:3rem;height:3rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:1rem;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.125rem;flex-shrink:0}.teacher-avatar img{width:100%;height:100%;object-fit:cover;border-radius:1rem;display:block}.teacher-details{flex:1;min-width:0}.teacher-name{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.25rem;truncate:true}.teacher-email{color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.teachers-grid-cell{font-size:.95rem;color:#0f172a}.teachers-cell-name .name-avatar{gap:.6rem}.teachers-name-text{font-size:.95rem;font-weight:600}.teachers-qualification-text{font-size:.8rem;color:#6b7280}.truncate-text{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-meta{display:flex;align-items:center;gap:1rem}.teacher-id{font-size:.75rem;color:#6b7280;background:#f3f4f6;padding:.25rem .5rem;border-radius:9999px}.subject-count{font-size:.75rem;padding:.25rem .5rem;border-radius:9999px}.subject-count.has-subjects{background:#dcfce7;color:#166534}.subject-count.no-subjects{background:#fef3c7;color:#92400e}.teacher-actions{display:flex;align-items:center;gap:1rem}.status-badge{padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.assigned{background:#dcfce7;color:#166534}.status-badge.available{background:#f3f4f6;color:#6b7280}.expand-btn{padding:.5rem;color:#9ca3af;border:none;background:transparent;cursor:pointer;border-radius:.5rem;transition:all .2s ease}.expand-btn:hover{color:#6b7280;background:#f3f4f6}.teacher-expanded-details{margin-top:1.5rem;padding-left:4rem;border-top:1px solid #f1f5f9;padding-top:1.5rem}.details-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.details-grid{grid-template-columns:1fr 1fr}}.details-title{font-weight:600;color:#1f2937;margin-bottom:.75rem}.subjects-list{display:flex;flex-wrap:wrap;gap:.5rem}.subject-tags{display:flex;flex-wrap:wrap;gap:.35rem}.subject-tag-pill{background:#eef2ff;color:#4338ca;padding:.25rem .5rem;border-radius:.6rem;font-size:.8rem;border:1px solid #e0e7ff}.subject-more{color:#6b7280;font-size:.8rem}.teachers-modern-card{border-radius:1.25rem;border:1px solid #e2e8f0;background:linear-gradient(145deg,#fff,#f8fafc);box-shadow:0 24px 60px #0f172a14}.teachers-modern-subheader{padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#3b82f60a;display:flex;justify-content:space-between;align-items:center}.teachers-modern-table{width:100%}.teachers-modern-table thead{box-shadow:#0000000d 0 0 0 1px}.teachers-grid-table th,.teachers-grid-head{white-space:nowrap}.teachers-modern-table th{padding:.95rem 1rem;font-weight:700;font-size:.95rem;letter-spacing:.01em;text-transform:uppercase}.teachers-modern-table td{padding:.9rem 1rem;box-shadow:#2123261a 0 10px 10px -10px}.teachers-modern-table tbody tr:hover{background:#f8fafc;box-shadow:0 6px 14px #0f172a0f;position:relative;z-index:1}.teachers-modern-modal-overlay{background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.teachers-modern-modal{width:100%;max-width:860px;border-radius:1.25rem;border:1px solid #e2e8f0;box-shadow:0 30px 60px #0f172a26;padding:0;overflow:hidden}.teachers-modern-modal-header{background:var(--color-primary);color:#fff;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:3}.teachers-modern-modal-header h2{color:var(--color-card);font-size:1.3rem}.teachers-modern-form{padding:1.5rem;background:#f8fafc;max-height:60vh;overflow-y:auto}.teachers-modern-footer{position:sticky;bottom:0;background:#fff;padding:.75rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:.75rem;z-index:3}.teachers-modern-close{background:#ffffff26;color:#fff;border:none;border-radius:.6rem;padding:.4rem .6rem;cursor:pointer}.teachers-subject-chip{background:#eef2ff;color:#4338ca;padding:.25rem .6rem;border-radius:.65rem;font-size:.8rem;border:1px solid #e0e7ff}.teachers-btn-compact{display:inline-flex;align-items:center;gap:.5rem}.teachers-btn-compact .btn-text{display:inline}@media(max-width:640px){.teachers-btn-compact{padding:.6rem;width:fit-content}.teachers-btn-compact .btn-text{display:none}}.subject-tag{background:#dcfce7;color:#166534;padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;font-weight:500;border:1px solid #bbf7d0}.no-subjects-warning{display:flex;align-items:center;gap:.5rem;color:#92400e;background:#fef3c7;padding:.75rem;border-radius:.5rem;font-size:.875rem;font-weight:500}.info-list{space-y:.5rem}.info-item{display:flex;justify-content:space-between;font-size:.875rem}.info-label{color:#6b7280}.info-value{font-weight:500}.info-value.eligible{color:#166534}.info-value.not-eligible{color:#92400e}.teachers-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:5rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border-radius:9999px;height:3rem;width:3rem;border-bottom:2px solid #3b82f6;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal-container{background:#fff;border-radius:1.5rem;max-width:80rem;width:100%;max-height:95vh;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;color:#fff;position:relative}.modal-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.modal-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.modal-subtitle{color:#dbeafe;opacity:.9}.modal-close-btn{padding:.5rem;color:#fff;border:none;background:transparent;cursor:pointer;border-radius:.75rem;transition:background-color .2s ease}.selection-summary{margin-top:1.5rem;background:#fff3;border-radius:.75rem;padding:1rem}.summary-content{display:flex;align-items:center;justify-content:space-between}.summary-label{color:#dbeafe;font-size:.875rem}.summary-count{font-size:1.5rem;font-weight:700}.summary-actions{display:flex;gap:.75rem}.summary-btn{background:#fff3;color:#fff;padding:.5rem 1rem;border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease}.summary-btn:hover{background:#ffffff4d}.modal-body{padding:2rem;overflow-y:auto;max-height:60vh}.search-filter-bar{display:flex;gap:1rem;margin-bottom:2rem}.search-container{flex:1;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af}.search-input{padding:1rem 1rem 1rem 3rem;border:1px solid #e5e7eb;border-radius:1rem;background:#f9fafb;font-size:1.125rem}.search-input:focus{outline:none;ring:2px;ring-color:#3b82f6;border-color:#3b82f6}.filter-container{position:relative}.filter-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af}.filter-select{padding:1rem 2.5rem 1rem 3rem;border:1px solid #e5e7eb;border-radius:1rem;background:#f9fafb;appearance:none}.filter-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.teachers-modal-grid{display:grid;gap:1rem}.modal-empty-state{text-align:center;padding:4rem}.modal-empty-icon{margin:0 auto 1rem;color:#d1d5db}.modal-empty-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.modal-empty-description{color:#6b7280}.teacher-modal-card{padding:1.5rem;border:2px solid #f1f5f9;border-radius:1rem;background:#fff;transition:all .2s ease}.teacher-modal-card:hover{border-color:#e5e7eb;box-shadow:0 4px 6px -1px #0000000d}.teacher-modal-card.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 4px 6px -1px #3b82f61a}.teacher-modal-card.disabled{opacity:.7;filter:grayscale(1)}.teacher-modal-content{display:flex;align-items:flex-start;gap:1rem}.teacher-checkbox{height:1.25rem;width:1.25rem;color:#3b82f6;border-radius:.25rem;border:1px solid #d1d5db;margin-top:.25rem}.teacher-checkbox:focus{ring:2px;ring-color:#3b82f6}.teacher-modal-info{flex:1}.teacher-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.teacher-modal-name{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.teacher-modal-email{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.teacher-modal-id{color:#9ca3af;font-size:.75rem}.teacher-modal-stats{text-align:right}.matching-subjects-count{font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.eligibility-status{font-size:.75rem;font-weight:500}@media(max-width:768px){.filters_section{flex-direction:column}.teachers-header-content{flex-direction:column;gap:10px}}.subjects-page{padding:1rem;background:#f8fafc;min-height:100vh}.subjects-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1rem}.subjects-title{font-size:1rem;font-weight:700;color:#0f172a}.subjects-subtitle{color:#475569;margin-top:.25rem;font-size:.95rem}.subjects-actions{display:flex;align-items:center;gap:.75rem}.primary-btn,.ghost-btn{display:inline-flex;align-items:center;gap:.5rem;border:none;border-radius:.75rem;padding:.75rem 1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.primary-btn{background:#2563eb;color:#fff;box-shadow:0 10px 15px -3px #2563eb40}.primary-btn:hover{background:#1d4ed8}.ghost-btn{background:#fff;color:#1f2937;border:1px solid #e2e8f0}.ghost-btn:hover{border-color:#cbd5e1;box-shadow:0 4px 6px #0f172a0d}.subjects-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.subjects-stats.compact{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.subjects-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:.75rem .9rem;box-shadow:0 10px 30px #0f172a0d;display:flex;flex-direction:row;align-items:center;gap:.65rem}.stat-icon{display:inline-flex;padding:.4rem;border-radius:.75rem}.bg-blue{background:#e0f2fe;color:#2563eb}.bg-green{background:#dcfce7;color:#16a34a}.bg-orange{background:#fff7ed;color:#ea580c}.bg-purple{background:#f3e8ff;color:#7c3aed}.stat-label{color:#64748b;font-weight:500;margin:0;display:inline-flex;align-items:center;gap:.5rem}.stat-value{font-size:1.6rem;font-weight:700;margin:.2rem 0 0;color:#0f172a;line-height:1.2}.subject-filters{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem}.subjects-search-box,.subjects-search-bar{margin-top:auto;position:relative;flex:1;min-width:280px;background:#fff;border:1px solid #e2e8f0;border-radius:.9rem;box-shadow:0 8px 20px #0f172a0d}.subjects-search-input{width:100%;padding:.9rem 1rem .9rem 2.7rem;border-radius:.9rem;border:none;background:transparent;font-size:1rem}.subjects-search-input:focus{outline:none}.subjects-search-icon{position:absolute;top:50%;left:.95rem;transform:translateY(-50%);color:#94a3b8}.subjects-filter-group{min-width:160px;display:flex;flex-direction:column;gap:.3rem}.subjects-filter-group label{font-size:.875rem;color:#475569;font-weight:600}.subjects-filter-select{padding:.75rem .9rem;border-radius:.85rem;border:1px solid #e2e8f0;background:#fff;box-shadow:0 8px 16px #0f172a0a}.subjects-table-card{background:#fff;border-radius:1rem;border:1px solid #e2e8f0;box-shadow:0 12px 30px #0f172a0f}.table-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.table-title{margin:0;font-size:1.1rem;font-weight:700}.table-subtitle{margin:.1rem 0 0;color:#64748b;font-size:.95rem}.table-actions{display:flex;gap:.5rem}.subjects-loading,.subjects-empty{padding:2.5rem;text-align:center}.loading-spinner{height:2.5rem;width:2.5rem;margin:0 auto 1rem;border-radius:50%;border:3px solid #e5e7eb;border-top-color:#2563eb;animation:spin 1s linear infinite}.subjects-empty h4{margin:0 0 .25rem}.subjects-empty p{margin:0 0 1rem;color:#64748b}.subjects-table-wrapper{overflow-x:auto}.subjects-table{width:100%;border-collapse:collapse}.subjects-table th,.subjects-table td{padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}.subjects-table th{background:#f8fafc;font-size:.95rem;color:#475569;font-weight:700}.subject-cell{display:flex;flex-direction:column;gap:.25rem}.subject-name{font-weight:700;color:#0f172a;font-size:1rem}.subjects-truncate{max-width:340px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subject-meta{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.subject-id{background:#f1f5f9;color:#475569;padding:.25rem .5rem;border-radius:999px;font-size:.85rem}.subject-description{margin:0;color:#64748b;line-height:1.4}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:999px;font-weight:600;font-size:.85rem}.pill.core{background:#dbeafe;color:#1d4ed8}.pill.elective{background:#f3e8ff;color:#7c3aed}.pill.muted{background:#f8fafc;color:#475569}.subjects-teacher-pill{white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0}.link-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:.65rem;background:#eef2ff;color:#4338ca;text-decoration:none;font-weight:600}.status-pill{padding:.35rem .75rem;border-radius:999px;font-weight:700;font-size:.9rem}.status-pill.active{background:#dcfce7;color:#15803d}.status-pill.inactive{background:#fee2e2;color:#b91c1c}.actions{display:flex;gap:.35rem}.icon_btn{display:flex;gap:8px;padding:8px 10px;border-radius:.55rem;border:1px solid #e2e8f0;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.icon_btn:hover{border-color:#cbd5e1;box-shadow:0 4px 6px #0f172a14}.icon_btn.danger{color:#b91c1c;border-color:#fecdd3;background:#fff1f2}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal-container{background:#fff;border-radius:1.25rem;width:100%;max-width:760px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.subject-modal-header{display:flex;flex-direction:column;gap:20px;background:var(--color-primary);color:#fff;padding:1.75rem 1.75rem 1rem}.modal-header-content{display:flex;justify-content:space-between;gap:1rem;align-items:center}.modal-header h3,.modal-close{color:#fff}.modal-actions-inline{display:flex;align-items:center;margin-left:auto}.modal-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;margin:0 0 .2rem;color:#e0e7ff}.modal-title{margin:0;font-size:1.4rem}.modal-subtitle{margin:.35rem 0 0;color:#e0e7ff;opacity:.9}.modal-close-btn{border:none;background:#ffffff1a;color:#fff;padding:.4rem .6rem;border-radius:.65rem;cursor:pointer}.modal-close-btn:hover{background:#fff3}.modal-body{padding:1.75rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem 1.25rem}.form-group input,.form-group textarea{border:1px solid #e2e8f0;border-radius:.75rem;padding:.7rem .9rem;font-size:1rem;background:#fff}.form-group textarea{resize:vertical}.form-group label{font-weight:600;color:#0f172a}.form-switch{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.9rem;padding:.75rem;display:flex;flex-direction:column;gap:.2rem}.form-switch label{display:flex;gap:.5rem;align-items:center;font-weight:600}.helper-text{margin:0;color:#64748b;font-size:.9rem}.subjects-teacher-manager{margin-top:1rem;border:1px solid #e2e8f0;border-radius:1rem;padding:1rem;background:#f8fafc}.subjects-modal-tabs{display:flex;width:100%;gap:.5rem;padding:.4rem;background:#eef2ff;border-radius:.95rem;margin-bottom:1rem;position:sticky;top:0;z-index:2}.subjects-tab-btn{border:none;background:transparent;flex:1;padding:.7rem 1rem;border-radius:.8rem;font-weight:700;color:#4338ca;cursor:pointer;transition:all .2s ease}.subjects-tab-btn.active{background:#fff;box-shadow:0 10px 30px #4338ca33}.modal-container{display:flex;flex-direction:column}.modal-header{position:sticky;top:0;z-index:3;background:var(--color-primary)}.modal-body{flex:1;overflow-y:auto;overflow-x:hidden}.modal-actions{position:sticky;bottom:0;background:#fff;padding:1rem;margin-top:0;border-top:1px solid #e2e8f0}.subjects-teacher-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem}.subjects-teacher-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#6366f1}.subjects-teacher-title{margin:.15rem 0 0;font-size:1.1rem}.subjects-teacher-subtitle{margin:.15rem 0 0;color:#64748b;font-size:.95rem}.subjects-teacher-count{background:#eef2ff;color:#4338ca;padding:.5rem .75rem;border-radius:.9rem;font-weight:700;white-space:nowrap}.subjects-teacher-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem}.subjects-teacher-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid #e2e8f0;border-radius:.9rem;background:#fff;cursor:pointer;transition:all .2s ease}.subjects-teacher-card input{margin:0}.subjects-teacher-card.selected{border-color:#c7d2fe;box-shadow:0 6px 14px #4f46e51f}.subjects-teacher-info{display:flex;align-items:center;gap:.75rem;min-width:0}.subjects-teacher-avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.subjects-teacher-name{font-weight:700;color:#0f172a}.subjects-teacher-meta{color:#475569;font-size:.9rem}.modal-actions{margin-top:1.5rem;display:flex;justify-content:flex-end;gap:.75rem}@media(max-width:768px){.subjects-header{flex-direction:column}.subjects-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.table-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.employees-container{min-height:100vh}.employees-header{border-radius:16px;padding:1rem 2rem}.employees-header-content{display:flex;justify-content:space-between;align-items:center}.page-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-primary);margin:0 0 .5rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-primary)}.breadcrumb-item{transition:color .2s ease}.breadcrumb-item:hover{color:var(--color-text-primary)}.breadcrumb-item.active{color:var(--color-accent);font-weight:600}.breadcrumb-separator{color:#9ca3af}.header-actions{display:flex;gap:1rem}.btn-primary{border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;background-color:var(--color-primary);color:var(--color-card)}.btn-secondary{border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:1rem 2rem 2rem}.stat-card{background:var(--color-card);padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{padding:1rem;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.admin{background:#e0e7ff;color:#667eea}.stat-icon.principal{background:#d1fae5;color:#059669}.stat-icon.total{background:#fef3c7;color:#d97706}.stat-icon.active{background:#dcfce7;color:#16a34a}.stat-content h3{font-size:2rem;font-weight:700;margin:0;color:#1f2937}.stat-content p{margin:0;color:#6b7280;font-size:.875rem}.filters-section{border-radius:16px;padding:.5rem 2rem;display:flex;gap:1rem;align-items:center}.search-box{position:relative;flex:1}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#64748b}.search-input{padding:.75rem 1rem .75rem 3rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .3s ease;background:var(--color-card)}.search-input:focus{outline:none;border-color:#667eea}.filter-group{display:flex;gap:1rem}.filter-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:var(--color-card);cursor:pointer;min-width:150px}.date-range-picker{position:relative}.date-range-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:var(--color-card);cursor:pointer;transition:all .2s;min-width:200px}.date-range-trigger:hover{border-color:#9ca3af}.date-range-display{font-size:14px;color:#374151;flex:1}.date-picker-bubble{position:absolute;top:100%;right:0;margin-top:8px;background:var(--color-card);border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;min-width:280px;overflow:hidden}.bubble-arrow{position:absolute;top:-6px;right:20px;width:12px;height:12px;background:var(--color-card);border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.date-picker-content{padding:16px;background:var(--color-card);border-radius:8px;box-sizing:border-box}.date-section{margin-bottom:12px;width:100%}.date-label{display:block;font-size:12px;font-weight:500;color:#374151;margin-bottom:4px}.date-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box;max-width:100%;background:var(--color-background)}.date-picker-actions{display:flex;justify-content:space-between;gap:8px;margin-top:16px}.clear-btn{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:var(--color-card);color:#374151;cursor:pointer;font-size:14px}.apply-btn{padding:8px 16px;border:1px solid #3b82f6;border-radius:6px;background:#3b82f6;color:#fff;cursor:pointer;font-size:14px}.clear-btn:hover{background:#f9fafb}.apply-btn:hover{background:#2563eb}.filter-dropdown-bubble{position:relative;z-index:100}.filter-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:var(--color-card);cursor:pointer;transition:all .2s;min-width:140px;font-size:14px;color:#374151}.filter-trigger:hover{border-color:#9ca3af;background:#f9fafb}.filter-display{flex:1;text-align:left}.filter-bubble{position:absolute;top:100%;left:0;margin-top:8px;background:var(--color-card);border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:1000;min-width:160px;overflow:hidden}.filter-bubble .bubble-arrow{position:absolute;top:-6px;left:20px;width:12px;height:12px;background:var(--color-card);border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.filter-options{padding:8px}.filter-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151}.filter-option:hover{background:#f3f4f6}.filter-option.selected{background:#eff6ff;color:#1d4ed8}.status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-indicator.all{background:#6b7280}.status-indicator.active{background:#10b981}.status-indicator.inactive{background:#ef4444}.department-dropdown-bubble{position:relative}.department-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:var(--color-card);cursor:pointer;transition:all .2s;min-width:160px;font-size:14px;color:#374151}.department-trigger:hover{border-color:#9ca3af;background:#f9fafb}.department-display{flex:1;text-align:left}.department-bubble{position:absolute;top:100%;left:0;margin-top:8px;background:var(--color-card);border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;min-width:180px;max-height:300px;overflow-y:auto;overflow:hidden}.department-bubble .bubble-arrow{position:absolute;top:-6px;left:20px;width:12px;height:12px;background:var(--color-card);border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.department-options{padding:8px;background:var(--color-card);border-radius:8px}.department-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151}.department-option:hover{background:#f3f4f6}.department-option.selected{background:#eff6ff;color:#1d4ed8}.role-dropdown-bubble{position:relative}.role-trigger{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:var(--color-card);cursor:pointer;transition:all .2s;min-width:140px;font-size:14px;color:#374151}.role-trigger:hover{border-color:#9ca3af;background:#f9fafb}.role-display{flex:1;text-align:left}.role-bubble{position:absolute;top:100%;left:0;margin-top:8px;background:var(--color-card);border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:50;min-width:160px;overflow:hidden}.role-bubble .bubble-arrow{position:absolute;top:-6px;left:20px;width:12px;height:12px;background:var(--color-card);border-left:1px solid #e5e7eb;border-top:1px solid #e5e7eb;transform:rotate(45deg)}.role-options{padding:8px;background:var(--color-card);border-radius:8px}.role-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:#374151}.role-option:hover{background:#f3f4f6}.role-option.selected{background:#eff6ff;color:#1d4ed8}.chevron{transition:transform .2s}.chevron.open{transform:rotate(180deg)}.filters-section{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.status-dropdown-bubble,.department-dropdown-bubble,.role-dropdown-bubble,.date-range-picker{position:relative}.employees-table-container{background:var(--color-card);border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;margin:.5rem 2rem}.table-header{padding:.8rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.table-count{color:#64748b;font-weight:500}.table-wrapper{overflow-x:auto}.employees-table{width:100%;border-collapse:collapse;table-layout:fixed}.employees-table th:nth-child(1),.employees-table td:nth-child(1){width:120px;min-width:120px}.employees-table th:nth-child(2),.employees-table td:nth-child(2){width:250px;min-width:220px}.employees-table th:nth-child(3),.employees-table td:nth-child(3){width:120px;min-width:120px}.employees-table th:nth-child(4),.employees-table td:nth-child(4){width:250px;min-width:250px}.employees-table th:nth-child(5),.employees-table td:nth-child(5){width:150px;min-width:150px}.employees-table th:nth-child(6),.employees-table td:nth-child(6){width:100px;min-width:100px}.employees-table th:nth-child(7),.employees-table td:nth-child(7){width:140px;min-width:140px}.employees-table th:nth-child(8),.employees-table td:nth-child(8){width:150px;min-width:150px}.employees-table th:nth-child(9),.employees-table td:nth-child(9){width:100px;min-width:100px}.employees-table th:nth-child(10),.employees-table td:nth-child(10){width:120px;min-width:120px}.employees-table th:nth-child(11),.employees-table td:nth-child(11){width:120px;min-width:120px}.employees-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.employees-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employees-table tr:hover{background:#f8fafc}.employee-id{font-weight:600;color:#667eea}.employee-name-avatar{display:flex;align-items:center;gap:.75rem}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.75rem}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.full-name{font-weight:600;color:#1e293b}.employee-position{font-size:.875rem;color:#64748b}.role-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin{background:#e0e7ff;color:#3730a3}.role-badge.principal{background:#d1fae5;color:#065f46}.employee-department,.employee-position{font-weight:500;color:#374151}.profile-upload{margin-bottom:1rem}.profile-upload-control{display:flex;align-items:center;gap:1rem}.profile-preview{width:56px;height:56px;border-radius:50%;overflow:hidden;border:2px solid #e5e7eb;background:#f8fafc;display:flex;align-items:center;justify-content:center}.profile-preview img{width:100%;height:100%;object-fit:cover;display:block}.actions{text-align:center}.action-buttons{display:flex;gap:.5rem;justify-content:center}.btn-icon{padding:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid var(--color-border)}.btn-icon.view{background:#e0e7ff;color:#3730a3}.btn-icon.delete{background:#fee2e2;color:#dc2626}.status-toggle{border:none;background:none;cursor:pointer;padding:0}.empty-state{text-align:center;padding:4rem 2rem;color:#64748b}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#374151;margin-bottom:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-card);border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.modal-header{padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:#fff;font-size:1.5rem}.employee-form{flex:1;overflow-y:auto;max-height:calc(90vh - 200px);padding:0 1rem 1rem 0}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b;padding:.25rem}.close-button:hover{color:#374151}.employee-form{padding:2rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:#374151;font-size:.875rem}.form-input{padding:1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#f8fafc;width:100%;transition:border-color .3s ease}.form-input:focus{outline:none;border-color:#667eea;background:#fff}.form-input:disabled{opacity:.7;cursor:not-allowed}.phone-input .PhoneInputInput{padding:1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#f8fafc;width:100%}.phone-input .PhoneInputInput:focus{outline:none;border-color:#667eea;background:#fff}.phone-input .PhoneInputCountry{padding:1rem;border:2px solid #e5e7eb;border-radius:8px;margin-right:.5rem;background:#f8fafc}.optional-text{color:#6b7280;font-size:.8rem;font-weight:400;font-style:italic}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #e5e7eb}.btn-cancel{background:#fff;color:#374151;border:2px solid #e5e7eb;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel:hover{border-color:#64748b}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.react-select__control{border:2px solid #e5e7eb!important;border-radius:8px!important;background:#f8fafc!important;min-height:48px!important}.react-select__control:hover{border-color:#667eea!important}.react-select__control--is-focused{border-color:#667eea!important;box-shadow:0 0 0 3px #667eea1a!important}.react-select__menu{z-index:9999!important}.react-select__option--is-focused{background-color:#e0e7ff!important}.react-select__option--is-selected{background-color:#667eea!important;color:#fff!important}.react-select__input input{color:#374151!important}.react-select__value-container{padding:0 8px!important}.react-select__single-value{color:#374151!important}.react-select__placeholder{color:#9ca3af!important}.react-select__multi-value{background:#e0e7ff!important;border-radius:6px!important}.react-select__multi-value__label{color:#3730a3!important;font-weight:500!important}.react-select__multi-value__remove{color:#3730a3!important}.react-select__multi-value__remove:hover{background:#c7d2fe!important;color:#1e1b4b!important}@media(max-width:768px){.employees-container{padding:1rem}.employees-header-content{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.filters-section{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column}.form-grid{grid-template-columns:1fr}.employees-table{min-width:1000px}.date-picker-bubble{right:-50px;min-width:260px}.bubble-arrow{right:70px}.status-bubble,.department-bubble,.role-bubble{left:-50px}.status-bubble .bubble-arrow,.department-bubble .bubble-arrow,.role-bubble .bubble-arrow{left:70px}.stats-section{margin:1rem 1rem 2rem;grid-template-columns:1fr}.employees-table-container{margin:.5rem 1rem}}@media(max-width:480px){.header-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}.filters-section{gap:.5rem}.status-trigger,.department-trigger,.role-trigger,.date-range-trigger{min-width:120px;font-size:12px}}.library-page{display:flex;flex-direction:column;gap:16px;padding:10px 20px}.library-hero{background:linear-gradient(135deg,#471b08,#a04823);color:#e2e8f0;border-radius:16px;padding:20px 24px;display:grid;gap:16px;align-items:center}.library-hero-left{display:flex;justify-content:space-between;align-items:center}.hero-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:12px;margin:0;opacity:.8}.hero-title{font-size:28px;margin:0;color:#fff;font-weight:800;letter-spacing:-.02em}.hero-subtitle{margin:0;max-width:560px;color:#cbd5e1}.library-hero-actions{display:flex;flex-direction:row;gap:10px;flex-wrap:wrap}.library-hero-actions .btn_primary,.library-hero-actions .btn-secondary{display:inline-flex;align-items:center;gap:8px}.resources-actions{display:flex;gap:10px}.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.stat-card{background:#ffffff14;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stat-label{font-size:12px;color:#cbd5e1}.stat-value{font-size:24px;font-weight:800;color:#fff}.stat-foot{font-size:12px;color:#cbd5e1}.library-filters{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;align-items:center}.filter-item{display:inline-flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:8px 10px}.filter-item select,.filter-item input{border:none;background:transparent;outline:none;width:100%;font-size:14px;color:#0f172a}.filter-item.search{grid-column:span 2}.filter-item svg{color:#475569}@media(max-width:960px){.library-hero{grid-template-columns:1fr}.filter-item.search{grid-column:span 1}}@media(max-width:640px){.library-filters{grid-template-columns:1fr}.hero-actions{flex-direction:column}.hero-actions .btn_primary,.hero-actions .btn-secondary{width:100%;justify-content:center}}.resources-section{background:#f8fafc;border-radius:12px;padding:16px}.resources-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.resources-header-content{display:flex;align-items:baseline;gap:8px}.resources-title{font-size:20px;margin:0}.resources-count{color:#64748b;font-size:14px}.resources-actions .res-btn{display:inline-flex;align-items:center;gap:6px}.resources-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.res-table{width:100%;border-collapse:collapse}.res-table th,.res-table td{padding:12px 14px;text-align:left;border-bottom:1px solid #e2e8f0}.res-table th{background:#f1f5f9;font-weight:600;color:#334155}.res-table tbody tr:hover{background:#f8fafc}.res-actions{display:flex;gap:8px}.res-btn{border:none;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600;transition:all .15s ease}.res-btn-primary{background:#2563eb;color:#fff}.res-btn-primary:hover{background:#1d4ed8}.res-btn-secondary{background:#e2e8f0;color:#0f172a}.res-btn-secondary:hover{background:#cbd5e1}.res-error{background:#fef2f2;border:1px solid #fecdd3;color:#b91c1c;padding:10px 12px;border-radius:8px;margin-bottom:12px}.res-loading,.res-empty{text-align:center;padding:32px 16px;color:#475569}.res-empty h3{margin:8px 0 4px}.res-empty p{margin:0 0 12px;color:#64748b}.res-spinner{width:28px;height:28px;border-radius:50%;border:3px solid #cbd5e1;border-top-color:#2563eb;margin:0 auto 10px;animation:res-spin .8s linear infinite}.res-modal-overlay{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;animation:fadeIn .2s ease-out}.res-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(229,231,235,.8)}.res-modal-header{padding:1.5rem;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid rgba(229,231,235,.6)}.res-modal-header h3{margin:0;font-size:1.5rem;font-weight:700;color:#111827;line-height:1.2}.res-modal-close{background:none;border:none;font-size:1.75rem;cursor:pointer;color:#6b7280;padding:.25rem .5rem;border-radius:6px;line-height:1;transition:all .2s ease;margin:-.5rem -.5rem -.5rem 0}.res-modal-close:hover{background-color:#f3f4f6;color:#374151;transform:rotate(90deg)}.res-modal-body{padding:1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.res-form-group{display:flex;flex-direction:column;gap:.5rem}.res-form-group label{font-size:.875rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:.375rem}.res-form-group label:after{content:"";height:4px;width:4px;background:#ef4444;border-radius:50%;opacity:0;transition:opacity .2s}.res-form-group input:required+label:after{opacity:1}.res-form-group input,.res-form-group select,.res-form-group textarea{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.9375rem;transition:all .2s ease;background:#fff;color:#111827}.res-form-group input:focus,.res-form-group select:focus,.res-form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;transform:translateY(-1px)}.res-form-group input:hover,.res-form-group select:hover{border-color:#d1d5db}.res-form-group textarea{resize:vertical;min-height:80px;line-height:1.5;font-family:inherit}.res-source-options{display:flex;gap:1.5rem;padding:.5rem 0}.res-source-options label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#4b5563;cursor:pointer;padding:.5rem 1rem;border-radius:8px;transition:all .2s ease;border:2px solid transparent}.res-source-options label:hover{background-color:#f9fafb;color:#111827}.res-source-options input[type=radio]{width:18px;height:18px;margin:0;accent-color:#3b82f6;cursor:pointer}.res-source-options label:has(input:checked){background-color:#eff6ff;color:#1d4ed8;border-color:#3b82f6}.muted-text.small-text{font-size:.8125rem;color:#6b7280;margin-top:.375rem;font-style:italic}input[type=file]{padding:1rem;border:2px dashed #d1d5db;border-radius:10px;background-color:#f9fafb;cursor:pointer;transition:all .2s ease}input[type=file]:hover{border-color:#9ca3af;background-color:#f3f4f6}input[type=file]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.res-dropdown{position:relative}.res-dropdown-trigger{width:100%;border:2px solid #e5e7eb;border-radius:10px;background:#fff;padding:.65rem .85rem;display:inline-flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.95rem;font-weight:600;color:#0f172a;transition:all .15s ease}.res-dropdown-trigger:hover{border-color:#d1d5db}.res-dropdown-trigger:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.res-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 16px 40px #0f172a1f;z-index:20;max-height:220px;overflow-y:auto}.res-dropdown-option{width:100%;text-align:left;border:none;background:transparent;padding:10px 12px;display:flex;align-items:center;gap:8px;font-size:.95rem;cursor:pointer}.res-dropdown-option:hover{background:#f8fafc}.res-dropdown-option.active{background:#eef2ff;color:#312e81}.res-dropdown-check{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:#1d4ed8}.res-modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(229,231,235,.6);margin-top:auto}.res-btn{padding:.75rem 1.5rem;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.res-btn:disabled{opacity:.6;cursor:not-allowed}.res-btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 2px 10px #3b82f64d}.res-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #3b82f666}.res-btn-primary:active:not(:disabled){transform:translateY(0)}.res-btn-secondary{background-color:#fff;color:#374151;border:2px solid #e5e7eb}.res-btn-secondary:hover{background-color:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.res-modal-body::-webkit-scrollbar{width:6px}.res-modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.res-modal-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.res-modal-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:640px){.res-modal{max-height:85vh}.res-modal-header{padding:1.25rem}.res-modal-body{padding:1.25rem;gap:1.25rem}.res-grid{grid-template-columns:1fr;gap:1rem}.res-modal-actions{flex-direction:column-reverse}.res-btn{width:100%}}@media(prefers-color-scheme:dark){.res-modal{background:#1f2937;border-color:#374151}.res-modal-header h3{color:#f9fafb}.res-modal-close{color:#9ca3af}.res-modal-close:hover{background-color:#374151;color:#f9fafb}.res-form-group label{color:#e5e7eb}.res-form-group input,.res-form-group select,.res-form-group textarea{background:#111827;border-color:#4b5563;color:#f9fafb}.res-form-group input::placeholder,.res-form-group textarea::placeholder{color:#9ca3af}.res-form-group input:focus,.res-form-group select:focus,.res-form-group textarea:focus{border-color:#3b82f6}.res-source-options label{color:#d1d5db}.res-source-options label:hover{background-color:#374151;color:#f9fafb}.res-source-options label:has(input:checked){background-color:#1e40af;color:#93c5fd}input[type=file]{background-color:#374151;border-color:#4b5563}input[type=file]:hover{border-color:#6b7280;background-color:#4b5563}.res-btn-secondary{background-color:#374151;color:#e5e7eb;border-color:#4b5563}.res-btn-secondary:hover{background-color:#4b5563}.res-modal-body::-webkit-scrollbar-track{background:#374151}.res-modal-body::-webkit-scrollbar-thumb{background:#6b7280}}.res-source-options{display:flex;gap:16px;color:#0f172a}.subject-cell{display:flex;flex-direction:column;gap:4px}.subject-name{font-weight:600;color:#0f172a}.subject-meta .link-pill{display:inline-flex;padding:4px 8px;border-radius:999px;background:#e0f2fe;color:#0369a1;text-decoration:none;font-size:12px;border:none;cursor:pointer}.link-actions{display:inline-flex;gap:6px;flex-wrap:wrap}.link-pill.secondary{background:#eef2ff;color:#4338ca}.res-preview-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;justify-content:center;align-items:center;padding:16px;z-index:1300}.res-preview-modal{background:#fff;width:min(900px,100%);height:min(80vh,720px);border-radius:14px;box-shadow:0 16px 48px #0f172a40;display:flex;flex-direction:column;overflow:hidden}.res-preview-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e2e8f0}.res-preview-title{font-weight:700;color:#0f172a}.res-preview-body{flex:1;background:#0f172a}.res-preview-frame{width:100%;height:100%;border:none;background:#0f172a}.teacher-chip{background:#e2e8f0;color:#0f172a;border-radius:999px;padding:4px 10px;font-size:12px}.muted-text{color:#94a3b8}@media(max-width:640px){.resources-header{flex-direction:column;align-items:flex-start}.res-actions{flex-direction:column}.res-modal{max-height:95vh}.res-modal-body{padding-bottom:16px}.res-modal-actions{flex-direction:column-reverse;align-items:stretch}.res-grid{grid-template-columns:1fr}}.sequences-page{display:flex;flex-direction:column;gap:14px;padding:10px 20px}.seq-hero{display:grid;gap:12px;background:linear-gradient(135deg,#471b08,#a04823);color:#e2e8f0;padding:18px 20px;border-radius:14px;box-shadow:0 16px 40px #0f172a40}.seq-hero-head{display:flex;justify-content:space-between;align-items:center}.seq-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:18px;opacity:.85;color:#fff}.seq-title{margin:4px 0;font-size:26px;font-weight:800}.seq-subtitle{margin:0 0 8px;color:#cbd5e1}.seq-actions{display:flex;gap:8px;flex-wrap:wrap}.seq-actions .btn_primary,.seq-actions .btn-secondary{display:inline-flex;align-items:center;gap:6px}.seq-stat{background:#ffffff14;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:6px;align-items:flex-start}.seq-stat .stat-value{font-size:24px;font-weight:800;color:#fff}.seq-stat .stat-label{font-size:13px;color:#cbd5e1}.seq-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px}.seq-table{width:100%;border-collapse:collapse}.seq-table th,.seq-table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;text-align:left}.seq-table th{background:#f8fafc;font-weight:700;color:#334155}.seq-actions-row{display:flex;gap:8px}.seq-loading,.seq-empty{padding:20px;text-align:center;color:#475569}.seq-error{background:#fef2f2;border:1px solid #fecdd3;color:#b91c1c;padding:10px 12px;border-radius:8px}.seq-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.seq-modal{background:#fff;border-radius:14px;border:1px solid #e2e8f0;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 18px 40px #0f172a40}.seq-modal-header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:2}.seq-close{background:none;border:none;font-size:20px;cursor:pointer;color:#475569}.seq-form{display:grid;gap:12px;padding:14px 16px 70px;flex:1;overflow-y:auto;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.seq-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px}.seq-form input{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff}.seq-form select{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;width:100%}.seq-modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:10px 16px;border-top:1px solid #e2e8f0;position:sticky;bottom:0;background:#fff;z-index:2}.seq-hints{grid-column:1 / -1;padding:12px;background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1px solid #e0e7ff;border-radius:12px;color:#1e293b;font-size:13px}.seq-hint-title{font-weight:700;margin-bottom:6px}.seq-examples{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin:6px 0}.seq-example{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px}.seq-example-label{font-weight:600;font-size:12px;color:#475569}.seq-example-value{font-weight:800;font-size:14px;color:#0f172a}.seq-example-current{margin-top:8px;font-weight:700}@media(max-width:720px){.seq-hero{grid-template-columns:1fr}}.profile-container{margin:0 auto;padding:2rem;background:#f8fafc;min-height:100vh}.profile-page-header{border-radius:20px;margin-bottom:1rem;color:#fff;box-shadow:0 20px 40px #0000001a;color:#1e293b}.header-content{display:flex;align-items:center;gap:rem}.avatar-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.avatar-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary, #667eea),var(--color-accent, #764ba2));display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;border:3px solid rgba(255,255,255,.3)}.status-badge{display:flex;align-items:center;gap:.5rem;width:fit-content;padding:.25rem .75rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);font-size:14px}.status-badge.active{background-color:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.status-badge.inactive{background-color:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.status-dot{width:5px;height:5px;border-radius:50%;display:inline-block}.status-dot.active{background:#10b981!important;box-shadow:0 0 10px #10b98180}.status-dot.inactive{background:#ef4444!important;box-shadow:0 0 10px #ef444480}.profile-info{flex:1}.profile-name{font-size:var(--font-size-h3);font-weight:700}.profile-title{font-size:1rem;opacity:.9;margin:0 0 .5rem}.edit-button{padding:1rem 2rem;background:var(--color-primary);color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:12px;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.edit-button:hover{background:var(--color-primary);transform:translateY(-2px)}.edit-button.cancel{background:#ef444433;border-color:#ef444480}.edit-button.cancel:hover{background:#ef44444d}.profile-content{display:flex;flex-direction:column;gap:1rem}.profile-card{background:#fff;border-radius:20px;padding:1rem 2rem;box-shadow:0 10px 30px #00000014;border:1px solid #e2e8f0;transition:transform .3s ease,box-shadow .3s ease}.profile-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0000001f}.card-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.section-title{font-size:1.2rem;font-weight:700;color:#1e293b;margin:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.required-star{color:#ef4444;font-weight:700}.optional-text{color:#6b7280;font-size:.8rem;font-weight:400;text-transform:none}.form-input{padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#f8fafc}.form-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.form-value{padding:1rem;background:#f8fafc;border-radius:12px;margin:0;color:#374151;min-height:52px;display:flex;align-items:center}.email-display{color:#6b7280;font-style:italic}.phone-input{width:100%}.phone-input .PhoneInputInput{padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#f8fafc}.phone-input .PhoneInputInput:focus{outline:none;border-color:#3b82f6;background:#fff}.phone-input .PhoneInputCountry{padding:1rem;border:2px solid #e2e8f0;border-radius:12px;margin-right:.5rem;background:#f8fafc}.action-section{display:flex;gap:1rem;justify-content:flex-end;padding:2rem 0}.save-button{padding:1rem 2rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease}.save-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #10b9814d}.cancel-button{padding:1rem 2rem;border:2px solid #dc2626;background:#fff;color:#dc2626;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-button:hover{background:#dc2626;color:#fff;transform:translateY(-2px)}@media(max-width:768px){.profile-container{padding:1rem}.profile-page-header{padding:2rem 1rem}.header-content{flex-direction:column;text-align:center;gap:1rem}.form-grid{grid-template-columns:1fr}.action-section{flex-direction:column;width:100%}.avatar-circle{width:80px;height:80px;font-size:1.5rem}.profile-name{font-size:2rem}.edit-button{width:100%;text-align:center}}.Toastify__toast{border-radius:12px;font-weight:500}.Toastify__toast--success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.Toastify__toast--error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.session-dialog{background:#fff;border-radius:20px;width:90%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s cubic-bezier(.4,0,.2,1);border:1px solid #e2e8f0;display:flex;flex-direction:column}.dialog-header{background:var(--color-primary);color:#fff;padding:24px;display:flex;justify-content:space-between;align-items:flex-start;border-radius:20px 20px 0 0;position:relative;flex-shrink:0}.dialog-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.dialog-title{display:flex;color:#fff;align-items:flex-start;gap:12px;flex:1}.title-icon{background:#fff3;padding:8px;border-radius:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.dialog-title-content h2{margin:0;font-size:20px;font-weight:700;line-height:1.2}.dialog-title-content .title-subtitle{color:#fff;margin:4px 0 0;opacity:.9;font-size:14px;font-weight:400}.dialog-body{padding:24px;background:#f8fafc;overflow-y:auto;flex:1}.session-info-card{background:linear-gradient(135deg,#f0f4ff,#f8fafc);padding:20px;border-radius:16px;margin-bottom:24px;border:1px solid #e2e8f0;display:flex;align-items:flex-start;gap:16px;box-shadow:0 2px 8px #0000000d}.info-icon{background:var(--color-primary);color:#fff;padding:8px;border-radius:8px;flex-shrink:0}.info-content{flex:1;display:flex;flex-direction:column;gap:12px}.info-item{display:flex;justify-content:space-between;align-items:center}.info-label{font-weight:600;color:#374151;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.info-value{color:#1f2937;font-weight:500;font-size:14px;display:flex;align-items:center;gap:6px}.form-section{display:flex;flex-direction:column;gap:24px}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-weight:600;color:#374151;font-size:14px;display:flex;align-items:center;gap:8px}.form-select{padding:12px 40px 12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;transition:all .2s ease;background:#fff;width:100%;appearance:none;cursor:pointer;font-weight:500}.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-select:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.form-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;transition:all .2s ease;background:#fff;width:100%;font-weight:500}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder{color:#9ca3af}.error-message{color:#ef4444;font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px;margin-top:4px}.warning-message{color:#f59e0b;font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px;margin-top:4px;background:#fef3c7;padding:8px 12px;border-radius:8px;border-left:3px solid #f59e0b}.checkbox-group{margin-top:8px}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500;color:#374151;font-size:14px;padding:12px;border-radius:12px;transition:all .2s ease}.checkbox-label:hover{background:#f8fafc}.checkbox-input{display:none}.checkbox-custom{color:#667eea;transition:all .2s ease}.checkbox-input:checked+.checkbox-custom{color:#10b981}.checkbox-text{flex:1}.checkbox-warning{color:#6b7280;font-size:12px;margin-top:8px;padding:12px;background:#f3f4f6;border-radius:8px;border-left:3px solid #667eea;display:flex;align-items:center;gap:8px}.dialog-footer{padding:20px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:16px;background:#fff;border-radius:0 0 20px 20px;flex-shrink:0}.footer-left{flex:1}.footer-actions{display:flex;gap:12px}.btn_primary,.btn-secondary,.btn-destructive{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:120px;justify-content:center}.btn_primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.btn_primary:disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.btn_primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #10b98166}.btn-destructive{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-destructive:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ef444466}@media(max-width:768px){.session-dialog{max-width:95%;margin:10px}.form-row{flex-direction:column;gap:16px}.dialog-footer{flex-direction:column;align-items:stretch;gap:12px}.footer-actions{order:-1;justify-content:stretch}.footer-actions button{flex:1}.btn-destructive{order:1;width:100%;margin-top:8px}.footer-left{width:100%}}.dialog-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px}.modern-dialog{background:#fff;border-radius:20px;width:90%;max-width:800px;max-height:90vh;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s cubic-bezier(.4,0,.2,1);border:1px solid #e2e8f0;display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header.fixed-header{color:#fff;background:var(--color-primary);padding:24px;display:flex;justify-content:space-between;align-items:flex-start;border-radius:20px 20px 0 0;position:relative;flex-shrink:0;z-index:10}.dialog-header.fixed-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.dialog-title{display:flex;align-items:flex-start;gap:12px;flex:1}.dialog-title-icon-wrapper{background:#fff3;padding:8px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.dialog-title-content h2{margin:0;font-size:24px;font-weight:700;line-height:1.2;color:#fff}.dialog-title-subtitle{margin:4px 0 0;opacity:.9;font-size:14px;font-weight:400;color:#fff}.dialog-close{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px;border-radius:10px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.dialog-close:hover{background:#ffffff4d;transform:scale(1.05)}.dialog-body.scrollable-content{padding:24px;background:#f8fafc;overflow-y:auto;flex:1;max-height:calc(90vh - 160px)}.dialog-footer.fixed-footer{padding:20px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:12px;background:#fff;border-radius:0 0 20px 20px;flex-shrink:0;z-index:10}.period-controls,.period-drag-handle{display:none}.period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.period-type{display:flex;align-items:center;gap:12px}.type-icon-wrapper{background:var(--color-primary);color:#fff;padding:8px;border-radius:10px;box-shadow:0 2px 8px #667eea4d}.break-card .type-icon-wrapper{background:linear-gradient(135deg,#ef4444,#dc2626)}.period-label{font-weight:600;font-size:16px;color:#1f2937}.break-card .period-label{color:#991b1b}.info-card{background:linear-gradient(135deg,#f0f4ff,#f8fafc);padding:20px;border-radius:16px;margin-bottom:24px;border:1px solid #e2e8f0;display:flex;align-items:flex-start;gap:16px;box-shadow:0 2px 8px #0000000d}.info-icon-wrapper{background:#667eea;color:#fff;padding:8px;border-radius:10px;flex-shrink:0}.info-content{flex:1}.info-main{margin:0 0 8px;color:#374151;font-size:14px;line-height:1.5;font-weight:500}.info-note{margin:0;color:#6b7280;font-size:13px;line-height:1.4;border-top:1px solid #e5e7eb;padding-top:8px}.quick-actions{display:flex;gap:12px;margin-bottom:24px}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);flex:1;justify-content:center;box-shadow:0 2px 4px #0000001a}.action-btn.primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.action-btn.secondary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.action-btn:active{transform:translateY(0)}.periods-container{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.period-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.period-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.period-card.break-card{background:linear-gradient(135deg,#fef2f2,#fecaca);border-color:#fca5a5}.time-inputs{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.time-input-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}.time-input-group label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.select-wrapper{position:relative;display:flex;align-items:center}.time-select{padding:12px 40px 12px 16px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;font-size:14px;font-weight:500;width:100%;transition:all .2s ease;appearance:none;cursor:pointer}.time-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.break-card .time-select:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.select-icon{position:absolute;right:12px;color:#9ca3af;pointer-events:none}.time-separator{color:#6b7280;font-weight:600;padding:0 8px;font-size:14px}.break-settings{margin-bottom:16px}.toggle-wrapper{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;font-size:14px;color:#374151}.toggle-input{display:none}.toggle-slider{width:44px;height:24px;background:#d1d5db;border-radius:24px;position:relative;transition:all .3s ease}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .3s ease;box-shadow:0 1px 3px #0003}.toggle-input:checked+.toggle-slider{background:#10b981}.toggle-input:checked+.toggle-slider:before{transform:translate(20px)}.break-options{margin-top:16px;padding:16px;background:#fffc;border-radius:12px;display:flex;gap:16px;flex-wrap:wrap;border:1px solid #e5e7eb}.break-option{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}.break-option label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.break-select{padding:12px 40px 12px 16px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;font-size:14px;width:100%;transition:all .2s ease;appearance:none;cursor:pointer}.break-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-wrapper{position:relative}.break_input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;font-size:14px;transition:all .2s ease}.break-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.remove-btn{position:absolute;top:16px;right:16px;background:#ef4444;color:#fff;border:none;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #ef44444d}.remove-btn:hover:not(:disabled){background:#dc2626;transform:scale(1.1)}.remove-btn:disabled{background:#d1d5db;cursor:not-allowed;box-shadow:none}.schedule-preview{background:#fff;padding:20px;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.preview-title{margin:0 0 16px;color:#1f2937;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.preview-list{display:flex;flex-direction:column;gap:8px}.preview-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:500;transition:all .2s ease}.preview-item.period{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:4px solid #0ea5e9;color:#0369a1}.preview-item.break{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-left:4px solid #ef4444;color:#dc2626}.preview-time{font-weight:600;font-size:13px}.preview-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:120px;justify-content:center}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.btn-secondary{background:#6b7280;color:#fff;box-shadow:0 2px 8px #6b72804d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b98166}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6b728066;background:#4b5563}.empty-state{text-align:center;padding:60px 40px;background:#fff;border-radius:16px;border:2px dashed #d1d5db}.empty-icon{color:#9ca3af;margin-bottom:16px}.empty-title{margin:0 0 8px;color:#374151;font-size:18px;font-weight:600}.empty-hint{margin:0;color:#6b7280;font-size:14px}@media(max-width:768px){.dialog-overlay{padding:10px}.time-inputs{flex-direction:column;align-items:stretch}.time-separator{text-align:center;padding:8px 0}.break-options{flex-direction:column}.dialog-footer.fixed-footer{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.timetable-container{height:100%;display:flex;flex-direction:column}.timetable-glass{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 8px 32px #0000001a;overflow:hidden;display:flex;flex-direction:column;height:100%}.timetable-header{background:#fff;padding:15px 24px;display:flex;justify-content:space-between;align-items:center}.timetable-header-content h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#2d3748;font-size:20px}.timetable-header-subtitle{color:#718096;font-size:14px;font-weight:500}.header-actions{display:flex;gap:12px}.btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s ease}.btn_primary{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.btn_secondary{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.timetable-content{flex:1;overflow:auto;padding:12px}.timetable-grid{display:flex;flex-direction:column;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;background:#fff}.grid-header{display:grid;grid-template-columns:150px repeat(7,1fr);background:var(--color-primary);color:#fff}.time-column-header{padding:16px 12px;text-align:center;font-weight:600;font-size:14px;border-right:1px solid rgba(255,255,255,.2)}.day-column-header{padding:16px 12px;text-align:center;font-weight:600;font-size:14px;border-right:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;gap:4px}.day-name{font-size:12px;opacity:.9}.day-short{font-size:10px;opacity:.7}.time-period-row{display:grid;grid-template-columns:150px repeat(7,1fr);border-bottom:1px solid #e2e8f0}.time-period-row:last-child{border-bottom:none}.time-slot-header{padding:12px;border-right:1px solid #e2e8f0;background:#f7fafc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.time-slot-header.break-header{background:#fff5f5;color:#c53030}.time-range{font-weight:600;font-size:12px;color:#2d3748}.break-header .time-range{color:#c53030}.break-indicator{font-size:10px;font-weight:500;color:#e53e3e;background:#f565651a;padding:2px 6px;border-radius:4px}.timetable-cell{padding:8px;border-right:1px solid #e2e8f0;min-height:80px;cursor:pointer;transition:all .3s ease;position:relative;background:#fafafa}.timetable-cell:last-child{border-right:none}.timetable-cell.break-cell{background:linear-gradient(135deg,#fed7d7,#feb2b2);border-left:4px solid #f56565;color:#742a2a}.timetable-cell.session-cell{background:#fff;border-left:4px solid #48bb78}.timetable-cell.empty-cell{background:#f7fafc}.timetable-cell.cell-hovered{background:#edf2f7;box-shadow:inset 0 0 0 2px #cbd5e0;z-index:2}.break-cell:hover{background:linear-gradient(135deg,#feb2b2,#fc8181)}.session-cell:hover{background:#f0fff4;transform:scale(1.02);box-shadow:0 4px 12px #00000026;z-index:3}.empty-cell:hover{background:#e2e8f0}.break-content{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.break-icon{font-size:16px}.break-label{font-weight:600;font-size:11px;text-align:center}.session-content{height:100%;display:flex;flex-direction:column;justify-content:center;gap:4px}.session-subject{font-weight:600;font-size:12px;color:#2d3748;line-height:1.2}.session-teacher{font-size:11px;color:#718096}.session-topic{font-size:10px;color:#48bb78;font-style:italic;background:#f0fff4;padding:2px 6px;border-radius:4px;display:inline-block}.empty-content{height:100%;display:flex;align-items:center;justify-content:center}.add-session-prompt{display:flex;flex-direction:column;align-items:center;gap:6px;color:#718096;font-size:11px;font-weight:500;animation:fadeIn .3s ease}.add-icon{background:#48bb78;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.timetable-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #4c51bf;border-radius:50%;animation:spin 1s linear infinite}.snackbar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:16px 24px;border-radius:8px;color:#fff;font-weight:500;box-shadow:0 4px 20px #00000026;z-index:1000;min-width:300px;text-align:center;animation:slideUpSnackbar .3s ease}@keyframes slideUpSnackbar{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.snackbar-success{background:linear-gradient(135deg,#48bb78,#38a169)}.snackbar-error{background:linear-gradient(135deg,#f56565,#e53e3e)}.snackbar-info{background:linear-gradient(135deg,#4299e1,#3182ce)}.snackbar-content{display:flex;align-items:center;justify-content:center;gap:8px}@media(max-width:1200px){.timetable-container{padding:10px}.timetable-content{padding:16px}}@media(max-width:768px){.timetable-header{flex-direction:column;gap:16px;text-align:center}.header-actions{width:100%;justify-content:center}.grid-header,.time-period-row{grid-template-columns:100px repeat(7,1fr)}.time-slot-header{padding:8px 4px}.time-range{font-size:10px}.break-indicator{font-size:8px}}.schedule_page,.schedule-page{display:flex;flex-direction:column;gap:16px;height:89vh;overflow:hidden;padding:10px 20px}.schedule-hero{display:grid;gap:16px;background:linear-gradient(135deg,#471b08,#a04823);color:#e2e8f0;padding:20px 24px;border-radius:16px;box-shadow:0 20px 50px #0f172a59}.hero-copy{display:flex;justify-content:space-between;align-items:center}.hero-copy .title{color:#fff}.hero-copy .kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:12px;opacity:.8}.hero-copy .title{margin:4px 0;font-size:28px;font-weight:800;letter-spacing:-.02em}.hero-copy .subtitle{margin:0 0 12px;color:#cbd5e1}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.hero-actions .btn_primary{display:inline-flex;align-items:center;gap:8px}.hero-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;align-items:stretch}.metric-card{background:#ffffff14;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;display:flex;gap:10px;align-items:center}.metric-card .metric-value{font-size:22px;font-weight:800;color:#fff}.metric-card .metric-label{font-size:13px;color:#cbd5e1}.schedule-layout{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:stretch;height:calc(100vh - 220px);overflow:hidden}.group-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;display:flex;flex-direction:column;gap:8px;position:sticky;top:12px;max-height:calc(100vh - 120px);overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center}.panel-header h3{font-size:18px}.panel-count{font-size:13px;background-color:#c1711c59;padding:2px 8px;border-radius:10px}.group-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;height:calc(100vh - 210px)}.group-pill{width:100%;text-align:left;border:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;padding:10px 12px;cursor:pointer;transition:all .15s ease}.group-pill .pill-name{font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-pill .pill-meta{font-size:12px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-pill:hover{border-color:#cbd5e1}.group-pill.active{border-color:#2563eb;background:#eef2ff;box-shadow:0 4px 18px #2563eb26}.panel-loading,.panel-empty,.panel-error{padding:10px;color:#475569;font-size:14px}.panel-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecdd3;border-radius:8px}.schedule-content{min-height:480px;position:relative;height:100%;overflow:hidden}.schedule-empty{background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:32px;text-align:center;color:#475569}.schedule-content-wrapper{position:relative;height:100%;overflow:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.schedule-overlay{position:absolute;inset:0;background:#ffffffa6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:10}.overlay-spinner{width:28px;height:28px;border-radius:50%;border:3px solid #cbd5e1;border-top-color:#2563eb;animation:res-spin .8s linear infinite}@keyframes res-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.schedule-layout{grid-template-columns:1fr}.group-panel{max-height:280px}}@media(max-width:720px){.schedule-hero{grid-template-columns:1fr}}.attendance-shell{display:flex;flex-direction:column;gap:16px;background:var(--color-bg);color:var(--color-text-primary);padding:20px;border-radius:16px}.attendance-hero{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.08),rgba(var(--color-primary-rgb),.02));border:1px solid var(--color-border);padding:16px;border-radius:14px;box-shadow:var(--shadow-card)}.attendance-kicker{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);font-size:12px;margin:0}.attendance-title{font-size:22px;margin:4px 0;color:var(--color-text-primary)}.attendance-subtitle{margin:0;color:var(--color-text-secondary);font-size:14px}.attendance-stats{display:flex;gap:10px;align-items:stretch}.attendance-stat-card{background:var(--color-card);border:1px solid var(--color-border);padding:10px 12px;border-radius:12px;min-width:110px;box-shadow:var(--shadow-card)}.attendance-stat-label{margin:0;color:var(--color-text-secondary);font-size:12px}.attendance-stat-value{margin:2px 0 0;font-size:20px;color:var(--color-text-primary);font-weight:600}.attendance-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.attendance-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-card)}.attendance-card-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.attendance-card-row.space{gap:20px}.attendance-day{margin:0;font-weight:600;color:var(--color-text-primary)}.attendance-time{margin:2px 0 0;color:var(--color-text-secondary);font-size:13px}.attendance-badge{background:rgba(var(--color-primary-rgb),.08);color:var(--color-primary);padding:6px 10px;border-radius:999px;font-size:12px;border:1px solid rgba(var(--color-primary-rgb),.2)}.attendance-label{margin:0;color:var(--color-text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.attendance-value{margin:2px 0 0;color:var(--color-text-primary);font-weight:600}.attendance-btn{border:none;cursor:pointer;font-weight:600;border-radius:12px;padding:12px 14px;transition:transform .1s ease,box-shadow .1s ease,background .2s ease}.attendance-btn.full{width:100%}.attendance-btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;box-shadow:0 10px 30px rgba(var(--color-primary-rgb),.25)}.attendance-btn-primary:hover{transform:translateY(-1px)}.attendance-btn-secondary{background:var(--color-card);color:var(--color-text-primary);border:1px solid var(--color-border)}.attendance-loading,.attendance-error,.attendance-empty{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;padding:20px;text-align:center;box-shadow:var(--shadow-card)}.attendance-spinner{width:32px;height:32px;border:3px solid rgba(var(--color-primary-rgb),.12);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto 8px;animation:attendance-spin 1s linear infinite}@keyframes attendance-spin{to{transform:rotate(360deg)}}.attendance-empty-icon{font-size:28px;margin-bottom:8px}.attendance-muted{color:var(--color-text-secondary);margin:4px 0 0;font-size:13px}.attendance-error-message{color:var(--color-error);margin:0 0 10px}.attendance-modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:20px;z-index:30}.attendance-modal{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;width:min(900px,100%);max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 12px 40px rgba(var(--color-primary-rgb),.15)}.attendance-modal-header{display:flex;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border);align-items:center}.attendance-modal-title{margin:4px 0;color:var(--color-text-primary)}.attendance-modal-close{border:none;background:var(--color-card);color:var(--color-text-secondary);border:1px solid var(--color-border);width:32px;height:32px;border-radius:10px;cursor:pointer}.attendance-modal-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.attendance-student-list{display:flex;flex-direction:column;gap:10px}.attendance-student-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;border-radius:12px;background:var(--color-card-hover);border:1px solid var(--color-border)}.attendance-student-name{margin:0;color:var(--color-text-primary)}.attendance-status-pills{display:grid;grid-auto-flow:column;gap:8px}.attendance-pill{background:var(--color-card);color:var(--color-text-primary);border:1px solid var(--color-border);padding:8px 10px;border-radius:999px;cursor:pointer;font-size:12px;transition:all .15s ease}.attendance-pill.active{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-color:transparent;color:#fff;box-shadow:0 10px 25px rgba(var(--color-primary-rgb),.2)}.attendance-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:0 16px 12px}@media(max-width:640px){.attendance-hero{flex-direction:column}.attendance-stats{width:100%}.attendance-student-row{flex-direction:column;align-items:flex-start}.attendance-status-pills{grid-auto-flow:row;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));width:100%}}.homework-section{display:flex;flex-direction:column;gap:16px}.homework-header{display:flex;justify-content:space-between;align-items:center}.homework-header-content{display:flex;align-items:center;gap:10px}.homework-title{margin:0;font-size:20px;font-weight:700}.homework-count{color:#6b7280;font-size:14px}.homework-actions{display:flex;gap:10px}.hw-btn{border:none;border-radius:8px;padding:10px 16px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.hw-btn-primary{background:#3b82f6;color:#fff}.hw-btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.homework-table-container{border:1px solid #e5e7eb;border-radius:10px;overflow-x:auto;background:#fff}.hw-table{width:100%;border-collapse:collapse;min-width:700px}.hw-table th{padding:14px 12px;background:#f8fafc;text-align:left;font-weight:700;color:#374151;font-size:14px}.hw-table td{padding:14px 12px;border-top:1px solid #f1f5f9;color:#1f2937;font-size:14px}.hw-empty{text-align:center;padding:60px 20px}.hw-empty-icon{font-size:42px;margin-bottom:12px}.hw-status{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;background:#eff6ff;color:#1d4ed8}.hw-actions{display:flex;gap:8px}.hw-score-input{width:80px;border:1px solid #d1d5db;border-radius:6px;padding:6px 8px}.hw-score-cell{display:inline-flex;align-items:center;gap:6px}.hw-score-select{border:1px solid #d1d5db;border-radius:6px;padding:6px 10px;min-width:64px}.hw-icon-btn{border:1px solid #d1d5db;background:#f8fafc;border-radius:6px;padding:6px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.hw-icon-btn:hover:not(:disabled){background:#e5e7eb}.hw-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.hw-modal{background:#fff;border-radius:12px;width:100%;max-width:640px;max-height:92vh;box-shadow:0 12px 40px #0000001f;display:flex;flex-direction:column;overflow:hidden}.hw-modal-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:1}.hw-modal-header h3{margin:0;font-size:18px}.hw-modal-close{background:transparent;border:none;font-size:22px;cursor:pointer}.hw-modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.hw-form-group{display:flex;flex-direction:column;gap:6px}.attachments{border:1px dashed #d1d5db;border-radius:10px;padding:10px;background:#f8fafc}.attachments-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.attachments-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.attachment-row{display:grid;grid-template-columns:1fr;gap:8px;align-items:center}.attachments-hint{margin:0;font-size:13px;color:#6b7280}.attachment-actions{display:flex;gap:8px;align-items:center}.attachment-actions-inline{display:flex;flex-wrap:wrap;gap:8px}.attachment-label{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;background:#f8fafc;font-size:14px;color:#111827}.hw-btn.danger{border:1px solid #dc2626;color:#dc2626;background:#fff5f5}.hw-form-group input,.hw-form-group select,.hw-form-group textarea{border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:14px}.hw-form-row{display:flex;align-items:center;gap:12px}.hw-checkbox{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#111827}.hw-max-score{width:140px}.hw-modal-actions{padding:14px 20px 18px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #e5e7eb;position:sticky;bottom:0;background:#fff}.hw-loading,.hw-error{text-align:center;padding:60px 20px}.hw-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}.hw-error-message{color:#dc2626;margin-bottom:12px;font-weight:600}@media(max-width:640px){.hw-modal{max-height:95vh}.hw-modal-body,.hw-modal-header,.hw-modal-actions{padding:12px 16px}}.group-students-section{overflow:hidden}.group-students-header{display:flex;justify-content:space-between}.group-students-header-content{display:flex;align-items:center;gap:12px;justify-content:center;margin:auto 0}.group-students-section-title{font-size:20px;font-weight:700;color:#1a1d21;margin:0}.group-students-count{color:#6b7280;font-size:14px;font-weight:500}.bulk-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#eff6ff;border-bottom:1px solid #dbeafe;margin-top:10px;border-radius:10px}.group-students-table-container{overflow-x:auto;border-radius:5px;margin-top:10px}.group-students-table{width:100%;border-collapse:collapse;min-width:800px;border:1px solid var(--color-border)}.group-students-table th{background:#f8fafc;padding:16px 12px;text-align:left;font-weight:600;color:#374151;font-size:14px;border-bottom:1px solid #e5e7eb}.group-students-table td{padding:16px 12px;border-bottom:1px solid #f3f4f6;vertical-align:middle}.group-students-table tr:hover{background:#f9fafb}.group-students-table tr.selected{background:#eff6ff}.student-id-column{min-width:120px}.status-column{min-width:100px}.student-name{font-weight:500;color:#1f2937}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#166534}.actions-container{display:flex;gap:10px}.action_btn{background:#e8f5e8;color:var(--color-success);border:1px solid var(--color-success);padding:5px 10px;border-radius:10px}.action_btn:hover{cursor:pointer}.action_btn.danger{color:var(--color-error);border-color:1px solid var(--color-error);background-color:var(--color-error-bg)}.action_btn.danger:hover{cursor:pointer}.empty_state{text-align:center;padding:60px 24px;color:#6b7280;display:flex;justify-content:center;align-items:center;flex-direction:column}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:640px;box-shadow:0 12px 40px #0000001f;overflow:hidden}.modal-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb}.modal-close{background:transparent;border:none;font-size:22px;cursor:pointer}.modal-body{padding:16px 20px}.candidate-list{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.candidate-row{border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;display:grid;grid-template-columns:auto 1fr;column-gap:10px;align-items:center;cursor:pointer}.candidate-row.selected{border-color:#3b82f6;background:#eff6ff}.candidate-info{display:flex;flex-direction:column;gap:4px}.candidate-name{font-weight:600;color:#111827}.candidate-meta{display:flex;gap:10px;color:#6b7280;font-size:13px}.modal-actions{padding:14px 20px 18px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #e5e7eb}@media(max-width:768px){.students-header{flex-direction:column;gap:16px;align-items:stretch}.header-content{justify-content:center}.bulk-actions-bar{flex-direction:column;gap:12px;align-items:stretch}.bulk-actions-buttons{justify-content:center;flex-wrap:wrap}}.subjects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.subjects-header-content{display:flex;align-items:center;gap:12px}.subjects-section-title{font-size:24px;font-weight:700;color:#1a1d21;margin:0}.subjects-count{color:#6b7280;font-size:14px;font-weight:500;background:#f3f4f6;padding:4px 8px;border-radius:6px}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;font-size:14px;box-shadow:0 2px 4px #3b82f633}.btn-primary:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:14px}.btn-secondary:hover{background:#e5e7eb;border-color:#9ca3af;transform:translateY(-1px)}.bulk-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #dbeafe;margin-bottom:20px;border-radius:10px;box-shadow:0 2px 8px #2563eb1a}.bulk-actions-info{font-weight:600;color:#1e40af;display:flex;align-items:center;gap:8px}.selected-count{font-size:14px;font-weight:700}.subjects-table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 4px 6px -1px #0000001a;margin-top:10px}.subjects-table{width:100%;border-collapse:collapse;min-width:1000px;font-size:14px}.subjects-table th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:18px 16px;text-align:left;font-weight:700;color:#374151;font-size:14px;border-bottom:2px solid #e5e7eb;text-transform:uppercase;letter-spacing:.5px}.subjects-table td{padding:18px 16px;border-bottom:1px solid #f3f4f6;vertical-align:middle;color:#4b5563}.subjects-table tr{transition:all .2s ease}.subjects-table tr:hover{background:#f9fafb;transform:translateY(-1px);box-shadow:0 2px 8px #0000000d}.subjects-table tr.selected{background:#eff6ff;border-left:4px solid #3b82f6}.subjects-table tr:last-child td{border-bottom:none}.checkbox-column{width:60px;text-align:center}.checkbox{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6;border-radius:4px;transition:all .2s ease}.checkbox:hover{transform:scale(1.1)}.subject-id-column{min-width:140px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px}.subject-name-column{min-width:180px}.subject-name-column strong{color:#1f2937;font-weight:600}.description-column{min-width:250px;max-width:300px;line-height:1.5}.meeting-link-column{min-width:160px}.actions-column{min-width:150px;text-align:center}.meeting-link{color:#3b82f6;text-decoration:none;font-weight:500;padding:6px 12px;border-radius:6px;background:#eff6ff;border:1px solid #dbeafe;transition:all .2s ease;display:inline-block;font-size:13px}.meeting-link:hover{background:#dbeafe;color:#1d4ed8;text-decoration:none;transform:translateY(-1px);box-shadow:0 2px 4px #3b82f633}.actions-container{display:flex;gap:8px;justify-content:center}.action_btn{background:#e8f5e8;color:#166534;border:1px solid #bbf7d0;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:6px}.action_btn:hover{background:#dcfce7;transform:translateY(-2px);box-shadow:0 2px 8px #22c55e33}.action_btn.danger{color:#dc2626;border-color:#fecaca;background:#fef2f2}.action_btn.danger:hover{background:#fee2e2;box-shadow:0 2px 8px #dc262633}.empty-state{text-align:center;padding:80px 24px;color:#6b7280;background:#fff;border-radius:12px}.empty-state-icon{font-size:64px;margin-bottom:24px;opacity:.7}.empty-state h3{color:#374151;margin:0 0 12px;font-size:20px;font-weight:600}.empty-state p{font-size:16px;line-height:1.6;max-width:400px;margin:0 auto 32px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 24px;text-align:center;background:#fff;border-radius:12px;margin:20px 0}.loading-spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-container p{color:#6b7280;font-size:16px;font-weight:500;margin:0}.error-container{text-align:center;padding:60px 24px;background:#fff;border-radius:12px;margin:20px 0;border:1px solid #fecaca}.error-message{color:#dc2626;margin-bottom:24px;font-weight:500;font-size:16px;line-height:1.5}.retry-button{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #3b82f633}.retry-button:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f64d}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-badge.inactive{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}@media(max-width:1024px){.subjects-section{padding:16px}.subjects-header{padding:16px;flex-direction:column;gap:16px;align-items:stretch}.subjects-header-content{justify-content:center;text-align:center}}@media(max-width:768px){.subjects-section{padding:12px}.bulk-actions-bar{flex-direction:column;gap:16px;align-items:stretch;padding:20px}.bulk-actions-buttons{justify-content:center;flex-wrap:wrap}.subjects-table th,.subjects-table td{padding:14px 12px}.actions-container{flex-direction:column;gap:6px}.action_btn{padding:10px 12px;font-size:11px}.empty-state{padding:60px 20px}.empty-state-icon{font-size:48px}}@media(max-width:480px){.subjects-section{padding:8px}.subjects-header{padding:12px}.subjects-section-title{font-size:20px}.btn-primary,.btn-secondary{padding:10px 16px;font-size:13px}.subjects-table th,.subjects-table td{padding:12px 8px;font-size:13px}.meeting-link{padding:4px 8px;font-size:12px}}.subjects-table-container::-webkit-scrollbar{height:8px}.subjects-table-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:0 0 8px 8px}.subjects-table-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.subjects-table-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.subjects-table tbody tr{animation:fadeIn .3s ease-out}.subjects-table tbody tr:nth-child(2n){animation-delay:.1s}.teacher-chips{display:flex;flex-wrap:wrap;gap:8px}.teacher-chip{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600}.small-text{font-size:12px}.modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:560px;box-shadow:0 10px 40px #0000001f;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:18px}.modal-close{background:transparent;border:none;font-size:22px;cursor:pointer;line-height:1}.modal-body{padding:16px 20px 20px;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group select,.form-group input{padding:10px 12px;border-radius:8px;border:1px solid #d1d5db;font-size:14px}.teacher-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.teacher-option{border:1px solid #e5e7eb;border-radius:10px;padding:10px;display:grid;grid-template-columns:auto 1fr;column-gap:10px;row-gap:2px;align-items:center;cursor:pointer}.teacher-option.selected{border-color:#3b82f6;background:#eff6ff}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.teacher-option-text{display:flex;flex-direction:column;gap:2px}.teacher-option-name{font-weight:600;color:#111827;line-height:1.3}.btn-primary:focus,.btn-secondary:focus,.action_btn:focus,.checkbox:focus,.meeting-link:focus{outline:2px solid #3b82f6;outline-offset:2px}@media print{.subjects-header-actions,.bulk-actions-bar,.actions-column,.checkbox-column{display:none}.subjects-table{box-shadow:none;border:1px solid #000}.subjects-table th{background:#f0f0f0!important;color:#000!important}}.group-teachers-section{overflow:hidden}.group-teachers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.group-teachers-header-content{display:flex;align-items:center;gap:12px}.group-teachers-section-title{font-size:20px;font-weight:700;color:#1a1d21;margin:0}.group-teachers-count{color:#6b7280;font-size:14px;font-weight:500}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.btn-primary:hover{background:#2563eb;transform:translateY(-1px)}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#e5e7eb;border-color:#9ca3af}.bulk-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#eff6ff;border-bottom:1px solid #dbeafe;margin-bottom:20px;border-radius:10px}.bulk-actions-info{font-weight:600;color:#1e40af}.selected-count{font-size:14px}.bulk-actions-buttons{display:flex;gap:12px}.group-teachers-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb;background:#fff}.group-teachers-table{width:100%;border-collapse:collapse;min-width:800px}.group-teachers-table th{background:#f8fafc;padding:16px 12px;text-align:left;font-weight:600;color:#374151;font-size:14px;border-bottom:1px solid #e5e7eb}.group-teachers-table td{padding:16px 12px;border-bottom:1px solid #f3f4f6;vertical-align:middle}.group-teachers-table tr:hover{background:#f9fafb}.group-teachers-table tr.selected{background:#eff6ff}.checkbox-column{width:50px;text-align:center}.checkbox{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.name-column{min-width:200px}.email-column{min-width:250px}.subjects-column{min-width:220px}.actions-column{min-width:150px;text-align:right}.teacher-name{font-weight:500;color:#1f2937}.teacher-chips{display:flex;flex-wrap:wrap;gap:6px}.teacher-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe;font-size:12px;font-weight:600}.actions-container{display:flex;gap:8px;justify-content:flex-end}.action_btn{background:#e8f5e8;color:#166534;border:1px solid #166534;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.action_btn:hover{background:#dcfce7;transform:translateY(-1px)}.action_btn.danger{color:#dc2626;border-color:#dc2626;background:#fef2f2}.action_btn.danger:hover{background:#fee2e2}.empty-state{text-align:center;padding:60px 24px;color:#6b7280}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:#374151;margin:0 0 8px;font-size:18px}.empty-state p{margin:0 0 24px;font-size:14px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-container{text-align:center;padding:40px 24px}.error-message{color:#dc2626;margin-bottom:16px;font-weight:500}.retry-button{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500}.retry-button:hover{background:#2563eb}@media(max-width:768px){.group-teachers-header{flex-direction:column;gap:16px;align-items:stretch}.group-teachers-header-content{justify-content:center}.bulk-actions-bar{flex-direction:column;gap:12px;align-items:stretch}.bulk-actions-buttons{justify-content:center;flex-wrap:wrap}.actions-container{flex-direction:column;gap:4px}.action_btn{padding:8px 12px;font-size:11px}}.group-management-header{display:flex;align-items:center;gap:20px;margin-bottom:15px;padding:10px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.back-btn{padding:8px 16px;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.back-btn:hover{background:#5a6268}.group-info h1{margin:0;color:#333;font-size:16px}.group-info p{margin:0;color:#666;font-size:14px}.tabs-navigation{display:flex;background:#fff;border-radius:8px;padding:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.tab-btn{padding:12px 20px;border:none;background:transparent;cursor:pointer;border-radius:6px;font-size:14px;font-weight:500;color:#666;white-space:nowrap;transition:all .2s ease}.tab-btn:hover{background:#f8f9fa;color:#333}.tab-btn.active{background:var(--color-accent);color:#fff}.tab-content{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;min-height:400px}@media(max-width:768px){.group-management-header{flex-direction:column;align-items:flex-start;gap:12px}.tabs-navigation{flex-wrap:wrap}.tab-btn{flex:1;min-width:120px;text-align:center}}.groups-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--color-bg)}.groups-header-content .title-section{display:flex;gap:12px;margin-bottom:8px}.groups-header-content h2{font-size:1.5rem;font-weight:600;color:var(--color-primary);margin:0}.group-count{background:var(--color-bg);color:var(--color-primary);padding:4px 12px;border-radius:20px;font-size:.875rem;font-weight:500}.header-description{color:#666;font-size:.95rem;margin:0;max-width:400px}.header-actions{display:flex;gap:12px;align-items:center}.refresh-btn,.add-group-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:12px;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease}.refresh-btn{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-border)}.refresh-btn:hover:not(:disabled){background:var(--color-bg);transform:translateY(-1px)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.add-group-btn,.create-first-group-btn{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;border:none}.add-group-btn:hover,.create-first-group-btn:hover{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.btn_icon{font-size:1.1rem}.empty-state{text-align:center;padding:60px 20px;background:var(--color-bg);border-radius:16px;border:1px dashed #ddd}.empty-icon{font-size:3rem;margin-bottom:20px}.empty-state h3{font-size:1.25rem;color:var(--color-primary);margin-bottom:8px}.empty-state p{color:#666;margin-bottom:24px}.groups-content{animation:fadeIn .3s ease}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.group-card{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.12);transition:all .2s ease;box-shadow:#00000038 0 10px 30px;color:#fff}.group-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0003;border-color:#ffffff40}.group-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.group-avatar{width:44px;height:44px;border-radius:12px;background:var(--color-primary);color:var(--color-card);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;flex-shrink:0}.group-info{flex:1;min-width:0}.group-name{font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-id{font-size:.875rem;color:#ffffffb3;margin:0}.group-meta{flex-shrink:0}.mode-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.mode-offline{background:#e8f5e8;color:var(--color-success);border:1px solid var(--color-success)}.mode-online{background:#fff3e0;color:var(--color-warning);border:1px solid var(--color-warning)}.group-card-body{margin-bottom:20px}.group-stats{display:flex;gap:20px}.stat{display:flex;flex-direction:column;gap:4px;justify-content:center;align-items:center;flex:1;border:1px solid rgba(255,255,255,.25);border-radius:10px;padding:6px}.stat-label{font-size:.75rem;color:#ffffffbf;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:1.1rem;font-weight:600;color:#fff}.group-card-actions{display:flex;gap:8px}.action-btn{flex:1;padding:8px 16px;border:1.5px solid var(--color-bg);background:transparent;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.view-btn{color:var(--color-primary);border:1.5px solid var(--color-border)}.view-btn:hover{background:var(--color-bg);border-color:var(--color-primary)}.manage-btn{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;border-color:transparent}.manage-btn:hover{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-color:transparent}.group-modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.group-modal{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;width:min(520px,100%);box-shadow:0 12px 40px #00000026;display:flex;flex-direction:column}.group-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border)}.group-modal-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);font-size:12px}.group-modal-title{margin:4px 0 0;color:var(--color-text-primary)}.group-modal-close{border:none;background:var(--color-card);color:var(--color-text-secondary);border-radius:10px;width:32px;height:32px;cursor:pointer;border:1px solid var(--color-border)}.group-modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:.9rem;color:var(--color-text-secondary)}.form-field input,.form-field select{padding:10px 12px;border:1px solid var(--color-border);border-radius:10px;font-size:.95rem;outline:none}.form-row{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.group-modal-error{margin:0;color:var(--color-error);font-size:.9rem}.group-modal-footer{padding:12px 20px 16px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--color-border)}.modal-btn{padding:10px 16px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600}.modal-btn.primary{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff}.modal-btn.secondary{background:var(--color-card);border-color:var(--color-border);color:var(--color-text-primary)}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.loading-state,.error-state{text-align:center;padding:60px 20px}.spinner{width:40px;height:40px;border:3px solid var(--color-bg);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.error-icon{font-size:3rem;margin-bottom:20px}.retry-btn{background:var(--color-primary);color:var(--color-card);padding:10px 24px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s ease}.retry-btn:hover{background:#1b2b41}.groups-split{display:grid;grid-template-columns:320px 1fr;gap:16px;align-items:start}.group-list-panel{background:var(--color-card);border:1px solid var(--color-bg);border-radius:12px;padding:12px;position:sticky;top:12px;max-height:calc(100vh - 180px);display:flex;flex-direction:column;gap:12px}.list-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--color-primary)}.group-count-chip{background:var(--color-bg);padding:4px 10px;border-radius:12px;font-size:.85rem}.group-list-scroll{overflow-y:auto;padding-right:6px}.group-list-item{width:100%;display:flex;gap:10px;align-items:center;border:1px solid var(--color-border);border-radius:10px;padding:10px 12px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:left}.group-list-item.active{border-color:var(--color-primary);background:#eef2ff}.group-list-item:hover{border-color:var(--color-primary);transform:translateY(-1px)}.group-list-avatar{width:38px;height:38px;border-radius:10px;background:var(--color-primary);color:var(--color-card);display:grid;place-items:center;font-weight:700}.group-list-info{flex:1;min-width:0}.group-list-name{font-weight:600;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-list-meta{display:flex;gap:6px;font-size:.85rem;color:#6b7280}.dot{color:#9ca3af}.group-detail-panel{background:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.groups-tab{padding:16px}.groups-header{flex-direction:column;gap:16px;align-items:stretch}.header-actions{justify-content:flex-start}.groups-grid{grid-template-columns:1fr}.group-stats{justify-content:space-between}.groups-split{grid-template-columns:1fr}.group-list-panel{position:relative;max-height:none}}.course-details-container{min-height:100vh;background:#f8fafc;padding:1rem 2rem;display:flex;flex-direction:column;gap:20px}.course-details-header{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.header-top{display:flex;justify-content:space-between;align-items:center}.back-button{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:.5rem 0;transition:color .3s ease;margin-bottom:10px}.back-button:hover{color:#5a67d8}.header-actions{display:flex;gap:.5rem}.btn-icon{padding:.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid #e5e7eb}.btn-icon.edit{background:#fef3c7;color:#92400e}.btn-icon.more{background:#f3f4f6;color:#374151}.btn-icon:hover{transform:scale(1.1)}.course-title-section{padding:20px}.header-title-section{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.course-title{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1rem;line-height:1.2}.course-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.875rem}.status-badge{padding:.375rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;text-transform:capitalize}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.course-basic-details{background:#f8fafc;border-radius:12px;padding:1.5rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.5rem}.detail-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.detail-value{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:500;color:#1e293b}.description-section{border-top:1px solid #e5e7eb;padding-top:1.5rem}.description-text{line-height:1.6;color:#475569}.tabs-section{background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -2px 10px #0000000d}.tabs-container{display:flex;border-bottom:1px solid #e5e7eb;overflow-x:auto}.tab-button{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .3s ease;color:#64748b;font-weight:500;white-space:nowrap;min-width:fit-content}.tab-button:hover{color:#667eea;background:#f8fafc}.tab-button.active{color:#667eea;border-bottom-color:#667eea;background:#f0f4ff}.tab-content{background:#fff;border-radius:0 0 16px 16px;box-shadow:0 4px 6px -1px #0000001a;min-height:400px}.loading,.error{text-align:center;padding:3rem;font-size:1.25rem;color:#6b7280}.error{color:#dc2626}@media(max-width:768px){.detail-grid{grid-template-columns:1fr;gap:1rem}.tabs-container{flex-wrap:wrap}.tab-button{flex:1;min-width:120px;justify-content:center;padding:.75rem 1rem}}@media(max-width:480px){.header-top{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:flex-end}.course-meta{flex-direction:column;align-items:flex-start;gap:.5rem}}.student-details-page{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.student-breadcrumb{display:flex;align-items:center;gap:.35rem;color:#6b7280;font-size:.95rem}.student-breadcrumb .breadcrumb-item{cursor:pointer}.student-hero{position:sticky;top:0;z-index:1;background:linear-gradient(135deg,#471b08,#a04823);border:none;border-radius:12px;display:grid;grid-template-columns:240px 1fr 180px;gap:0;box-shadow:0 10px 30px #0f172a1f;align-items:stretch;overflow:hidden;min-height:200px}.hero-left{display:flex;align-items:stretch;justify-content:stretch;height:100%}.hero-avatar{width:100%;height:100%;border-radius:12px 0 0 12px;overflow:hidden;color:#fff;font-weight:700;font-size:1.2rem;display:flex;align-items:center;justify-content:center}.hero-avatar img{width:100%;height:100%;object-fit:cover;display:block}.hero-right{display:flex;flex-direction:column;justify-content:center;gap:1rem;padding:1.5rem 2rem;color:#fff;box-sizing:border-box;flex:1}.hero-meta{display:flex;flex-direction:column;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.hero-meta-name{display:flex;gap:20px}.hero-meta h1{margin:0;font-size:1.8rem;font-weight:700;color:#fff}.hero-personal{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.hero-info-card{display:flex;gap:.5rem;padding:.65rem;border:1px solid rgba(255,255,255,.25);border-radius:10px;background:#ffffff14;color:#fff}.hero-info-label{display:block;font-size:.85rem;color:#ffffffdb}.hero-info-value{margin:.1rem 0 0;font-weight:700;color:#fff}.student-id-chip{display:inline-block;background:#fff3;color:#fff;padding:.35rem .85rem;border-radius:20px;font-weight:600;font-size:.9rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin:.2rem 0}.gender-badge{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#ffffff2e;color:#fff;font-weight:700;border:1px solid rgba(255,255,255,.3)}.email-chip{border:1px solid rgba(255,255,255,.3);background:#ffffff24;color:#fff;border-radius:12px;padding:.45rem .85rem;cursor:pointer;font-weight:600;width:fit-content}.hero-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:.5rem}.hero-grid>div{margin-bottom:.25rem}.hero-actions{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:1rem;text-align:right;padding:1.5rem 2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:relative}.hero-actions.top-right{position:absolute;top:12px;right:12px;padding:0}.label{display:block;color:#ffffffe6;font-size:.85rem;margin-bottom:.35rem;font-weight:500}.hero-right p:not(.student-id-chip){margin:0;font-size:1rem;font-weight:600}.status{font-weight:700;font-size:1.1rem;padding:.5rem 1rem;border-radius:10px;display:inline-block;background:#ffffff1a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.status.active{color:#fff;background:#20194c}.status.inactive{color:#fecaca;background:#fecaca26}.student-tabs{display:flex;gap:.75rem;border-bottom:1px solid #e5e7eb}.student-tab{border:none;background:transparent;padding:.75rem 1.5rem;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease}.student-tab:hover{color:linear-gradient(135deg,#471b08,#a04823)}.student-tab.active{color:#000;border-color:#471b08}.student-tab-panel{margin-top:.5rem}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:1.5rem;box-shadow:0 10px 25px #0f172a0a}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.card.muted{color:#6b7280;text-align:center;padding:3rem 2rem;font-size:1.1rem}.personal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.info-card{display:flex;gap:.75rem;padding:.9rem;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.info-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#471b08,#a04823);display:flex;align-items:center;justify-content:center;color:#fff}.info-label{display:block;color:#6b7280;font-size:.85rem}.info-value{margin:.1rem 0 0;font-weight:600;color:#111827}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.course-card{position:relative;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;background:#fff;box-shadow:0 4px 12px #0f172a0a,0 1px 2px #0f172a0f;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease;overflow:hidden}.course-card:hover{box-shadow:0 10px 28px #0f172a1f,0 2px 4px #0f172a0f;transform:translateY(-2px)}.course-accent{position:absolute;left:0;top:0;bottom:0;width:8px;border-radius:16px 0 0 16px;background:linear-gradient(135deg,#471b08,#a04823)}.course-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-left:4px}.course-icon-wrapper{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#471b08,#a04823);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 8px #a0482333}.course_meta{flex:1;min-width:0}.course-title{font-weight:700;color:#0f172a;font-size:1.1rem;line-height:1.3;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-header-bottom{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;color:#6b7280;font-size:.9rem}.course-date{display:inline-flex;align-items:center;gap:.35rem;color:#6b7280}.course-pill{padding:.35rem .9rem;border-radius:999px;font-weight:700;font-size:.8rem;background:#ecfdf3;color:#166534;text-transform:capitalize;letter-spacing:.02em;white-space:nowrap}.course-pill.inactive{background:#fef2f2;color:#991b1b}.course-card__body{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem;border-top:1px solid #f3f4f6}.course-instructor{display:flex;align-items:center;gap:.5rem;color:#374151;font-size:.95rem;padding:.5rem;background:#f9fafb;border-radius:8px}.course-instructor .icon-wrapper{width:32px;height:32px;border-radius:8px;background:#e5e7eb;display:flex;align-items:center;justify-content:center;color:#6b7280;flex-shrink:0}.course-tags{display:flex;flex-wrap:wrap;gap:.5rem}.course-tag{display:inline-flex;align-items:center;gap:.35rem;background:#eef2ff;color:#4338ca;padding:.4rem .75rem;border-radius:8px;font-size:.85rem;transition:all .2s ease}.course-tag:hover{background:#e0e7ff;transform:translateY(-1px)}.course-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid #f3f4f6;margin-top:auto}.course_id{display:inline-flex;align-items:center;gap:.35rem;color:#6b7280;font-size:.85rem;font-family:SF Mono,Monaco,monospace}.course-status-indicator{width:8px;height:8px;border-radius:50%;background:#166534}.course-status-indicator.inactive{background:#991b1b}@media(max-width:640px){.course-grid{grid-template-columns:1fr;gap:1rem}.course-card{padding:1.25rem}.course-header-bottom{flex-direction:column;align-items:flex-start;gap:.5rem}}@media(max-width:768px){.student-hero{grid-template-columns:1fr;grid-template-rows:auto auto auto;position:static;gap:0}.hero-left{justify-content:center;height:160px}.hero-avatar{width:120px;height:120px;border-radius:50%;margin:1.5rem auto .5rem}.hero-right{padding:1rem;text-align:center}.hero-meta{justify-content:center}.hero-actions{padding:1rem;align-items:center;text-align:center;flex-direction:row;justify-content:space-between}.hero-grid{grid-template-columns:1fr;gap:1rem}}.invoice-page{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.invoice-breadcrumb{display:flex;align-items:center;gap:.35rem;color:#6b7280;font-size:.95rem}.invoice-breadcrumb .breadcrumb-item{cursor:pointer}.invoice-hero{display:flex;justify-content:space-between;align-items:center}.invoice-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #e5e7eb;border-radius:10px;padding:.75rem;font-size:1rem}.student-summary{display:flex;justify-content:space-between;align-items:center}.invoice-preview{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-radius:14px;box-shadow:0 10px 24px #0f172a1f;border:3px dotted rgba(15,23,42,.12)}.invoice-preview .preview-left{display:flex;flex-direction:column;gap:.2rem}.invoice-preview .preview-amount{font-size:1.4rem;font-weight:800}.invoice-preview .preview-label{font-size:.9rem;opacity:.9}.invoice-preview .preview-pill{background:#ffffff2e;border:1px solid rgba(255,255,255,.3);padding:.35rem .75rem;border-radius:999px;font-weight:700;font-size:.9rem}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:min(520px,90%);box-shadow:0 18px 40px #0f172a33;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.modal-body{padding:1rem 1.25rem;color:#1f2937;display:flex;flex-direction:column;gap:.35rem}.close-button{border:none;background:transparent;font-size:1.25rem;cursor:pointer}:root{--color-primary: #0A2E5D;--color-accent: #e0591e;--color-primary-rgb: 10, 46, 93;--color-primary-hover: 204, 225, 252;--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 Tight", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-h1: clamp(1.75rem, 1.5vw + 1rem, 1.5rem);--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)}body{margin:0;padding:0;font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg)}h1{font-size:var(--font-size-h1);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}h3{font-size:var(--font-size-h3);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}p{font-size:var(--font-size-body);line-height:var(--line-height-normal);color:var(--color-text-secondary)}button{font-family:var(--font-family);font-size:var(--font-size-button)}
