@charset "UTF-8";/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.table{display:table}.shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Roboto,sans-serif}code{font-family:Roboto Mono,monospace}select{color:#1f2937;cursor:pointer;box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;height:42px;font-size:.875rem;line-height:1.5;transition:all .2s;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;background-color:#fff!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234b5563'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E")!important;background-position:right .5rem center!important;background-repeat:no-repeat!important;background-size:1rem!important;padding:0 2rem 0 .875rem!important}select:focus{border-color:#075079;outline:none;box-shadow:0 0 0 3px #0750791a}select option{padding:.5rem}.react-datepicker-popper{z-index:9999!important}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-in}.dialog-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;width:90%;animation:slideUp .3s ease-out}.dialog-header{padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.dialog-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.dialog-body{padding:24px}.dialog-body p{margin:0;font-size:1rem;line-height:1.6;color:#4b5563}.dialog-footer{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end}.dialog-btn{padding:10px 24px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;border:none;transition:all .2s}.dialog-btn-cancel{background:#f3f4f6;color:#374151}.dialog-btn-cancel:hover{background:#e5e7eb}.dialog-btn-confirm{background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;box-shadow:0 2px 8px #0750794d}.dialog-btn-confirm:hover{background:linear-gradient(135deg,#086491,#0b7bb8);transform:translateY(-1px);box-shadow:0 4px 12px #07507966}.dialog-btn:disabled{opacity:.6;cursor:not-allowed}.dialog-btn-cancel:disabled:hover{background:#f3f4f6}.dialog-btn-confirm:disabled:hover{background:linear-gradient(135deg,#075079,#0a6ca0);transform:none;box-shadow:0 2px 8px #0750794d}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:12px;box-shadow:0 10px 40px #00000026;z-index:2000;min-width:320px;max-width:500px;animation:slideInUp .3s ease-out}.toast-success{background:#10b981;color:#fff}.toast-error{background:#ef4444;color:#fff}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-message{flex:1;font-size:1rem;font-weight:500;line-height:1.5}.toast-close{flex-shrink:0;background:none;border:none;color:inherit;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;opacity:.8;transition:opacity .2s}.toast-close:hover{opacity:1;background:#ffffff1a}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-image:url(https://images.unsplash.com/photo-1503676260728-1c00da094a0b?auto=format&fit=crop&w=1920&q=80);background-size:cover;background-position:center;padding:20px;position:relative}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:0}.login-card{background:#fff;padding:48px 40px;border-radius:12px;box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f;width:100%;max-width:490px;position:relative;z-index:1}.login-header{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:8px}.login-logo{width:80px;height:80px;object-fit:contain;border-radius:12px}.login-logo-placeholder{width:80px;height:80px;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;border-radius:12px;box-shadow:0 4px 12px #0750794d}.login-title{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin:0;text-align:center}.login-subtitle{text-align:center;color:#4b5563;font-size:.875rem;margin:0 0 32px}.signup-link{color:#3b82f6;text-decoration:none;font-weight:500}.signup-link:hover{text-decoration:underline}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.875rem;font-weight:600;color:#1a1a1a}.password-header{display:flex;justify-content:space-between;align-items:center}.forgot-password{font-size:.875rem;color:#ef4444;text-decoration:none;font-weight:500}.forgot-password:hover{text-decoration:underline}.form-input{padding:12px 16px;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s;outline:none;width:100%;box-sizing:border-box}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:45px}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:color .2s}.password-toggle:hover{color:#075079}.form-input:focus{border-color:#075079;box-shadow:0 0 0 3px #0750791a}.login-button{background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;padding:14px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;box-shadow:0 2px 8px #0750794d}.login-button:hover{background:linear-gradient(135deg,#086491,#0b7bb8);transform:translateY(-2px);box-shadow:0 4px 12px #07507966}.login-button:active{transform:translateY(0)}.login-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.error-message{background-color:#fee;border:1px solid #fcc;color:#c33;padding:12px 16px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.success-message{background-color:#dcfce7;border:1px solid #86efac;color:#166534;padding:12px 16px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.back-to-login{text-align:center;margin-top:8px}.back-to-login a{color:#075079;text-decoration:none;font-size:.875rem;font-weight:500}.back-to-login a:hover{text-decoration:underline}.google-button{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#4b5563;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:16px}.google-button:hover{background:#f9fafb;border-color:#d1d5db}.google-button:active{transform:scale(.98)}.google-icon{flex-shrink:0}@media (max-width: 640px){.login-card{padding:32px 24px}.login-title{font-size:2rem}}.notification-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:flex-end;align-items:flex-start;z-index:10000;padding:70px 20px 20px}.notification-modal{background:#fff;border-radius:12px;width:400px;max-width:100%;max-height:calc(100vh - 100px);display:flex;flex-direction:column;box-shadow:0 20px 50px #0003;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb}.notification-modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.notification-modal-actions{display:flex;align-items:center;gap:8px}.btn-mark-all-read{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#f3f4f6;border:none;border-radius:6px;font-size:.8125rem;color:#4b5563;cursor:pointer;transition:all .2s ease}.btn-mark-all-read:hover{background:#e5e7eb;color:#1f2937}.notification-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.notification-modal-close svg{width:20px;height:20px;color:#6b7280}.notification-modal-close:hover{background:#f3f4f6}.notification-modal-close:hover svg{color:#1f2937}.notification-filter{display:flex;padding:12px 20px;gap:8px;border-bottom:1px solid #e5e7eb}.filter-btn{padding:6px 14px;background:transparent;border:1px solid #e5e7eb;border-radius:20px;font-size:.8125rem;color:#6b7280;cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:#f3f4f6;color:#1f2937}.filter-btn.active{background:#075079;border-color:#075079;color:#fff}.notification-list{flex:1;overflow-y:auto;min-height:200px;max-height:400px}.notification-item{display:flex;align-items:flex-start;padding:14px 20px;border-bottom:1px solid #f3f4f6;transition:all .2s ease}.notification-item:last-child{border-bottom:none}.notification-item.clickable{cursor:pointer}.notification-item.clickable:hover{background:#f9fafb}.notification-item.unread{background:#eff6ff}.notification-item.unread.clickable:hover{background:#dbeafe}.notification-content{flex:1;min-width:0}.notification-title{font-size:.875rem;font-weight:600;color:#1f2937;margin-bottom:4px;line-height:1.4}.notification-text{font-size:.8125rem;color:#6b7280;margin-bottom:6px;line-height:1.5;white-space:pre-line}.notification-time{font-size:.75rem;color:#9ca3af}.notification-unread-dot{width:8px;height:8px;background:#3b82f6;border-radius:50%;margin-left:12px;margin-top:6px;flex-shrink:0}.notification-loading{display:flex;align-items:center;justify-content:center;padding:40px 20px;color:#6b7280;font-size:.875rem}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#9ca3af}.notification-empty svg{width:48px;height:48px;margin-bottom:12px;opacity:.5}.notification-empty p{margin:0;font-size:.875rem}.notification-load-more{padding:12px 20px;text-align:center;border-top:1px solid #f3f4f6}.btn-load-more{padding:8px 24px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:.8125rem;color:#4b5563;cursor:pointer;transition:all .2s ease}.btn-load-more:hover:not(:disabled){background:#e5e7eb;color:#1f2937}.btn-load-more:disabled{cursor:not-allowed;opacity:.6}@media (max-width: 480px){.notification-modal-overlay{padding:60px 10px 10px}.notification-modal{width:100%}.btn-mark-all-read span{display:none}}.dashboard-header{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;position:sticky;top:0;z-index:10}.header-logo{width:260px;border-right:1px solid #e5e7eb;display:flex;align-items:center;padding:0 20px;flex-shrink:0;transition:width .3s ease}.dashboard-layout.sidebar-collapsed .header-logo{width:70px;padding:0 12px}.dashboard-layout.sidebar-collapsed .header-logo .logo-text{display:none}.logo-container{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.logo-image{width:40px;height:40px;border-radius:8px;object-fit:contain}.logo-text{font-size:1.125rem;font-weight:700;color:#1a1a1a;white-space:nowrap}.header-content{display:flex;align-items:center;height:64px;flex:1;padding:0 24px;gap:16px}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;color:#6b7280;transition:all .2s ease;flex-shrink:0}.sidebar-toggle-btn:hover{background:#f3f4f6;border-color:#075079;color:#075079}.sidebar-toggle-btn svg{width:20px;height:20px}.header-title{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0;flex:1}.header-right{display:flex;align-items:center;gap:16px}.notification-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.notification-btn svg{width:22px;height:22px;color:#6b7280;transition:color .2s ease}.notification-btn:hover{background:#0750791a}.notification-btn:hover svg{color:#075079}.notification-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;font-size:.6875rem;font-weight:600;border-radius:10px;display:flex;align-items:center;justify-content:center;line-height:1}.user-menu{position:relative}.user-info{display:flex;align-items:center;gap:12px;cursor:pointer}.user-info:hover .user-name{color:#075079}.dropdown-arrow{width:20px;height:20px;color:#4b5563;transition:transform .3s}.user-info:hover .dropdown-arrow{color:#1f2937}.dropdown-arrow.active{transform:rotate(180deg)}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.user-name{font-size:.875rem;font-weight:600;color:#1a1a1a;transition:all .3s ease}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:200px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:50}.user-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#374151;font-size:.875rem;cursor:pointer;transition:background .2s}.dropdown-item svg{width:20px;height:20px;color:#4b5563;flex-shrink:0}.dropdown-item:hover{background:#f3f4f6}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item.logout{color:#ef4444;border-radius:0 0 8px 8px}.dropdown-item.logout svg{color:#ef4444}.dropdown-item.logout:hover{background:#fef2f2}.dropdown-divider{height:1px;background:#e5e7eb;margin:4px 0}@media (max-width: 768px){.header-logo{width:70px;padding:0 12px}.logo-text{display:none}.logo-icon,.logo-image{width:36px;height:36px;font-size:.875rem}.sidebar-toggle-btn{display:none}.header-title{font-size:1rem}.user-name,.dropdown-arrow{display:none}.user-dropdown{right:-8px}}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:99999!important;padding:1rem;animation:fadeIn .2s ease}.profile-modal-overlay .modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease;position:relative;z-index:100000!important}.profile-modal-body{padding:2rem 1.5rem}.profile-avatar-large{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;margin:0 auto 2rem;box-shadow:0 4px 12px #0750794d}.profile-info-grid{display:flex;flex-direction:column;gap:1.5rem}.profile-info-item{display:flex;flex-direction:column;gap:.5rem}.profile-info-item label{font-size:.875rem;font-weight:600;color:#4b5563;text-transform:uppercase;letter-spacing:.5px}.profile-info-value{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.profile-info-value svg{width:20px;height:20px;color:#075079;flex-shrink:0}.profile-info-value span{font-size:1rem;color:#1f2937;font-weight:500;word-break:break-word}.role-badge{display:inline-block;padding:.375rem .875rem;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff!important;border-radius:20px;font-size:.75rem!important;font-weight:600!important}@media (max-width: 640px){.profile-avatar-large{width:80px;height:80px;font-size:2rem}.modal-content{margin:1rem}.profile-info-grid{gap:1rem}}.sidebar{width:260px;background:#fff;border-right:1px solid #e5e7eb;height:calc(100vh - 64px);position:fixed;top:64px;left:0;overflow-y:auto;z-index:5;transition:width .3s ease}.sidebar.collapsed{width:70px}.sidebar-content{padding:24px 16px;display:flex;flex-direction:column;min-height:100%;height:100%}.sidebar-nav{display:flex;flex-direction:column;gap:8px;flex:1}.nav-item{display:flex;align-items:center;gap:26px;padding:12px 16px;color:#4b5563;text-decoration:none;border-radius:8px;font-size:.875rem;font-weight:500;transition:all .2s ease;position:relative;overflow:hidden;white-space:nowrap}.nav-item:hover{background:#f3f4f6;color:#1f2937;transform:translateY(-1px)}.nav-item.active{background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;font-weight:600;box-shadow:0 4px 12px #07507966}.nav-item.active:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.nav-item.active:hover:before{left:100%}.nav-item:focus{outline:none}.nav-item:focus-visible{outline:2px solid #075079;outline-offset:2px}.nav-icon{width:20px;height:20px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:8px}.language-switcher{display:flex;align-items:center;gap:26px;padding:12px 16px;width:100%;background:transparent;border:none;border-radius:8px;font-size:.875rem;font-weight:500;color:#4b5563;cursor:pointer;transition:all .2s ease;position:relative;white-space:nowrap;overflow:hidden}.language-switcher:hover{background:#f3f4f6;color:#1f2937;transform:translateY(-1px)}.language-switcher:active{transform:translateY(0)}.language-badge{margin-left:auto;padding:2px 8px;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;border-radius:4px;font-size:.75rem;font-weight:600}.logout-button{display:flex;align-items:center;gap:26px;padding:12px 16px;width:100%;background:transparent;border:none;border-radius:8px;font-size:.875rem;font-weight:500;color:#ef4444;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;white-space:nowrap}.logout-button:hover{background:#fef2f2;transform:translateY(-1px)}.logout-button:active{transform:translateY(0)}.logout-button .nav-icon{color:#ef4444}.sidebar.collapsed .sidebar-content{padding:24px 12px}.sidebar.collapsed .nav-item{justify-content:center;padding:12px;gap:0}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .logout-button{justify-content:center;padding:12px;gap:0}.sidebar.collapsed .logout-button span{display:none}.sidebar.collapsed .language-switcher{justify-content:center;padding:12px;gap:0;flex-direction:column}.sidebar.collapsed .language-switcher span:not(.language-badge){display:none}.sidebar.collapsed .language-switcher .nav-icon{margin-bottom:4px}.sidebar.collapsed .language-badge{margin-left:0;padding:2px 6px;font-size:.65rem}.sidebar.collapsed .sidebar-footer{padding-top:8px}@media (max-width: 768px){.sidebar{width:70px}.sidebar-content{padding:24px 8px}.nav-item span{display:none}.nav-item,.logout-button{justify-content:center;padding:12px;gap:0}.logout-button span{display:none}.language-switcher{justify-content:center;padding:12px;gap:0;flex-direction:column}.language-switcher span:not(.language-badge){display:none}.language-switcher .nav-icon{margin-bottom:4px}.language-badge{margin-left:0;padding:2px 6px;font-size:.65rem}.sidebar-footer{padding-top:8px}}.dashboard-layout{min-height:100vh;background:#f9fafb}.dashboard-body{display:flex}.dashboard-main{flex:1;margin-left:260px;padding:24px;overflow-x:auto;transition:margin-left .3s ease}.dashboard-layout.sidebar-collapsed .dashboard-main{margin-left:70px}@media (max-width: 768px){.dashboard-main{margin-left:70px;padding:16px}}.loading-container{display:flex;justify-content:center;align-items:center;padding:1.5rem;width:100%}.loading-fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#fffffff2;z-index:9999;gap:1.5rem}.loading-text{color:#075079;font-size:1rem;font-weight:500;margin:0}.dots-container{display:flex;align-items:center;justify-content:center;height:100%;width:100%}.dot{height:12px;width:12px;margin-right:6px;border-radius:6px;background-color:#075079;animation:pulse 1.5s infinite ease-in-out}.dot:last-child{margin-right:0}.dot:nth-child(1){animation-delay:-.3s}.dot:nth-child(2){animation-delay:-.1s}.dot:nth-child(3){animation-delay:.1s}.dot:nth-child(4){animation-delay:.3s}.dot:nth-child(5){animation-delay:.5s}@keyframes pulse{0%,80%,to{transform:scale(.6);background-color:#b3d4fc;opacity:.5}40%{transform:scale(1);background-color:#075079;opacity:1}}.dots-container-small .dot{height:8px;width:8px;margin-right:4px;border-radius:4px}.dots-container-medium .dot{height:12px;width:12px;margin-right:6px;border-radius:6px}.dots-container-large .dot{height:16px;width:16px;margin-right:8px;border-radius:8px}.table-loading-overlay{position:relative;min-height:200px}.table-loading-overlay:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#fffc;display:flex;justify-content:center;align-items:center;z-index:10}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5rem;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;margin:.4rem;padding-right:.2rem;padding-left:.2rem;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.btn-global{width:150px;height:45px;border-radius:8px;border:none;transition:all .5s ease-in-out;font-size:.875rem;font-family:inherit;font-weight:600;display:flex;align-items:center;background:#075079;color:#f5f5f5;cursor:pointer;position:relative;overflow:hidden}.btn-global:disabled{opacity:.5;cursor:not-allowed}.btn-global:hover:not(:disabled){box-shadow:0 0 20px #07507966;background:#086491}.btn-global .icon{position:absolute;height:24px;width:24px;display:flex;align-items:center;justify-content:center;left:12px;transition:all .5s}.btn-global .text{transform:translate(45px);transition:all .5s;letter-spacing:.5px}.btn-global:hover:not(:disabled) .icon{width:130px;left:10px}.btn-global:hover:not(:disabled) .text{opacity:0;transform:translate(100px)}.btn-global:focus{outline:2px solid #0a6ca0;outline-offset:2px}@media (max-width: 768px){.btn-global{width:130px;height:40px;font-size:.75rem}.btn-global .icon{width:20px;height:20px;left:10px}.btn-global .text{transform:translate(36px)}.btn-global:hover:not(:disabled) .icon{width:110px}.btn-global:hover:not(:disabled) .text{transform:translate(80px)}}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:850px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease;position:relative}.modal-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:12px}.modal-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#075079;border-radius:50%;animation:spin .8s linear infinite}.modal-form{padding:1.5rem;overflow-y:auto;flex:1;min-height:0;scrollbar-width:thin;scrollbar-color:#075079 #f3f4f6}.modal-form::-webkit-scrollbar{width:8px}.modal-form::-webkit-scrollbar-track{background:#f3f4f6}.modal-form::-webkit-scrollbar-thumb{background:#075079;border-radius:4px}.modal-form::-webkit-scrollbar-thumb:hover{background:#0a6ca0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.modal-content.fullscreen{max-width:100vw;max-height:100vh;width:100vw;height:100vh;border-radius:0;margin:0}.modal-large .form-grid{grid-template-columns:1fr 1fr 1fr;gap:.75rem 1rem}.form-group label .label-note{font-weight:400;font-size:.75rem;color:#6b7280;font-style:italic}.react-select-container{font-size:.875rem}.react-select__dropdown-indicator{color:#4b5563!important;padding:8px!important}.react-select__clear-indicator{color:#4b5563!important;padding:8px!important;cursor:pointer!important}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end;flex-shrink:0}@media (max-width: 1024px){.modal-large .form-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.modal-content{margin:1rem}.form-grid,.modal-large .form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-primary{width:100%}}.teachers-page,.schedule-teachers-page{width:100%;padding:0}.schedule-teachers-page .filters-container{padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.schedule-teachers-page .filter-input.date-picker{min-width:140px;cursor:pointer}.schedule-teachers-page .schedule-table-container{margin-top:1.5rem}@media (max-width: 768px){.schedule-teachers-page .filters-container{flex-wrap:wrap}.schedule-teachers-page .filter-group.with-label{width:100%;flex-wrap:wrap}.schedule-teachers-page .filter-label{width:100%;margin-bottom:.25rem}.schedule-teachers-page .week-nav-wrapper{width:100%;justify-content:space-between}.schedule-teachers-page .week-range{flex:1;justify-content:center}.schedule-teachers-page .filter-input.date-picker{min-width:110px;flex:1}.schedule-teachers-page .filter-select{width:100%}}.teachers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;flex-wrap:wrap;gap:1rem;border-bottom:2px solid #e5e7eb}.btn-advanced-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0}.btn-advanced-filter svg{width:20px;height:20px}.btn-advanced-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.btn-advanced-filter.active{background:#075079;color:#fff;border-color:#075079}.btn-advanced-filter.active:hover{background:#086491;border-color:#086491}.btn-advanced-filter:active{background:#e5e7eb}.btn-advanced-filter.active:active{background:#064963}.advanced-filters{margin-bottom:1.5rem;padding:1rem;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border:1px solid #0ea5e9;border-radius:12px;animation:slideDown .3s ease}.advanced-filters-header{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.advanced-filters-title{font-size:.875rem;font-weight:600;color:#0369a1}.advanced-filters-loading{font-size:.875rem;color:#0369a1;animation:pulse 1s infinite}.advanced-filters-count{font-size:.875rem;font-weight:500;color:#065f46}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.advanced-filters-content{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.advanced-filters-content .filter-select{flex:1;min-width:160px}.advanced-filters-content .filter-date-group{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:140px}.advanced-filters-content .filter-date-group label{font-size:.75rem;font-weight:500;color:#0369a1}.advanced-filters-content .filter-date-group .filter-select,.advanced-filters-content .filter-date-group .filter-input{width:100%;min-height:38px!important;height:38px!important;padding:.5rem .75rem!important;box-sizing:border-box;font-size:.8rem!important}.advanced-filters-content .filter-input{padding:.5rem .75rem;font-size:.8rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;min-width:140px}.advanced-filters-content .filter-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 2px #0750791a}.advanced-filters-content .react-datepicker-wrapper,.advanced-filters-content .react-datepicker__input-container{width:100%}.advanced-filters-content .react-datepicker__input-container input{width:100%;min-height:38px!important;height:38px!important;padding:.5rem .75rem!important;box-sizing:border-box;font-size:.8rem!important;border:1px solid #d1d5db;border-radius:6px;background:#fff}.advanced-filters-content .react-datepicker__input-container input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 2px #0750791a}.advanced-filters-content .react-datepicker__input-container input:disabled{background:#f3f4f6;cursor:not-allowed}.react-datepicker{font-family:inherit;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026}.react-datepicker__header{background:#075079;border-bottom:none;border-radius:8px 8px 0 0;padding-top:10px}.react-datepicker__current-month,.react-datepicker__day-name{color:#fff}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background:#075079;border-radius:50%}.react-datepicker__day--selected:hover{background:#086491}.react-datepicker__day:hover{background:#e0f2fe;border-radius:50%}.react-datepicker__day--disabled{color:#d1d5db}.react-datepicker__navigation-icon:before{border-color:#fff}.react-datepicker__close-icon:after{background-color:#9ca3af;font-size:14px}.react-datepicker__close-icon:hover:after{background-color:#dc2626}.btn-add-teacher{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0750794d}.btn-add-teacher:hover{transform:translateY(-2px);box-shadow:0 4px 12px #07507966;background:linear-gradient(135deg,#086491,#0b7bb8)}.btn-add-teacher:active{transform:translateY(0)}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff!important;border-bottom:2px solid #075079;white-space:nowrap}.data-table td{padding:1rem;color:#4b5563}.data-table tbody tr{border-bottom:1px solid #e5e7eb}.data-table tbody tr:last-child{border-bottom:1px solid #e5e7eb}.teacher-name{color:#1f2937;white-space:nowrap}.teachers-page .data-table th:nth-child(1),.teachers-page .data-table td:nth-child(1){text-align:center;width:60px}.actions-header{text-align:right!important;width:90px!important;max-width:90px!important;padding-right:1rem!important}.actions-cell{text-align:right!important;width:90px!important;max-width:90px!important;overflow:visible!important;white-space:normal!important;text-overflow:clip!important}.actions-buttons{display:flex;gap:.5rem;justify-content:flex-end;align-items:center}.btn-delete{display:inline-flex;align-items:center;padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #fecaca;border-radius:8px;cursor:pointer;transition:all .2s ease}@media (max-width: 768px){.teachers-header{flex-direction:row;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:.75rem}.btn-mobile-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0;order:1}.btn-mobile-filter svg{width:20px;height:20px}.btn-mobile-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.btn-mobile-filter:active{background:#e5e7eb}.btn-add-teacher{flex-shrink:0;margin-left:auto;order:2}.filters-container{display:flex;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:.75rem;width:100%;flex-basis:100%;order:3;overflow:hidden;max-height:0;padding:0 1rem;opacity:0;margin-top:0;transition:max-height .4s ease,padding .4s ease,opacity .3s ease,margin-top .4s ease}.filters-container.show-mobile{max-height:600px;padding:1rem;opacity:1;margin-top:0}.filter-group{flex:none;width:100%;min-width:0}.filter-input,.filter-select{width:100%;min-width:0}.btn-reset-filter,.btn-advanced-filter{flex-shrink:0;width:42px}.btn-add-teacher{flex-shrink:0;margin-left:auto}.advanced-filters{padding:.75rem}.advanced-filters-content{flex-direction:column;align-items:stretch;gap:.5rem}.advanced-filters-content .filter-select{width:100%!important;min-width:0!important;flex:none!important}.advanced-filters-content .filter-date-group{width:100%}.advanced-filters-content .filter-input{width:100%;min-width:0}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.75rem .5rem}}.modal-tabs{display:flex;gap:.5rem;padding:0;border-bottom:2px solid #e5e7eb;background:#f9fafb}.modal-body{padding:0}.schedule-filters{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}@media (max-width: 1024px){.modal-large{width:98%;max-width:98%}}@media (max-width: 768px){.modal-large{max-width:100%;width:100%}.modal-tabs{padding:0;overflow-x:auto}.tab-button{padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}.schedule-filters{flex-direction:column;align-items:stretch}.schedule-filters .filter-select{width:100%}}.btn-icon-action{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-icon-action svg{width:18px;height:18px}.btn-icon-action:disabled{opacity:.5;cursor:not-allowed}.btn-icon-add{color:#075079;border-color:#bfdbfe}.btn-icon-add:hover:not(:disabled){background:#eff6ff;border-color:#075079}.btn-icon-edit{color:#059669;border-color:#a7f3d0}.btn-icon-edit:hover:not(:disabled){background:#d1fae5;border-color:#059669}.btn-icon-delete{color:#dc2626;border-color:#fecaca}.btn-icon-delete:hover:not(:disabled){background:#fee2e2;border-color:#dc2626}.school-popup{max-width:500px}.school-list{max-height:400px;overflow-y:auto;margin-bottom:1rem}.school-items{display:flex;flex-direction:column;gap:.5rem}.school-item{width:100%;padding:.875rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left}.school-item:hover:not(:disabled){border-color:#075079;background:#f0f9ff}.school-item.selected{border-color:#075079;background:#eff6ff}.school-item:disabled{opacity:.6;cursor:not-allowed}.school-item-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.school-item-info{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}.school-item-name{font-size:.875rem;font-weight:500;color:#1f2937}.school-item-area{font-size:.75rem;font-weight:400;color:#4b5563}.check-icon{width:20px;height:20px;color:#075079;flex-shrink:0}.history-list{margin-top:0}.history-list .table-container{max-height:500px;overflow-y:auto;overflow-x:visible}.history-list .data-table{overflow:visible;width:100%;table-layout:auto}.history-list .data-table th,.history-list .data-table td{white-space:nowrap;padding:.75rem}.history-list .data-table th:nth-child(3),.history-list .data-table td:nth-child(3){white-space:normal;word-break:break-word;max-width:300px}.history-list .data-table th:nth-child(6),.history-list .data-table td:nth-child(6){max-width:150px;overflow:hidden;text-overflow:ellipsis}.history-list .data-table td:last-child{overflow:visible}.action-badge.action-confirmed{background:#d1fae5;color:#065f46}.action-badge.action-cancelled{background:#fef3c7;color:#92400e}.action-badge.action-substitute{background:#fff7ed;color:#ea580c}.description-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#4b5563;font-size:.85rem}.schedule-grid-table{width:100%;border-collapse:collapse;min-width:800px;background:#fff}.schedule-grid-table .lesson-header-cell{background:linear-gradient(135deg,#065368,#09608e);min-width:150px;font-weight:700;position:sticky;left:0;z-index:2;box-sizing:border-box}.schedule-grid-table tbody tr{transition:background .2s ease}.schedule-grid-table td{padding:1rem;text-align:center;border:1px solid #e5e7eb}.schedule-grid-table .lesson-cell{background:#f9fafb;font-weight:600;font-size:.875rem;color:#1f2937;text-align:left;position:sticky;left:0;z-index:1;min-width:150px;padding:1rem}.schedule-grid-table .schedule-cell{min-height:60px;vertical-align:middle;transition:all .2s ease}.schedule-grid-table .schedule-cell.clickable:hover{background:linear-gradient(135deg,#0750791a,#0a6ca01a)}.schedule-grid-table .schedule-cell.clickable:active{background:linear-gradient(135deg,#07507926,#0a6ca026)}.schedule-grid-table .teacher-badge{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.5rem .875rem;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;border-radius:6px;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #07507933;transition:all .2s ease;max-width:100%;word-wrap:break-word;white-space:normal}.schedule-grid-table .teacher-badge .teacher-name{font-weight:600;color:#fff}.schedule-grid-table .teacher-badge .teacher-note{font-size:.75rem;color:#ffffffe6;margin-top:.25rem}.badge-delete-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:#dc2626cc;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease;flex-shrink:0;opacity:.6}@media (max-width: 768px){.schedule-grid-table{font-size:.8rem}.schedule-grid-table th,.schedule-grid-table td{padding:.5rem}.schedule-grid-table .teacher-badge{padding:.375rem .625rem;font-size:.7rem}.schedule-grid-table .teacher-badge .teacher-note{font-size:.65rem}.badge-delete-btn{width:16px;height:16px}.badge-delete-btn svg{width:10px;height:10px}.schedule-grid-table .lesson-cell{font-size:.8rem;min-width:120px;position:static;z-index:auto}.schedule-grid-table .lesson-cell .lesson-name{font-size:.8rem}.schedule-grid-table .lesson-cell .lesson-desc{font-size:.7rem}.schedule-grid-table .day-header{font-size:.8rem}.schedule-grid-table .lesson-header-cell{min-width:120px;font-size:.9rem;position:static;z-index:auto}}.spinner{border:3px solid #f3f4f6;border-top:3px solid #075079;border-radius:50%;width:24px;height:24px;animation:spin .8s linear infinite;flex-shrink:0}.modal-teacher-popup{max-width:550px}@media (max-width: 768px){.modal-teacher-popup{max-width:95%}.popup-info-table th{font-size:.8rem;padding:.625rem .75rem;width:100px}.popup-info-table td{font-size:.8rem;padding:.625rem .75rem}}.school-year-select{height:32px;padding:0 .5rem;font-size:.8125rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;transition:all .2s ease;min-width:140px;margin-right:10px}.freetime-tab{padding:1.5rem}.freetime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:0 .5rem;flex-wrap:wrap;gap:.75rem}.freetime-info p{margin:0;color:#6b7280;font-size:.875rem}.freetime-filter select{min-width:180px}.freetime-table-container{overflow-x:auto;overflow-y:visible;border-radius:8px;border:1px solid #e5e7eb}.freetime-table-container{scrollbar-width:thin!important;scrollbar-color:#075079 #f3f4f6!important;-webkit-overflow-scrolling:touch!important}.freetime-table-container::-webkit-scrollbar{-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;height:8px!important;width:8px!important}.freetime-table-container::-webkit-scrollbar-track{background:#f3f4f6!important;border-radius:4px!important;-webkit-border-radius:4px!important}.freetime-table-container::-webkit-scrollbar-thumb{background:#075079!important;border-radius:4px!important;-webkit-border-radius:4px!important;min-height:30px!important}.freetime-table-container::-webkit-scrollbar-thumb:hover{background:#0a6ca0!important}.freetime-table-container::-webkit-scrollbar-thumb:active{background:#064060!important}.freetime-table{width:100%;border-collapse:collapse;min-width:600px;background:#fff}.freetime-table thead{background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff}.freetime-table thead tr{height:48px}.freetime-table th{padding:.75rem;text-align:center;font-weight:600;font-size:.875rem;border:1px solid rgba(255,255,255,.2);border-bottom:none;white-space:nowrap;vertical-align:middle;box-sizing:border-box;height:48px}.freetime-table th.timeslot-header{background:linear-gradient(135deg,#065368,#09608e);min-width:80px;font-weight:700;border-top-left-radius:7px}.freetime-table th:last-child{border-top-right-radius:7px}.freetime-table tbody tr{transition:background .2s ease}.freetime-table tbody tr:hover{background:#f9fafb}.freetime-table tbody tr:nth-child(2n){background:#f9fafb}.freetime-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.freetime-table td{padding:0;text-align:center;border:1px solid #e5e7eb}.freetime-table .timeslot-cell{background:#f9fafb;font-weight:600;font-size:.875rem;color:#075079;text-align:center;padding:.75rem;white-space:nowrap}.freetime-table tbody tr:nth-child(2n) .timeslot-cell{background:#f3f4f6}.freetime-cell{min-width:50px;height:44px;cursor:pointer;transition:all .2s ease;position:relative;vertical-align:middle}.freetime-cell:hover{background:#e0f2fe}.freetime-cell.free{background:#dcfce7}.freetime-cell.free:hover{background:#bbf7d0}.freetime-cell .check-icon{width:20px;height:20px;color:#16a34a;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.freetime-legend{display:flex;gap:1.5rem;margin-top:1rem;padding:.75rem 1rem;background:#f9fafb;border-radius:6px}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#4b5563}.legend-box{width:20px;height:20px;border:1px solid #d1d5db;border-radius:4px;background:#fff}.legend-box.free{background:#dcfce7;border-color:#86efac}@media (max-width: 640px){.freetime-table th,.freetime-table td{font-size:.75rem}.freetime-cell{min-width:40px;height:36px}.freetime-cell .check-icon{width:16px;height:16px}}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.free-time-warning{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:1rem;color:#92400e;font-size:.875rem;line-height:1.4}.free-time-warning svg{width:20px;height:20px;flex-shrink:0;color:#f59e0b;margin-top:1px}.free-time-warning span{flex:1}.teacher-badge.clickable-badge{cursor:pointer;transition:all .2s ease}.teacher-badge.clickable-badge:hover{transform:scale(1.02);box-shadow:0 4px 8px #0750794d}.teacher-badge .badge-content{flex:1;min-width:0;display:flex;flex-direction:column}.schedule-grid-table .teacher-badge .badge-content{display:flex;flex-direction:column}.schedule-grid-table .teacher-badge .badge-content .time-info{font-size:.7rem;opacity:.9}.schedule-grid-table .teacher-badge.assistant-badge{background:linear-gradient(135deg,#ea580c,#f97316);box-shadow:0 2px 4px #ea580c33;cursor:pointer}.schedule-grid-table .teacher-badge.assistant-badge:hover{transform:scale(1.02);box-shadow:0 4px 8px #ea580c4d}.schedule-grid-table .teacher-badge-wrapper[data-tooltip]:not([data-tooltip=""]):hover:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:.625rem 1rem;border-radius:6px;font-size:.8125rem;font-weight:500;white-space:pre;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #0000004d;animation:tooltipFadeIn .2s ease;width:max-content;max-width:300px;line-height:1.5}.attendance-tab{padding:1.5rem}.attendance-tab .table-container{overflow-x:auto}.attendance-tab .data-table{min-width:700px;table-layout:auto}.attendance-tab .data-table th,.attendance-tab .data-table td{white-space:nowrap;vertical-align:middle;border-bottom:none}.attendance-tab .data-table td:nth-child(7){vertical-align:middle}.attendance-tab .data-table tbody tr{border-bottom:1px solid #e5e7eb}.attendance-tab .data-table tbody tr:last-child{border-bottom:none}.attendance-tab .data-table td:nth-child(7){white-space:normal}.attendance-tab .data-table th:nth-child(2),.attendance-tab .data-table td:nth-child(2){width:40px;text-align:center}.attendance-tab .data-table th:nth-child(6),.attendance-tab .data-table td:nth-child(6){width:50px;text-align:center}.attendance-tab .data-table th:nth-child(8),.attendance-tab .data-table td:nth-child(8){min-width:180px;width:180px}.minutes-cell{font-weight:600;color:#075079}.statistics-tab{padding:1.5rem}.stats-filter{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.stats-filter-group{display:flex;align-items:center;gap:.5rem}.stats-filter-group label{font-size:.875rem;font-weight:500;color:#4b5563;white-space:nowrap}.stats-filter-group .form-input{width:160px}.stats-table{table-layout:auto}.stats-table th:nth-child(1),.stats-table td:nth-child(1){width:60px;text-align:center}.data-table.stats-table th:nth-child(3),.data-table.stats-table td:nth-child(3),.data-table.stats-table th:nth-child(4),.data-table.stats-table td:nth-child(4),.data-table.stats-table th:nth-child(5),.data-table.stats-table td:nth-child(5),.data-table.stats-table th:nth-child(6),.data-table.stats-table td:nth-child(6){text-align:center!important}.stats-total-row{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)!important;font-weight:600}.stats-total-row td{border-top:2px solid #075079;color:#075079}.text-center{text-align:center}.attendance-tab .today-row{background-color:#fef3c7!important}.attendance-tab .today-row:hover{background-color:#fde68a!important}.attendance-tab .today-badge{font-weight:600;color:#92400e;white-space:nowrap}.attendance-status{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.attendance-status.status-confirmed{background-color:#d1fae5;color:#065f46}.attendance-status.status-cancelled{background-color:#fee2e2;color:#991b1b}.attendance-status.status-pending{background-color:#e5e7eb;color:#4b5563}.status-cell{vertical-align:middle!important;text-align:left}.status-cell .status-content{display:inline-flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.25rem}.cancel-reason{font-size:.75rem;color:#991b1b;margin-top:.25rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendance-actions{display:flex;gap:.5rem;justify-content:center}.substitute-search-container{position:relative;display:flex;align-items:center;gap:.5rem}.substitute-search-container .form-input{flex:1}.substitute-loading{font-size:.75rem;color:#6b7280;white-space:nowrap}.attendance-tab .substitute-row{background-color:#fff7ed!important}.attendance-tab .substitute-row:hover{background-color:#ffedd5!important}.substitute-badge,.substitute-info{font-size:.7rem;color:#ea580c;font-weight:500;margin-top:.25rem}.attendance-tab .assistant-row{background-color:#fff7ed!important}.attendance-tab .assistant-row:hover{background-color:#ffedd5!important}.assistant-attendance-badge{font-size:.7rem;color:#ea580c;font-weight:500;margin-top:.25rem}.btn-confirm,.btn-cancel-attendance{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-confirm{background-color:#d1fae5;color:#065f46}.btn-confirm:hover:not(:disabled){background-color:#a7f3d0}.btn-confirm.active{background-color:#10b981;color:#fff}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-cancel-attendance{background-color:#fee2e2;color:#991b1b}.btn-cancel-attendance:hover:not(:disabled){background-color:#fecaca}.btn-cancel-attendance.active{background-color:#ef4444;color:#fff}.btn-cancel-attendance:disabled{opacity:.5;cursor:not-allowed}.btn-confirm svg,.btn-cancel-attendance svg{width:18px;height:18px}.modal-small{max-width:450px}.modal-small .modal-body{padding:1.5rem}.teachers-page .pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;margin-top:0;background:#fff;flex-wrap:wrap;gap:1rem}.pagination-info{color:#6b7280;font-size:.875rem}.pagination-btn{min-width:36px;height:36px;padding:0 .75rem;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-current,.pagination-page{padding:0 1rem;color:#374151;font-size:.875rem;font-weight:500}.pagination-select{height:36px;padding:0 .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.875rem;cursor:pointer;transition:all .2s ease}.pagination-select:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}@media (max-width: 768px){.pagination{flex-direction:column;align-items:stretch;gap:.75rem}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-btn{min-width:32px;height:32px;padding:0 .5rem}.pagination-current{padding:0 .5rem;font-size:.813rem}.pagination-select{height:32px}}.assistant-info-content{display:flex;flex-direction:column;gap:0}.assistant-info-content .info-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #e5e7eb;font-size:.875rem}.assistant-info-content .info-row:last-child{border-bottom:none}.assistant-info-content .info-label{font-weight:600;color:#4b5563;min-width:100px;flex-shrink:0}.assistant-info-content .info-value{color:#1f2937;word-break:break-word}.form-actions .btn-toggle-ban{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;background:#dcfce7;border:1px solid #86efac;color:#16a34a;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:fit-content;height:42px;box-sizing:border-box;margin-right:auto}.form-actions .btn-toggle-ban:hover{background:#bbf7d0;border-color:#4ade80}.form-actions .btn-toggle-ban.banned{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.form-actions .btn-toggle-ban.banned:hover{background:#fecaca;border-color:#f87171}.form-actions .btn-toggle-ban:disabled{opacity:.6;cursor:not-allowed}.form-actions .btn-toggle-ban svg{flex-shrink:0;width:18px;height:18px}.change-email-section{background:#f8fafc;padding:1rem;border-radius:8px;border:1px solid #e2e8f0}.change-email-section label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.5rem}.current-login-email{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.current-login-email .email-value{font-weight:500;color:#1e293b;word-break:break-all}.btn-change-email{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;color:#075079;background:#e0f2fe;border:1px solid #bae6fd;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-change-email:hover{background:#bae6fd;border-color:#7dd3fc}.btn-change-email svg{width:16px;height:16px}.change-email-form{margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.change-email-form .form-input{width:100%}.change-email-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-cancel-email{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-cancel-email:hover{background:#e2e8f0}.btn-confirm-email{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background:#075079;border:1px solid #075079;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-confirm-email:hover:not(:disabled){background:#064067}.btn-confirm-email:disabled{opacity:.6;cursor:not-allowed}.modal-teacher-popup .modal-header{position:relative}.modal-teacher-popup .form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.modal-teacher-popup .form-row .form-group{margin-bottom:0}.modal-teacher-popup .form-group{margin-bottom:.75rem}.modal-teacher-popup .form-group label{margin-bottom:.25rem}.modal-teacher-popup .modal-body{padding:0!important}.modal-teacher-popup .add-schedule-content,.modal-teacher-popup .tab-content{padding:1rem 1.5rem 1.5rem}.modal-teacher-popup .form-actions{margin-top:0;padding:1rem 1.5rem 1.5rem;border-top:1px solid #e5e7eb}.modal-teacher-popup .popup-info-table{width:100%;border-collapse:collapse;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.modal-teacher-popup .popup-info-table tbody tr{border-bottom:1px solid #e5e7eb}.modal-teacher-popup .popup-info-table tbody tr:last-child{border-bottom:none}.modal-teacher-popup .popup-info-table th{text-align:left;padding:.5rem .75rem;font-weight:600;color:#4b5563;font-size:.875rem;background:#f3f4f6;width:100px;white-space:nowrap}.modal-teacher-popup .popup-info-table td{padding:.5rem .75rem;font-size:.875rem;color:#1f2937}.modal-teacher-popup .time-picker-row{display:flex;align-items:center;gap:.5rem}.modal-teacher-popup .time-picker-row .time-select{flex:1;min-width:70px}.modal-teacher-popup .time-picker-row .time-separator{font-weight:600;color:#4b5563;font-size:1.1rem}.modal-teacher-popup .modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:.75rem}.modal-teacher-popup .modal-loading-spinner{width:40px;height:40px}.modal-teacher-popup .modal-loading-spinner svg{width:100%;height:100%;animation:spin 1s linear infinite}.modal-teacher-popup .modal-loading-spinner svg circle{stroke:#075079;stroke-dasharray:80;stroke-dashoffset:60;stroke-linecap:round}.modal-teacher-popup .popup-info-row-2cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.5rem .75rem;margin-bottom:.75rem}.modal-teacher-popup .popup-info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.modal-teacher-popup .popup-info-label{font-weight:600;color:#4b5563}.modal-teacher-popup .popup-info-value{color:#1f2937}.modal-teacher-popup .edit-schedule-tabs{display:flex;gap:0;margin-bottom:.75rem;border-bottom:2px solid #e5e7eb}.modal-teacher-popup .edit-schedule-tab{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#6b7280;background:transparent;border:none;border-radius:0;cursor:pointer;transition:all .2s ease;position:relative}.modal-teacher-popup .edit-schedule-tab:hover{color:#075079}.modal-teacher-popup .edit-schedule-tab.active{color:#075079;font-weight:600}.modal-teacher-popup .edit-schedule-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#075079}.modal-teacher-popup .schedule-info-group{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;margin-bottom:.5rem}.modal-teacher-popup .schedule-info-group .form-group{margin-bottom:.5rem}.modal-teacher-popup .schedule-info-group .form-group:last-child{margin-bottom:0}.modal-teacher-popup .form-row-3cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-bottom:.5rem}.modal-teacher-popup .form-col{display:flex;flex-direction:column;gap:.5rem}.modal-teacher-popup .form-col .form-group{margin-bottom:0}.modal-teacher-popup .teacher-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;margin-bottom:.75rem}.modal-teacher-popup .teacher-section:last-of-type{margin-bottom:0}.modal-teacher-popup .teacher-section-header{display:grid;grid-template-columns:1fr 1fr 1fr 28px;gap:.5rem;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.modal-teacher-popup .teacher-section-header label{font-weight:600;color:#1f2937;font-size:.875rem;margin-bottom:0}.modal-teacher-popup .teacher-section-header .header-col-label{font-size:.8rem;color:#6b7280;text-align:center}.modal-teacher-popup .btn-add-teacher{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:#fff;background:#075079;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.modal-teacher-popup .btn-add-teacher:hover{background:#053d5c;transform:scale(1.05)}.modal-teacher-popup .teacher-entry-group{padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px dashed #e5e7eb}.modal-teacher-popup .teacher-entry-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.modal-teacher-popup .teacher-entry-3cols{display:grid;grid-template-columns:1fr 1fr 1fr 28px;gap:.5rem;align-items:center;margin-bottom:.4rem}.modal-teacher-popup .teacher-entry-3cols .form-group{margin-bottom:0}.modal-teacher-popup .teacher-entry-3cols .form-input{font-size:.875rem}.modal-teacher-popup .teacher-select-group{min-width:0;margin-bottom:0}.modal-teacher-popup .teacher-select-group .react-select-container{width:100%}.modal-teacher-popup .teacher-entry-extra{display:grid;grid-template-columns:1fr 2fr;gap:.5rem;align-items:center;padding-right:calc(28px + .5rem)}.modal-teacher-popup .teacher-entry-extra .form-group{margin-bottom:0}.modal-teacher-popup .teacher-entry-extra .form-input{font-size:.875rem}.modal-teacher-popup .teacher-note-group{flex:1}.modal-teacher-popup .btn-remove-teacher{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.modal-teacher-popup .btn-remove-teacher:hover{background:#fee2e2;border-color:#f87171}.modal-teacher-popup .btn-remove-teacher.disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6;border-color:#d1d5db;color:#9ca3af}.modal-teacher-popup .btn-remove-teacher.disabled:hover{background:#f3f4f6;border-color:#d1d5db}.modal-teacher-popup .modal-delete{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#9ca3af;transition:all .2s ease}.modal-teacher-popup .modal-delete:hover{background:#fef2f2;color:#dc2626}.modal-teacher-popup .modal-delete svg{width:18px;height:18px}@media (max-width: 768px){.modal-teacher-popup .form-row,.modal-teacher-popup .form-row-3cols{grid-template-columns:1fr}.modal-teacher-popup .popup-info-row-2cols{grid-template-columns:1fr;gap:.5rem}.modal-teacher-popup .teacher-section-header{grid-template-columns:1fr 32px}.modal-teacher-popup .teacher-section-header .header-col-label{display:none}.modal-teacher-popup .teacher-entry-3cols{grid-template-columns:1fr 28px;gap:.5rem}.modal-teacher-popup .teacher-entry-3cols .form-group:nth-child(2),.modal-teacher-popup .teacher-entry-3cols .form-group:nth-child(3){grid-column:1}.modal-teacher-popup .teacher-entry-extra{grid-template-columns:1fr;padding-right:0}}.offdays-tab{padding:1.5rem}.offdays-tab .offday-form{background:#f9fafb;padding:.75rem 1rem;border-radius:8px;border:1px solid #e5e7eb;margin-bottom:1.5rem}.offdays-tab .offday-form-row{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center}.offdays-tab .offday-field{display:inline-flex;align-items:center;gap:.5rem}.offdays-tab .offday-field>label{font-size:.875rem;font-weight:500;color:#374151;white-space:nowrap}.offdays-tab .offday-field .react-datepicker-wrapper{width:140px}.offdays-tab .offday-field .react-datepicker-popper{z-index:9999!important}.offdays-tab .offday-field .react-datepicker-wrapper .form-input{width:100%}.offdays-tab .offday-field-reason{flex:1;min-width:150px}.offdays-tab .offday-field-reason .form-input{flex:1;min-width:80px}.offdays-tab .offday-actions{display:inline-flex;gap:.5rem}.offdays-tab .offday-actions .btn-primary,.offdays-tab .offday-actions .btn-cancel{height:38px;padding:0 1rem;white-space:nowrap}.offdays-tab .table-container{padding:0}.offdays-tab .empty-state{text-align:center;color:#6b7280;padding:2rem}.offdays-tab .action-buttons{display:flex;gap:.5rem;justify-content:center}.offdays-tab .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.offdays-tab .btn-icon svg{width:18px;height:18px}.offdays-tab .btn-edit{background:#eff6ff;color:#2563eb}.offdays-tab .btn-edit:hover{background:#dbeafe;color:#1d4ed8}.offdays-tab .btn-delete{background:#fef2f2;color:#dc2626}.offdays-tab .btn-delete:hover{background:#fee2e2;color:#b91c1c}.staff-page{width:100%;padding:0}.staff-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;flex-wrap:wrap;gap:1rem;border-bottom:2px solid #e5e7eb}.btn-add-staff{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0750794d}.btn-add-staff:hover{transform:translateY(-2px);box-shadow:0 4px 12px #07507966;background:linear-gradient(135deg,#086491,#0b7bb8)}.btn-add-staff:active{transform:translateY(0)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:fixed}.data-table thead{background:linear-gradient(135deg,#075079,#0a6ca0)!important}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff!important;border-bottom:2px solid #075079}.staff-name{font-weight:600;color:#1f2937}.staff-page .data-table th:nth-child(1),.staff-page .data-table td:nth-child(1){width:50px;min-width:50px;text-align:center}.staff-page .data-table th:nth-child(2),.staff-page .data-table td:nth-child(2){width:180px;min-width:150px}.staff-page .data-table th:nth-child(3),.staff-page .data-table td:nth-child(3){width:200px;min-width:180px}.staff-page .data-table th:nth-child(4),.staff-page .data-table td:nth-child(4){width:120px;min-width:100px}.staff-page .data-table th:nth-child(5),.staff-page .data-table td:nth-child(5){width:150px;min-width:120px}.staff-page .data-table th:nth-child(6),.staff-page .data-table td:nth-child(6){width:150px;min-width:120px}.staff-page .data-table th:nth-child(7),.staff-page .data-table td:nth-child(7){width:120px;min-width:100px;text-align:center}.staff-page .data-table th:last-child,.staff-page .data-table td:last-child{width:60px;min-width:60px}.status-badge{display:inline-block;padding:.375rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease}.form-input{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937}.btn-select-schools{width:100%;padding:.625rem .875rem;font-size:.875rem;text-align:left;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#1f2937;cursor:pointer;transition:all .2s ease}.btn-select-schools:hover{border-color:#075079;background:#f9fafb}.school-modal{max-width:800px!important;width:90%}.school-modal-body{padding:1rem 1.5rem}.school-modal .form-actions{padding:1rem 1.5rem 1.5rem}.school-filter-bar{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem}.school-filter-bar .form-input,.school-filter-bar .school-area-filter{flex:1;width:50%}.school-select-info{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.school-table-container{max-height:400px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px}.school-table{width:100%;border-collapse:collapse;font-size:.875rem}.school-table thead{background:#f3f4f6;position:sticky;top:0;z-index:1}.school-table th{padding:.75rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.school-table td{padding:.75rem;color:#4b5563;border-bottom:1px solid #e5e7eb}.school-table tbody tr{cursor:pointer;transition:background .15s ease}.school-table tbody tr:hover{background:#f9fafb}.school-table tbody tr.selected{background:#e0f2fe}.school-table tbody tr.selected:hover{background:#bae6fd}.school-table tbody tr:last-child td{border-bottom:none}.school-table .col-checkbox{width:40px;text-align:center}.school-table .col-stt{width:50px;text-align:center}.school-table .col-name{min-width:200px}.school-table .col-type,.school-table .col-area{width:120px}.school-table input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#075079}.no-schools{padding:2rem;text-align:center;color:#9ca3af;font-style:italic}.school-count-cell{text-align:center}.staff-page .data-table th:nth-child(7),.staff-page .data-table td:nth-child(7){width:100px;min-width:80px;text-align:center}.staff-page .data-table th:nth-child(8),.staff-page .data-table td:nth-child(8){width:120px;min-width:100px;text-align:center}.staff-page .data-table th:nth-child(9),.staff-page .data-table td:nth-child(9){width:60px;min-width:60px}.staff-modal{max-width:900px!important;width:95%}.modal-header-actions{display:flex;align-items:center;gap:.5rem}.btn-toggle-ban{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#dcfce7;border:1px solid #86efac;border-radius:8px;cursor:pointer;color:#16a34a;transition:all .2s ease}.btn-toggle-ban:hover{background:#bbf7d0;border-color:#4ade80}.btn-toggle-ban svg{width:20px;height:20px}.btn-toggle-ban.banned{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.btn-toggle-ban.banned:hover{background:#fecaca;border-color:#f87171}.btn-toggle-ban:disabled{opacity:.5;cursor:not-allowed}.staff-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem}.staff-form-grid .form-group{margin-bottom:0}@media (max-width: 768px){.staff-header{flex-direction:row;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:.75rem}.btn-mobile-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0;order:1}.btn-mobile-filter svg{width:20px;height:20px}.btn-mobile-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.btn-mobile-filter:active{background:#e5e7eb}.btn-add-staff{flex-shrink:0;margin-left:auto;order:2}.filters-container{display:flex;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:.75rem;width:100%;flex-basis:100%;order:3;overflow:hidden;max-height:0;padding:0 1rem;opacity:0;margin-top:0;transition:max-height .4s ease,padding .4s ease,opacity .3s ease,margin-top .4s ease}.filters-container.show-mobile{max-height:600px;padding:1rem;opacity:1;margin-top:0}.filter-input,.filter-select{width:100%;min-width:0}.btn-reset-filter{flex-shrink:0;width:42px}.btn-add-staff{flex-shrink:0;margin-left:auto}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.75rem .5rem}.modal-content{margin:1rem}.form-actions{flex-direction:column}.btn-cancel,.btn-primary{width:100%}.staff-form-grid{grid-template-columns:1fr}}.schools-page{width:100%;padding:0}.schools-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;flex-wrap:wrap;gap:1rem;border-bottom:2px solid #e5e7eb}.filters-container{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;flex:1}.filter-group{display:flex;align-items:center}.filter-input{height:42px;padding:0 .875rem;font-size:.875rem;line-height:1.5;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;min-width:200px;box-sizing:border-box}.filter-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.filter-input::placeholder{color:#9ca3af}.filter-select{min-width:160px}.btn-apply-filter{display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 1.25rem;color:#fff;background:#075079;border:1px solid #075079;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0;font-size:.875rem;font-weight:500}.btn-apply-filter:hover{background:#064060;border-color:#064060}.btn-apply-filter:active{background:#053550}.btn-reset-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0}.btn-reset-filter svg{width:20px;height:20px}.btn-reset-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.btn-reset-filter:active{background:#e5e7eb}.btn-add-school{width:150px;height:45px;border-radius:8px;border:none;transition:all .5s ease-in-out;font-size:.875rem;font-family:inherit;font-weight:600;display:flex;align-items:center;background:#075079;color:#f5f5f5;cursor:pointer;position:relative;overflow:hidden}.btn-add-school:hover{box-shadow:0 0 20px #07507966;background:#086491}.btn-add-school .icon{position:absolute;height:24px;width:24px;display:flex;align-items:center;justify-content:center;left:12px;transition:all .5s}.btn-add-school .text{transform:translate(45px);transition:all .5s;letter-spacing:.5px}.btn-add-school:hover .icon{width:130px;left:10px}.btn-add-school:hover .text{opacity:0;transform:translate(100px)}.btn-add-school:focus{outline:2px solid #0a6ca0;outline-offset:2px}.btn-icon{width:20px;height:20px}.loading-state{text-align:center;padding:3rem;color:#4b5563;font-size:1rem}.table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 3px #0000001a}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:auto;margin:0}.data-table thead{background:linear-gradient(135deg,#075079,#0a6ca0)}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff;border-bottom:2px solid #064963}.data-table td{padding:1rem;color:#4b5563;border-bottom:1px solid #e5e7eb}.schools-page .data-table th:nth-child(1),.schools-page .data-table td:nth-child(1){width:1%;white-space:nowrap;text-align:center}.schools-page .data-table th:nth-child(6),.schools-page .data-table td:nth-child(6){width:1%;white-space:nowrap;text-align:center}.schools-page .data-table th:last-child,.schools-page .data-table td:last-child{width:1%;white-space:nowrap}.data-table tbody tr:last-child td{border-bottom:1px solid #e5e7eb}.data-table tbody tr:nth-child(2n){background:#f9fafb}.data-table tbody tr:hover{background:#f0f9ff}.school-name{color:#1f2937;font-family:Roboto,sans-serif;font-size:.875rem;white-space:nowrap}.empty-state{text-align:center;padding:3rem!important;color:#9ca3af;font-style:italic}.status-badge{display:inline-block;padding:.375rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;white-space:nowrap}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.actions-header,.actions-cell{text-align:center!important}.btn-delete-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:#dc2626;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-delete-icon svg{width:20px;height:20px}.btn-delete-icon:hover{background:#fee2e2;color:#991b1b}.btn-delete-icon:active{background:#fecaca}.btn-delete-icon:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#4b5563;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-close svg{width:20px;height:20px}.modal-delete{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#ef4444;transition:all .2s ease}.modal-delete:hover{background:#fef2f2;color:#dc2626}.modal-delete svg{width:20px;height:20px}.modal-form{padding:1.5rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin-bottom:1.5rem}.form-grid .form-group{margin-bottom:0}.form-group{margin-bottom:1.5rem;width:100%;box-sizing:border-box}.form-group-full{grid-column:1 / -1}.react-select-container{font-size:.875rem;width:100%}.react-select__control{border:1px solid #d1d5db!important;border-radius:8px!important;min-height:42px!important;box-shadow:none!important;transition:all .2s ease!important}.react-select__control:hover{border-color:#9ca3af!important}.react-select__control--is-focused{border-color:#075079!important;box-shadow:0 0 0 3px #0750791a!important}.react-select__placeholder{color:#9ca3af!important;font-size:.875rem!important}.react-select__input-container{color:#1f2937!important;font-size:.875rem!important}.react-select__value-container{padding:2px 8px!important}.react-select__indicators{padding-right:8px!important}.react-select__multi-value{background-color:#e0f2fe!important;border-radius:6px!important}.react-select__multi-value__label{color:#075079!important;font-size:.875rem!important;padding:3px 6px!important}.react-select__multi-value__remove{color:#075079!important;cursor:pointer!important;border-radius:0 6px 6px 0!important}.react-select__multi-value__remove:hover{background-color:#dc2626!important;color:#fff!important}.react-select__menu{border-radius:8px!important;box-shadow:0 4px 12px #00000026!important;border:1px solid #e5e7eb!important;margin-top:4px!important;font-size:.875rem!important}.react-select__menu-list{padding:4px!important;max-height:200px!important}.react-select__option{padding:8px 12px!important;cursor:pointer!important;border-radius:6px!important;font-size:.875rem!important;color:#374151!important}.react-select__option--is-focused{background-color:#f3f4f6!important}.react-select__option--is-selected{background-color:#075079!important;color:#fff!important}.react-select__option--is-selected:hover{background-color:#086491!important}.react-select__indicator-separator{display:none!important}.react-select__dropdown-indicator{color:#6b7280!important;padding:8px!important;margin-right:8px!important}.react-select__dropdown-indicator:hover{color:#075079!important}.react-select__clear-indicator{color:#6b7280!important;padding:8px!important;cursor:pointer!important}.react-select__clear-indicator:hover{color:#dc2626!important}.react-select__loading-indicator{color:#075079!important}.form-input{width:100%!important;max-width:none!important;padding:.625rem .875rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;box-sizing:border-box}select.form-input,textarea.form-input{width:100%!important;max-width:none!important;box-sizing:border-box}textarea.form-textarea-auto{min-height:42px;resize:none;overflow:hidden;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row .form-group{margin-bottom:0}.time-picker-row{display:flex;align-items:center;gap:.5rem}.time-picker-row .time-select{flex:1;min-width:70px}.time-picker-row .time-separator{font-weight:600;color:#4b5563;font-size:1.1rem}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem}.modal-loading-spinner{width:50px;height:50px}.modal-loading-spinner svg{width:100%;height:100%;animation:spin 1s linear infinite}.modal-loading-spinner svg circle{stroke:#075079;stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0}.modal-loading span{color:#4b5563;font-size:.9rem;font-weight:500}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.btn-cancel{padding:.625rem 1.5rem;font-size:.875rem;font-weight:500;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#f3f4f6;color:#1f2937}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-large{max-width:1200px;width:95%}.modal-content{transition:all .3s ease}.modal-overlay:has(.modal-content.fullscreen){padding:0}.modal-content.fullscreen{max-width:100%;width:100%;height:100vh;max-height:100vh;margin:0;border-radius:0}.modal-content.fullscreen .schedule-tab{padding:1.5rem 0}.modal-actions{display:flex;align-items:center;gap:.5rem}.school-year-select{height:32px;padding:0 .5rem;font-size:.8125rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;transition:all .2s ease;min-width:140px}.school-year-select:hover{border-color:#9ca3af}.school-year-select:focus{outline:none;border-color:#075079;box-shadow:0 0 0 2px #0750791a}.school-year-select{margin-right:10px}.modal-maximize{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#4b5563;transition:all .2s ease}.modal-maximize:hover{background:#f3f4f6;color:#075079}.modal-maximize svg{width:18px;height:18px}.modal-tabs{display:flex;gap:.5rem;padding:0;border-bottom:2px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.tab-button{padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;color:#4b5563;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.tab-button:hover{color:#075079}.tab-button.active{color:#075079;font-weight:600;border-bottom-color:#075079}.tab-spinner{width:16px;height:16px;margin-left:8px;display:inline-block;vertical-align:middle;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-body{padding:0;overflow-y:auto;flex:1;min-height:0}.modal-body{scrollbar-width:thin!important;scrollbar-color:#075079 #f3f4f6!important;-webkit-overflow-scrolling:touch!important}.modal-body::-webkit-scrollbar{-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;width:8px!important;height:8px!important}.modal-body::-webkit-scrollbar-track{background:#f3f4f6!important;border-radius:4px!important;-webkit-border-radius:4px!important}.modal-body::-webkit-scrollbar-thumb{background:#075079!important;border-radius:4px!important;-webkit-border-radius:4px!important;min-height:30px!important}.modal-body::-webkit-scrollbar-thumb:hover{background:#0a6ca0!important}.modal-body::-webkit-scrollbar-thumb:active{background:#064060!important}.schedule-tab{padding:1.5rem}.schedule-table-container{overflow-x:auto;overflow-y:visible}.schedule-table-container{scrollbar-width:thin!important;scrollbar-color:#075079 #f3f4f6!important;-webkit-overflow-scrolling:touch!important}.schedule-table-container::-webkit-scrollbar{-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;height:8px!important;width:8px!important}.schedule-table-container::-webkit-scrollbar-track{background:#f3f4f6!important;border-radius:4px!important;-webkit-border-radius:4px!important}.schedule-table-container::-webkit-scrollbar-thumb{background:#075079!important;border-radius:4px!important;-webkit-border-radius:4px!important;min-height:30px!important}.schedule-table-container::-webkit-scrollbar-thumb:hover{background:#0a6ca0!important}.schedule-table-container::-webkit-scrollbar-thumb:active{background:#064060!important}.schedule-grid-table thead{cursor:grab}.schedule-grid-table thead:active{cursor:grabbing}.schedule-form{background:#f9fafb;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid #e5e7eb;overflow:visible}@media (max-width: 1024px){.schedule-form{overflow-x:auto;overflow-y:visible}.schedule-form::-webkit-scrollbar{height:8px}.schedule-form::-webkit-scrollbar-track{background:#e5e7eb;border-radius:4px}.schedule-form::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:4px}.schedule-form::-webkit-scrollbar-thumb:hover{background:#6b7280}}.schedule-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:1rem;align-items:end}.schedule-form-grid .form-group{margin-bottom:0}.schedule-form-grid-5{display:grid;grid-template-columns:120px minmax(180px,1fr) minmax(250px,2fr) minmax(150px,1fr) auto;gap:1rem;align-items:end;min-width:900px}.schedule-form-grid-5 .form-group{margin-bottom:0}.schedule-form-grid-5 .form-group label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schedule-form-grid-5 .react-select-container{min-width:0}.schedule-form-grid-5 .react-select__control{min-width:200px}.schedule-list h4{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.btn-delete{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-delete:hover{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.btn-delete:active{background:#fecaca}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.history-tab{padding:1.5rem}.history-list h4{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.history-list .table-container{margin-top:0}.history-list .data-table th:first-child,.history-list .data-table td:first-child{min-width:160px;width:160px;white-space:nowrap}.history-list .data-table th:nth-child(2),.history-list .data-table td:nth-child(2){width:90px;text-align:center}.history-list .data-table th:nth-child(4),.history-list .data-table td:nth-child(4){width:110px;text-align:center}.action-badge{display:inline-block;padding:.375rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px}.action-badge.action-created{background:#d1fae5;color:#065f46}.action-badge.action-updated{background:#dbeafe;color:#1e40af}.action-badge.action-deleted{background:#fee2e2;color:#991b1b}.user-name-hover{cursor:help;border-bottom:1px dotted #6b7280;transition:all .2s ease}.user-name-hover:hover{font-weight:700;color:#075079;border-bottom:1px dotted #075079}.btn-mobile-filter{display:none}@media (max-width: 1024px){.modal-large{width:98%;max-width:98%}.schedule-form-grid-5{grid-template-columns:100px minmax(150px,1fr) minmax(200px,1.5fr) minmax(120px,1fr) auto;min-width:750px}}@media (max-width: 768px){.schools-header{flex-direction:row;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:.75rem}.btn-mobile-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0;order:1}.btn-mobile-filter svg{width:20px;height:20px}.btn-mobile-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.btn-mobile-filter:active{background:#e5e7eb}.btn-add-school{flex-shrink:0;margin-left:auto;order:2;width:130px;height:40px;font-size:.75rem}.btn-add-school .icon{width:20px;height:20px;left:10px}.btn-add-school .text{transform:translate(36px)}.btn-add-school:hover .icon{width:110px}.btn-add-school:hover .text{transform:translate(80px)}.filters-container{display:flex;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:.75rem;width:100%;flex-basis:100%;order:3;overflow:hidden;max-height:0;padding:0 1rem;opacity:0;margin-top:0;transition:max-height .4s ease,padding .4s ease,opacity .3s ease,margin-top .4s ease}.filters-container.show-mobile{max-height:600px;padding:1rem;opacity:1;margin-top:0}.filter-group{flex:none;width:100%;min-width:0}.filter-input,.filter-select{width:100%;min-width:0}.btn-reset-filter{flex-shrink:0;width:42px}.btn-add-school{flex-shrink:0;margin-left:auto}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.75rem .5rem}.modal-content{margin:.5rem}.modal-large{max-width:100%;width:100%}.modal-tabs{padding:0;overflow-x:auto}.tab-button{padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}.form-grid{grid-template-columns:1fr}.schedule-form{padding:1rem}.schedule-form-grid,.schedule-form-grid-5{grid-template-columns:1fr;min-width:auto}.schedule-form-grid-5 .form-group label{white-space:normal}.form-actions{flex-direction:column}.btn-cancel,.btn-primary{width:100%}.schedule-list h4{font-size:.875rem}}.schedule-grid-table{width:100%;border-collapse:collapse;min-width:800px;background:#fff;overflow:visible}.schedule-grid-table thead{background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff}.schedule-grid-table thead tr{height:58px}.schedule-grid-table th{padding:1rem;text-align:center;font-weight:600;font-size:.875rem;border:1px solid rgba(255,255,255,.2);border-bottom:none;white-space:nowrap;vertical-align:middle;box-sizing:border-box;height:58px}.schedule-grid-table .lesson-header-cell{background:linear-gradient(135deg,#065368,#09608e);min-width:150px;font-weight:700;position:sticky;left:0;z-index:2;box-sizing:border-box;text-align:center}.schedule-grid-table .day-header{min-width:120px;font-weight:700}.schedule-grid-table tbody tr{transition:background .2s ease;overflow:visible}.schedule-grid-table tbody tr:hover{background:#f9fafb}.schedule-grid-table tbody tr:nth-child(2n){background:#f9fafb}.schedule-grid-table tbody tr:nth-child(2n):hover{background:#f3f4f6}.schedule-grid-table td{padding:1rem;text-align:center;border:1px solid #e5e7eb;overflow:visible}.schedule-grid-table .lesson-cell{background:#f9fafb;font-weight:600;font-size:.875rem;color:#1f2937;text-align:center;position:sticky;left:0;z-index:1;min-width:150px;padding:1rem}.schedule-grid-table .lesson-cell .lesson-name{font-weight:700;font-size:.875rem;color:#075079;margin-bottom:.25rem}.schedule-grid-table .lesson-cell .lesson-time{font-size:.75rem;font-weight:500;color:#3b82f6;margin-top:.15rem}.schedule-grid-table .lesson-cell .lesson-desc{font-size:.75rem;font-weight:400;color:#6b7280;margin-top:.25rem}.schedule-grid-table .schedule-cell{min-height:60px;vertical-align:middle;transition:all .2s ease;overflow:visible}.schedule-grid-table .schedule-cell.has-schedule{background:linear-gradient(135deg,#0750790d,#0a6ca00d)}.schedule-grid-table .schedule-cell.clickable{cursor:pointer}.schedule-grid-table .schedule-cell.clickable:not(.has-schedule):hover{background:linear-gradient(135deg,#0750791a,#0a6ca01a)}.schedule-grid-table .schedule-cell.clickable:not(.has-schedule):active{background:linear-gradient(135deg,#07507926,#0a6ca026)}.schedule-grid-table .teacher-badge{display:flex;align-items:center;justify-content:space-between;gap:.375rem;padding:.5rem .5rem .5rem .875rem;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;border-radius:6px;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #07507933;transition:all .2s ease;white-space:nowrap;min-width:max-content}.schedule-grid-table .teacher-badge.no-teacher{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d}.schedule-grid-table .teacher-badge.no-teacher:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 8px #f59e0b66}.schedule-grid-table .teacher-badge.no-teacher .no-teacher-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.schedule-grid-table .teacher-badge.no-teacher .time-slot,.schedule-grid-table .teacher-badge .teacher-name{font-weight:600;color:#fff}.schedule-grid-table .teacher-badge .teacher-grade{font-size:.7rem;font-weight:500;color:#ffffffd9;margin-top:.125rem}.schedule-grid-table .teacher-badge .teacher-note,.schedule-grid-table .teacher-badge .teacher-email{display:none}.schedule-grid-table .teacher-badge-wrapper{position:relative;overflow:visible}.schedule-grid-table .teacher-badge-wrapper[data-tooltip]:not([data-tooltip=""]):hover:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.75rem;font-weight:500;white-space:pre-line;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #0000004d;animation:tooltipFadeIn .2s ease}.schedule-grid-table .teacher-badge-wrapper[data-tooltip]:not([data-tooltip=""]):hover:before{content:"";position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#000000e6;z-index:1000;pointer-events:none;animation:tooltipFadeIn .2s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.badge-delete-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:transparent;border:none;border-radius:3px;cursor:pointer;transition:all .15s ease;flex-shrink:0;opacity:.6}.badge-delete-btn:hover{background:#dc2626e6;opacity:1;transform:scale(1.15)}.badge-delete-btn svg{width:12px;height:12px;color:#fff;stroke-width:2.5}.cell-add-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;cursor:pointer;transition:all .2s ease;margin:0 auto;opacity:.3}.schedule-cell:hover .cell-add-btn{opacity:.6}.cell-add-btn:hover{opacity:1!important;transform:scale(1.3)}.cell-add-btn svg{width:20px;height:20px;color:#075079;stroke-width:2.5}.schedule-grid-table .schedule-cell.clickable .teacher-badge:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0750794d}.schedule-hint{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:.875rem;margin-bottom:1rem}.schedule-hint svg{flex-shrink:0}.modal-teacher-popup{max-width:1000px}.modal-teacher-popup .modal-body{padding:1.5rem}.popup-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.popup-info .info-item{display:flex;align-items:baseline;gap:.5rem;font-size:.875rem;line-height:1.5}.popup-info .info-item strong{color:#4b5563;font-weight:600;min-width:120px}.popup-info .info-item-with-delete{display:flex;justify-content:space-between;align-items:center;gap:1rem}.btn-delete-inline{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.btn-delete-inline:hover{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.popup-info-row-2cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.875rem 1rem;margin-bottom:1rem}.popup-info-item{display:flex;flex-direction:row;align-items:center}.popup-info-item>.popup-info-label{width:20%;flex:0 0 20%}.popup-info-item>.popup-info-value{flex:1}.popup-info-label{font-weight:600;color:#4b5563;font-size:.875rem;white-space:nowrap}.popup-info-value{font-size:.875rem;color:#1f2937}.popup-info-table{width:100%;border-collapse:collapse;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.popup-info-table tbody tr{border-bottom:1px solid #e5e7eb}.popup-info-table tbody tr:last-child{border-bottom:none}.popup-info-table th{text-align:left;padding:.875rem 1rem;font-weight:600;color:#4b5563;font-size:.875rem;background:#f3f4f6;width:120px;white-space:nowrap}.popup-info-table td{padding:.875rem 1rem;font-size:.875rem;color:#1f2937}.popup-info-table .teacher-cell-td{padding:.75rem 1rem}.popup-info-table .teacher-cell-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.btn-delete-inline:active{background:#fecaca}.btn-delete-inline:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1024px){.schedule-table-container{overflow-x:scroll}.schedule-grid-table{min-width:1000px}.schedule-grid-table th,.schedule-grid-table td{padding:.75rem}.schedule-grid-table .lesson-cell{min-width:130px}.schedule-grid-table .day-header{min-width:100px}}@media (max-width: 768px){.schedule-grid-table{font-size:.8rem}.schedule-grid-table th,.schedule-grid-table td{padding:.5rem}.schedule-grid-table .teacher-badge{padding:.375rem .625rem;font-size:.7rem}.schedule-grid-table .teacher-badge:hover .teacher-email{font-size:.6rem}.schedule-grid-table .lesson-cell{font-size:.8rem;min-width:120px;position:static;z-index:auto}.schedule-grid-table .lesson-cell .lesson-name{font-size:.8rem}.schedule-grid-table .lesson-cell .lesson-time,.schedule-grid-table .lesson-cell .lesson-desc{font-size:.7rem}.schedule-grid-table .day-header{font-size:.8rem}.schedule-grid-table .lesson-header-cell{min-width:120px;font-size:.9rem;position:static;z-index:auto}.modal-teacher-popup{max-width:95%}.popup-info .info-item{flex-direction:column;align-items:flex-start;gap:.25rem}.popup-info .info-item strong{min-width:auto}.popup-info-table th{font-size:.8rem;padding:.625rem .75rem;width:100px}.popup-info-table td{font-size:.8rem;padding:.625rem .75rem}.schedule-hint{font-size:.8rem;padding:.625rem .875rem}}.schools-page .pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;flex-wrap:wrap;gap:1rem;margin-top:0}.pagination-info{font-size:.875rem;color:#4b5563}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-select{height:36px;padding:0 .75rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;transition:all .2s ease}.pagination-select:hover{border-color:#9ca3af}.pagination-select:focus{outline:none;border-color:#075079;box-shadow:0 0 0 2px #0750791a}.pagination-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#4b5563}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;color:#075079}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb}.pagination-page{font-size:.875rem;font-weight:500;color:#374151;padding:0 .75rem;min-width:60px;text-align:center}@media (max-width: 768px){.pagination{flex-direction:column;padding:1rem;gap:.75rem}.pagination-info{font-size:.8rem;text-align:center}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-select{height:32px;font-size:.8rem}.pagination-btn{width:32px;height:32px}.pagination-page{font-size:.8rem;min-width:50px}}.teacher-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-top:1rem}.teacher-section:first-of-type{margin-top:0}.teacher-section-header{display:grid;grid-template-columns:1fr 1fr 1fr 32px;gap:1rem;align-items:center;margin-bottom:.5rem}.teacher-section-header label{font-weight:600;color:#1f2937;font-size:.875rem}.teacher-section-header .header-col-label{font-size:.875rem;color:#374151;font-weight:500}.btn-add-teacher{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:#fff;background:#075079;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-add-teacher:hover{background:#053d5c;transform:scale(1.05)}.teacher-entry{padding:.75rem;margin-bottom:.5rem;background:#fff;border-radius:6px;border:1px solid #e5e7eb}.teacher-entry:last-child{margin-bottom:0}.teacher-entry-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.teacher-select-group{flex:1;margin-bottom:0}.teacher-select-group .react-select-container{width:100%}.btn-remove-teacher{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-remove-teacher:hover{background:#fee2e2;border-color:#f87171}.teacher-dates-row{display:flex;gap:.75rem}.teacher-dates-row .form-group{flex:1;margin-bottom:0}.teacher-dates-row .form-group label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.teacher-dates-row .form-input{font-size:.875rem}.edit-schedule-tabs{display:flex;gap:0;margin-top:1rem;border-bottom:2px solid #e5e7eb}.edit-schedule-tab{padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;color:#6b7280;background:transparent;border:none;cursor:pointer;transition:all .2s ease;position:relative}.edit-schedule-tab:hover{color:#075079}.edit-schedule-tab.active{color:#075079;font-weight:600}.edit-schedule-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#075079}.schedule-info-group{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-top:1rem}.schedule-info-group .form-group{margin-top:1rem}.schedule-info-group .form-group:first-child{margin-top:0}.form-row-3cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.form-col{display:flex;flex-direction:column;gap:.75rem}.form-col .form-group{margin-bottom:0}.teacher-entry-3cols{display:grid;grid-template-columns:1fr 1fr 1fr 32px;gap:1rem;align-items:center;margin-bottom:.5rem}.teacher-entry-3cols:last-child{margin-bottom:0}.teacher-entry-3cols .form-group{margin-bottom:0}.teacher-entry-3cols .form-input{font-size:.875rem}.teacher-entry-3cols .teacher-select-group{min-width:0}.teacher-entry-group{padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid #e5e7eb}.teacher-entry-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.teacher-entry-group .teacher-entry-3cols{margin-bottom:.5rem}.teacher-entry-extra{display:grid;grid-template-columns:1fr 1fr 1fr 32px;gap:1rem;padding-top:.5rem;border-top:1px dashed #e5e7eb;align-items:end}.teacher-entry-extra .form-group{margin-bottom:0}.teacher-entry-extra .form-input{font-size:.875rem}.teacher-entry-extra .teacher-note-group{grid-column:2 / 5}@media (max-width: 768px){.form-row-3cols{grid-template-columns:1fr}.teacher-section-header{grid-template-columns:1fr 32px}.teacher-entry-3cols{grid-template-columns:1fr 32px;gap:.5rem}.teacher-entry-3cols .form-group:nth-child(2),.teacher-entry-3cols .form-group:nth-child(3){grid-column:1}}@media (max-width: 576px){.teacher-section{padding:.75rem}.teacher-dates-row{flex-direction:column;gap:.5rem}.teacher-entry{padding:.5rem}}.checkbox-column{width:40px!important;text-align:center!important;padding:.75rem .5rem!important}.checkbox-column input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#075079}.selected-row{background:#eff6ff!important}.selected-row:hover{background:#dbeafe!important}.btn-batch-add-offday{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff;color:#075079}.btn-batch-add-offday:hover:not(:disabled){background:#e0f2fe;transform:translateY(-1px)}.btn-batch-add-offday:disabled{opacity:.6;cursor:not-allowed}.header-actions{display:flex;gap:.75rem;align-items:center}.bulk-offday-modal{max-width:500px}.bulk-offday-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:.75rem 1rem;margin-bottom:1.5rem}.bulk-offday-info p{margin:0;color:#1e40af;font-weight:500;font-size:.875rem}.bulk-offday-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.bulk-offday-form .form-group{margin-bottom:1rem}.bulk-offday-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}@media (max-width: 768px){.batch-action-bar{flex-direction:column;gap:12px;padding:12px 16px}.batch-action-info{width:100%;justify-content:space-between}.batch-action-buttons{width:100%}.btn-batch-add-offday{flex:1;justify-content:center;padding:10px 12px}}@media (max-width: 576px){.bulk-offday-form .form-row{grid-template-columns:1fr}.header-actions{flex-direction:column;width:100%}.header-actions button{width:100%}}.settings-tabs{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.tabs-dropdown-mobile{display:none;width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:.875rem;font-weight:500;color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.tabs-dropdown-mobile:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.tabs-nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.tab-item{display:inline-flex;align-items:center;padding:10px 16px;font-size:.875rem;font-weight:500;color:#4b5563;background:transparent;border:none;border-radius:8px;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;overflow:hidden}.tab-item:hover{color:#1f2937;background:#f3f4f6;transform:translateY(-1px)}.tab-item.active{color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);font-weight:600;box-shadow:0 4px 12px #07507966}.tab-item.active:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.tab-item.active:hover:before{left:100%}.tab-item:focus{outline:2px solid #075079;outline-offset:2px}.settings-content{color:#4b5563;min-height:200px}.settings-content p{margin:0;font-size:1rem}.tab-panel{width:100%;text-align:left}.tab-panel h3{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 1.5rem}.tab-panel h4{font-size:1.125rem;font-weight:600;color:#374151;margin:1.5rem 0 1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-input{width:100%;max-width:500px;padding:.625rem .875rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937}.form-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.form-input::placeholder{color:#9ca3af}.file-name{font-size:.875rem;color:#4b5563;margin-top:.5rem}.btn-primary{padding:.625rem 1.5rem;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0750794d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #07507966;background:linear-gradient(135deg,#086491,#0b7bb8)}.btn-primary:active{transform:translateY(0)}.btn-edit{padding:.375rem .875rem;font-size:.875rem;font-weight:500;color:#075079;background:transparent;border:1px solid #075079;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-edit:hover{background:#075079;color:#fff}.btn-secondary{padding:.375rem .875rem;font-size:.875rem;font-weight:500;color:#6b7280;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#e5e7eb;color:#4b5563}.btn-delete{padding:.375rem .875rem;font-size:.875rem;font-weight:500;color:#dc2626;background:transparent;border:1px solid #dc2626;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-delete:hover{background:#dc2626;color:#fff}.data-table .btn-primary{padding:.375rem .875rem;font-size:.875rem;font-weight:500}.table-container{overflow-x:auto;margin-bottom:2rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background:#fff}.data-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.data-table td{padding:.875rem 1rem;color:#4b5563;border-bottom:1px solid #e5e7eb}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#f9fafb}.form-section{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid #e5e7eb}.inline-form{display:flex;gap:1rem;align-items:flex-end;margin-bottom:2rem;padding:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a}.inline-form-group{flex:1;display:flex;flex-direction:column;min-width:0}.inline-form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem;white-space:nowrap}.inline-form-group .form-input{max-width:none}.btn-inline{flex-shrink:0;align-self:flex-end;white-space:nowrap}@media (max-width: 992px){.data-table{min-width:600px;font-size:.8125rem}.data-table th,.data-table td{padding:.625rem .5rem}.data-table .btn-edit,.data-table .btn-delete,.data-table .btn-primary,.data-table .btn-secondary{padding:.25rem .4rem!important;font-size:.7rem!important;white-space:nowrap;width:auto!important;display:inline-block;margin-right:.25rem!important}.data-table .btn-edit:last-child,.data-table .btn-delete:last-child,.data-table .btn-primary:last-child,.data-table .btn-secondary:last-child{margin-right:0!important}.data-table td:last-child{white-space:nowrap;min-width:130px;padding-left:.25rem!important;padding-right:.25rem!important}}@media (max-width: 768px){.tabs-dropdown-mobile{display:block}.tabs-nav{display:none}.inline-form{flex-direction:column;align-items:stretch}.inline-form-group label{white-space:normal}.btn-inline{align-self:stretch;width:100%}}.tab-item.active:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #667eea}.form-group>div:hover .logo-hover-text{opacity:1!important}.report-page{width:100%;padding:0}.report-tabs{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.report-filter{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.report-filter label{font-size:.8125rem;font-weight:600;color:#374151;white-space:nowrap}.filter-select{padding:.5rem 2rem .5rem .75rem;font-size:.8125rem;font-weight:500;color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.filter-select:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.report-tabs .tabs-dropdown-mobile{display:none;width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:.875rem;font-weight:500;color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.report-tabs .tabs-dropdown-mobile:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.report-tabs .tabs-nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.report-tabs .tab-item{display:inline-flex;align-items:center;padding:10px 16px;font-size:.875rem;font-weight:500;color:#4b5563;background:transparent;border:none;border-radius:8px;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;overflow:hidden}.report-tabs .tab-item:hover{color:#1f2937;background:#f3f4f6;transform:translateY(-1px)}.report-tabs .tab-item.active{color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);font-weight:600;box-shadow:0 4px 12px #07507966}.report-tabs .tab-item.active:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.report-tabs .tab-item.active:hover:before{left:100%}.report-tabs .tab-item:focus{outline:2px solid #075079;outline-offset:2px}.report-content{padding:0}.tab-panel{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#075079;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container span{color:#6b7280;font-size:.9375rem}.stats-total-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 2rem;background:linear-gradient(135deg,#1e88e5,#5e35b1);border-radius:16px;margin-bottom:1.5rem;box-shadow:0 8px 32px #1e88e559;position:relative;overflow:hidden}.stats-total-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);pointer-events:none}.stats-total-card.teachers{background:linear-gradient(135deg,#43a047,#00897b);box-shadow:0 8px 32px #43a04759}.stats-total-card.schedule{background:linear-gradient(135deg,#fb8c00,#e53935);box-shadow:0 8px 32px #fb8c0059}.stats-total-card.staff{background:linear-gradient(135deg,#00acc1,#1e88e5);box-shadow:0 8px 32px #00acc159}.stats-total-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:16px}.stats-total-icon svg{width:32px;height:32px;color:#fff}.stats-total-info{display:flex;flex-direction:column;gap:.25rem}.stats-total-label{font-size:.9375rem;font-weight:500;color:#ffffffe6}.stats-total-value{font-size:2.5rem;font-weight:700;color:#fff;line-height:1}.charts-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.chart-card:hover{box-shadow:0 4px 16px #0000001a}.chart-card h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.chart-card-small{max-width:400px}.chart-card-large{grid-column:span 2}.chart-tooltip{background:#000000d9;padding:.75rem 1rem;border-radius:8px;box-shadow:0 4px 12px #00000026}.chart-tooltip-label{color:#fffc;font-size:.75rem;margin:0 0 .25rem}.chart-tooltip-value{color:#fff;font-size:1.125rem;font-weight:700;margin:0}.stats-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;transition:all .2s ease}.stats-card:hover{box-shadow:0 4px 12px #00000014}.stats-card h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.warning-card{border-color:#fde68a;background:linear-gradient(to bottom,#fffbeb,#fff)}.warning-card h3{color:#92400e}.stats-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.stats-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-radius:8px;transition:all .2s ease}.stats-item:hover{background:#f3f4f6}.stats-item-name{font-size:.875rem;font-weight:500;color:#374151}.stats-item-count{font-size:.875rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#1e88e5,#8e24aa);padding:.25rem .75rem;border-radius:20px;min-width:40px;text-align:center}.stats-item-badge{font-size:.75rem;font-weight:500;color:#6b7280;background:#e5e7eb;padding:.25rem .625rem;border-radius:20px}.stats-item-badge.active{color:#fff;background:linear-gradient(135deg,#43a047,#00897b)}.stats-item-badge.inactive{color:#fff;background:linear-gradient(135deg,#e53935,#d81b60)}.nationality-summary{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.badge-active{font-size:.75rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#43a047,#00897b);padding:.25rem .625rem;border-radius:20px}.badge-inactive{font-size:.75rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#e53935,#d81b60);padding:.25rem .625rem;border-radius:20px}.more-items{text-align:center;color:#9ca3af;font-size:.8125rem;font-style:italic;margin:.5rem 0 0}.empty-state{text-align:center;padding:1.5rem;color:#9ca3af;font-size:.875rem}.empty-state.success{color:#fff;background:linear-gradient(135deg,#43a047,#00897b);border-radius:8px;font-weight:500}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:1.5rem}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 3px #0000001a}.summary-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px}.summary-icon svg{width:24px;height:24px}.summary-icon.green{background:linear-gradient(135deg,#43a047,#00897b);color:#fff}.summary-icon.blue{background:linear-gradient(135deg,#1e88e5,#5e35b1);color:#fff}.summary-icon.orange{background:linear-gradient(135deg,#fb8c00,#e53935);color:#fff}.summary-info{display:flex;flex-direction:column;gap:.125rem}.summary-value{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1}.summary-label{font-size:.8125rem;color:#6b7280}.progress-container{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.progress-bar{flex:1;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#1e88e5,#8e24aa,#e53935);border-radius:6px;transition:width .5s ease;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{to{left:100%}}.progress-text{font-size:1.125rem;font-weight:700;color:#1e88e5;min-width:50px}.progress-note{font-size:.8125rem;color:#6b7280;margin:0}@media (max-width: 1024px){.charts-row{grid-template-columns:1fr}.chart-card-large{grid-column:span 1}.summary-cards{grid-template-columns:1fr}}@media (max-width: 768px){.report-tabs{flex-direction:column;align-items:stretch;gap:.75rem}.report-tabs .tabs-dropdown-mobile{display:block}.report-tabs .tabs-nav{display:none}.report-filter{justify-content:space-between}.filter-select{flex:1}.stats-total-card{padding:1.25rem 1.5rem}.stats-total-icon{width:50px;height:50px}.stats-total-icon svg{width:28px;height:28px}.stats-total-value{font-size:2rem}.chart-card{padding:1rem}.chart-card-small{max-width:none}}.recharts-default-tooltip{background:#000000d9!important;border:none!important;border-radius:8px!important;box-shadow:0 4px 12px #00000026!important}.recharts-tooltip-label{color:#fffc!important}.recharts-tooltip-item{color:#fff!important}.recharts-pie-label-text{font-size:11px!important;fill:#374151!important}.recharts-cartesian-axis-tick-value{fill:#6b7280;font-size:12px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#e5e7eb}.schedule-page{width:100%;padding:0}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;flex-wrap:wrap;gap:1rem;border-bottom:2px solid #e5e7eb}.schedule-page .filters-container{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;flex:1}.schedule-page .filter-group{display:flex;align-items:center}.schedule-page .filter-input{height:42px;padding:0 .875rem;font-size:.875rem;line-height:1.5;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;min-width:200px;box-sizing:border-box}.schedule-page .filter-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.schedule-page .filter-input::placeholder{color:#9ca3af}.schedule-page .date-input{min-width:150px}.schedule-page .filter-select{min-width:180px}.schedule-page .btn-reset-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0}.schedule-page .btn-reset-filter svg{width:20px;height:20px}.schedule-page .btn-reset-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.schedule-page .btn-reset-filter:active{background:#e5e7eb}.schedule-page .btn-mobile-filter{display:none}.schedule-page .loading-state{text-align:center;padding:3rem;color:#4b5563;font-size:1rem}.schedule-page .table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 3px #0000001a}.schedule-page .data-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:auto;margin:0}.schedule-page .data-table thead{background:linear-gradient(135deg,#075079,#0a6ca0)!important}.schedule-page .data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff!important;border-bottom:2px solid #075079;white-space:nowrap}.schedule-page .data-table td{padding:1rem;color:#4b5563}.schedule-page .data-table tbody tr{border-bottom:1px solid #e5e7eb}.schedule-page .data-table tbody tr:last-child{border-bottom:1px solid #e5e7eb}.schedule-page .data-table tbody tr:nth-child(2n){background:#f9fafb}.schedule-page .data-table tbody tr:hover{background:#f0f9ff}.schedule-page .attendance-table{min-width:900px}.schedule-page .attendance-table th,.schedule-page .attendance-table td{white-space:nowrap;vertical-align:middle}.schedule-page .date-col{width:110px;max-width:110px;min-width:110px;white-space:normal;text-align:left}.schedule-page .date-col .date-day{font-weight:500;color:#1f2937}.schedule-page .date-col .date-main{font-size:.85em;color:#6b7280;margin-top:2px}.schedule-page .teacher-name{font-weight:500;color:#1f2937}.schedule-page .clickable-link{color:#075079;cursor:pointer;transition:color .2s ease}.schedule-page .clickable-link:hover{color:#0369a1;text-decoration:underline}.schedule-page .add-teacher-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px dashed #d1d5db;border-radius:6px;background:#f9fafb;color:#9ca3af;cursor:pointer;transition:all .2s ease}.schedule-page .add-teacher-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#6b7280}.schedule-page .add-teacher-btn svg{width:16px;height:16px}.schedule-page .teacher-cell,.schedule-page .assistant-cell{text-align:left}.schedule-page .teacher-cell .add-teacher-btn,.schedule-page .assistant-cell .add-teacher-btn{margin:0}.schedule-page .clickable-cell{cursor:pointer}.schedule-page .empty-state{text-align:center;padding:3rem!important;color:#9ca3af;font-style:italic}.schedule-page .today-row{background-color:#fef3c7!important}.schedule-page .today-row:hover{background-color:#fde68a!important}.schedule-page .today-badge{font-weight:600;color:#92400e;white-space:nowrap}.schedule-page .substitute-row{background-color:#fff7ed!important}.schedule-page .substitute-row:hover{background-color:#ffedd5!important}.schedule-page .substitute-badge{font-size:.7rem;color:#ea580c;font-weight:500;margin-top:.25rem}.schedule-page .assistant-badge{font-size:.7rem;color:#16a34a;font-weight:500;margin-top:.25rem}.schedule-page .minutes-cell{font-weight:600;color:#075079}.schedule-page .text-center{text-align:center}.schedule-page .status-cell{vertical-align:middle!important;text-align:left}.schedule-page .status-cell .status-content{display:inline-flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.25rem}.schedule-page .attendance-status{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.schedule-page .attendance-status.status-confirmed{background-color:#d1fae5;color:#065f46}.schedule-page .attendance-status.status-cancelled{background-color:#fee2e2;color:#991b1b}.schedule-page .attendance-status.status-pending{background-color:#e5e7eb;color:#4b5563}.schedule-page .cancel-reason{font-size:.75rem;color:#991b1b;margin-top:.25rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-page .substitute-info{font-size:.7rem;color:#ea580c;font-weight:500;margin-top:.25rem}.schedule-page .attendance-actions{display:flex;gap:.5rem;justify-content:center}.schedule-page .btn-confirm,.schedule-page .btn-cancel-attendance{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.schedule-page .btn-confirm{background-color:#d1fae5;color:#065f46}.schedule-page .btn-confirm:hover:not(:disabled){background-color:#a7f3d0}.schedule-page .btn-confirm.active{background-color:#10b981;color:#fff}.schedule-page .btn-confirm:disabled{opacity:.5;cursor:not-allowed}.schedule-page .btn-cancel-attendance{background-color:#fee2e2;color:#991b1b}.schedule-page .btn-cancel-attendance:hover:not(:disabled){background-color:#fecaca}.schedule-page .btn-cancel-attendance.active{background-color:#ef4444;color:#fff}.schedule-page .btn-cancel-attendance:disabled{opacity:.5;cursor:not-allowed}.schedule-page .btn-confirm svg,.schedule-page .btn-cancel-attendance svg{width:18px;height:18px}.cancel-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.cancel-info .info-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid #e5e7eb;font-size:.875rem}.cancel-info .info-row:last-child{border-bottom:none}.cancel-info .info-label{font-weight:600;color:#4b5563;min-width:80px;flex-shrink:0}.cancel-info .info-value{color:#1f2937;word-break:break-word}.substitute-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;max-height:200px;overflow-y:auto}.substitute-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.875rem;color:#1f2937;text-align:left}.substitute-item:hover{border-color:#075079;background:#f0f9ff}.substitute-item.selected{border-color:#075079;background:#eff6ff}.substitute-item .check-icon{width:18px;height:18px;color:#075079;flex-shrink:0}.substitute-loading{font-size:.75rem;color:#6b7280;padding:.5rem 0}.no-substitute{font-size:.8rem;color:#9ca3af;font-style:italic;padding:.5rem 0}.substitute-note{font-size:.75rem;color:#075079;margin-top:.5rem;font-style:italic}.schedule-page .modal-small{max-width:520px}.schedule-page .modal-small .modal-body,.modal-body-content{padding:1.5rem}.modal-teacher-popup .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#fff}.schedule-page .form-group{margin-bottom:1rem}.schedule-page .form-group label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.schedule-page .form-group .form-input{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;box-sizing:border-box}.schedule-page .form-group .form-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.schedule-page .form-group textarea.form-input{resize:vertical;min-height:80px}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.btn-secondary{padding:.625rem 1.25rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.btn-danger{padding:.625rem 1.25rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.schedule-header{flex-direction:row;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:.75rem}.schedule-page .btn-mobile-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0;order:1}.schedule-page .btn-mobile-filter svg{width:20px;height:20px}.schedule-page .btn-mobile-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.schedule-page .btn-mobile-filter:active{background:#e5e7eb}.schedule-page .filters-container{display:flex;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:.75rem;width:100%;flex-basis:100%;order:3;overflow:hidden;max-height:0;padding:0 1rem;opacity:0;margin-top:0;transition:max-height .4s ease,padding .4s ease,opacity .3s ease,margin-top .4s ease}.schedule-page .filters-container.show-mobile{max-height:800px;padding:1rem;opacity:1;margin-top:0}.schedule-page .filter-group{flex:none;width:100%;min-width:0}.schedule-page .filter-input,.schedule-page .filter-select{width:100%;min-width:0}.schedule-page .btn-reset-filter{flex-shrink:0;width:42px}.schedule-page .data-table{font-size:.75rem}.schedule-page .data-table th,.schedule-page .data-table td{padding:.75rem .5rem}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.schedule-page .lesson-cell{white-space:nowrap}.schedule-page .lesson-cell .lesson-name{font-weight:500}.schedule-page .lesson-cell .lesson-time{font-size:.8125rem;color:#6b7280;margin-top:2px}.schedule-page .note-cell{max-width:200px;font-size:.8125rem;color:#4b5563}.schedule-page .note-cell .note-item{padding:2px 0;line-height:1.4}.schedule-page .note-cell .note-item:not(:last-child){border-bottom:1px solid #e5e7eb;margin-bottom:2px;padding-bottom:4px}.schedule-page .note-cell .bonus-item{color:#059669;font-weight:500}.current-substitute{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;gap:12px}.current-substitute .substitute-name{font-size:.875rem;font-weight:500;color:#166534}.current-substitute .btn-remove-substitute{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#fff;border:1px solid #fca5a5;border-radius:6px;color:#dc2626;cursor:pointer;transition:all .2s ease}.current-substitute .btn-remove-substitute:hover{background:#fef2f2;border-color:#f87171}.current-substitute .btn-remove-substitute:disabled{opacity:.5;cursor:not-allowed}.schedule-page .stt-col{width:55px;min-width:55px;max-width:55px;text-align:center!important;vertical-align:middle}.schedule-page .checkbox-col{width:40px;min-width:40px;max-width:40px;text-align:center;vertical-align:middle}.schedule-page .checkbox-col input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#075079}.schedule-page .selected-row{background-color:#eff6ff!important}.schedule-page .selected-row:hover{background-color:#dbeafe!important}.batch-action-bar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#075079,#0a6ca0);padding:12px 20px;border-radius:10px;margin-bottom:16px;box-shadow:0 4px 12px #0750794d;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.batch-action-info{display:flex;align-items:center;gap:12px}.batch-action-info .selected-count{font-size:.9rem;font-weight:600;color:#fff}.btn-clear-selection{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease}.btn-clear-selection:hover{background:#ffffff4d}.batch-action-buttons{display:flex;gap:10px}.btn-batch-confirm,.btn-batch-cancel{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-batch-confirm{background:#fff;color:#065f46}.btn-batch-confirm:hover:not(:disabled){background:#d1fae5;transform:translateY(-1px)}.btn-batch-cancel{background:#fef2f2;color:#991b1b}.btn-batch-cancel:hover:not(:disabled){background:#fee2e2;transform:translateY(-1px)}.btn-batch-confirm:disabled,.btn-batch-cancel:disabled{opacity:.6;cursor:not-allowed;transform:none}.batch-confirm-info,.batch-cancel-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:16px}.batch-confirm-info p,.batch-cancel-info p{font-size:.9rem;color:#374151;margin:0 0 12px;font-weight:500}.batch-items-preview{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.batch-item-preview{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:.8125rem}.batch-item-preview .preview-date{font-weight:600;color:#075079;min-width:90px}.batch-item-preview .preview-lesson{flex:1;color:#374151}.batch-item-preview .preview-school{color:#6b7280;font-size:.75rem}.more-items{font-size:.8125rem;color:#6b7280;font-style:italic;margin:8px 0 0;text-align:center}@media (max-width: 768px){.batch-action-bar{flex-direction:column;gap:12px;padding:12px 16px}.batch-action-info{width:100%;justify-content:space-between}.batch-action-buttons{width:100%;justify-content:stretch}.btn-batch-confirm,.btn-batch-cancel{flex:1;justify-content:center;padding:10px 12px}.batch-item-preview{flex-wrap:wrap;gap:4px 8px}.batch-item-preview .preview-date{min-width:auto}.batch-item-preview .preview-school{width:100%;margin-top:4px}}.schedule-page .clickable-row{cursor:pointer;transition:background-color .2s ease}.schedule-page .clickable-row:hover{background-color:#f0f9ff}.schedule-detail-modal{max-width:600px;width:100%}.modal-header-actions{display:flex;align-items:center;gap:8px}.btn-copy-image{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f3f4f6;border:none;border-radius:6px;cursor:pointer;color:#4b5563;transition:all .2s ease}.btn-copy-image:hover{background:#e5e7eb;color:#075079}.schedule-detail-modal .modal-body{padding:20px}.schedule-detail-content{display:flex;flex-direction:column;gap:20px}.detail-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.detail-section-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:#075079;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.detail-section-title svg{color:#075079}.detail-row{display:flex;align-items:flex-start;gap:12px;padding:8px 0}.detail-row:not(:last-child){border-bottom:1px dashed #e5e7eb}.detail-label{font-size:.8125rem;font-weight:500;color:#6b7280;min-width:100px;flex-shrink:0}.detail-value{font-size:.875rem;font-weight:500;color:#1f2937;flex:1}.detail-link{display:inline-flex;align-items:center;gap:6px;color:#075079;text-decoration:none;font-weight:600}.detail-link:hover{text-decoration:underline;color:#0a6ca0}.location-actions{display:flex;align-items:center;gap:12px}.btn-copy-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease}.btn-copy-link:hover{background:#e5e7eb;color:#075079;border-color:#075079}.detail-sub{font-size:.8125rem;color:#6b7280;font-weight:400}.detail-value .badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:600;margin-left:8px}.detail-value .badge-substitute{background:#fef3c7;color:#92400e}.detail-value .badge-assistant{background:#dbeafe;color:#1e40af}.detail-value.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8rem}.detail-value.status-confirmed{background:#d1fae5;color:#065f46}.detail-value.status-cancelled{background:#fee2e2;color:#991b1b}.detail-value.status-pending{background:#fef3c7;color:#92400e}@media (max-width: 480px){.schedule-detail-modal{max-width:100%;margin:16px}.detail-row{flex-direction:column;gap:4px}.detail-label{min-width:auto}}.popup-info-grid{display:flex;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;gap:16px}.popup-info-col{flex:1;display:flex;flex-direction:column;gap:8px}.popup-info-divider{width:1px;background-color:#e5e7eb;align-self:stretch}.popup-info-item{display:flex;align-items:baseline;gap:6px}.popup-info-label{font-size:.8125rem;font-weight:600;color:#6b7280;white-space:nowrap;min-width:65px;flex-shrink:0}.popup-info-value{font-size:.875rem;font-weight:500;color:#1f2937;word-break:break-word;flex:1}@media (max-width: 480px){.popup-info-grid{flex-direction:column}.popup-info-divider{width:100%;height:1px}}.schedule-teachers-page{width:100%;padding:0}.schedule-teachers-page .filters-container{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding-bottom:1rem}.schedule-teachers-page .schedule-legend{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;padding:.75rem 0 1rem;border-bottom:2px solid #e5e7eb}.schedule-teachers-page .legend-item{display:flex;align-items:center;gap:.5rem}.schedule-teachers-page .legend-color{width:16px;height:16px;border-radius:4px;flex-shrink:0}.schedule-teachers-page .legend-normal{background:linear-gradient(135deg,#075079,#0891b2)}.schedule-teachers-page .legend-assistant{background:linear-gradient(135deg,#ea580c,#f97316)}.schedule-teachers-page .legend-substitute{background:linear-gradient(135deg,#7c3aed,#a855f7)}.schedule-teachers-page .legend-off{background:linear-gradient(135deg,#dc2626,#ef4444)}.schedule-teachers-page .legend-text{font-size:.8rem;color:#4b5563;white-space:nowrap}.schedule-teachers-page .filter-group.with-label{display:flex;align-items:center;gap:.5rem}.schedule-teachers-page .filter-group.with-label:last-child{margin-left:auto}.schedule-teachers-page .filter-label{font-size:.875rem;font-weight:500;color:#374151;white-space:nowrap}.schedule-teachers-page .week-nav-wrapper{display:flex;align-items:center;gap:.5rem}.schedule-teachers-page .filter-input.date-picker{min-width:140px;cursor:pointer;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#374151;background:#fff}.schedule-teachers-page .filter-input.date-picker:focus{outline:none;border-color:#075985;box-shadow:0 0 0 3px #0759851a}.schedule-teachers-page .filter-select{padding:.5rem 2rem .5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#374151;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") no-repeat right .5rem center;background-size:1.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.schedule-teachers-page .filter-select:focus{outline:none;border-color:#075985;box-shadow:0 0 0 3px #0759851a}.schedule-teachers-page .week-range{display:flex;align-items:center;gap:.5rem}.schedule-teachers-page .date-separator{color:#6b7280;font-weight:500}.schedule-teachers-page .btn-week-nav{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;color:#374151;transition:all .2s ease}.schedule-teachers-page .btn-week-nav:hover{background:#f3f4f6;border-color:#9ca3af}.schedule-teachers-page .btn-week-nav:active{background:#e5e7eb}.schedule-teachers-page .schedule-table-container{margin-top:1.5rem;overflow-x:auto;cursor:grab}.schedule-teachers-page .schedule-table-container.grabbing{cursor:grabbing}.schedule-teachers-page .schedule-grid-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:900px}.schedule-teachers-page .schedule-grid-table th,.schedule-teachers-page .schedule-grid-table td{border:1px solid #e5e7eb;padding:.75rem;text-align:center;vertical-align:top}.schedule-teachers-page .schedule-grid-table thead th{background:linear-gradient(135deg,#075985,#0369a1);color:#fff;font-weight:600;font-size:.875rem;position:sticky;top:0;z-index:2;vertical-align:middle}.schedule-teachers-page .lesson-header-cell{width:120px;min-width:120px}.schedule-teachers-page .day-header{min-width:110px;text-align:center}.schedule-teachers-page .day-header .day-name{font-weight:600;font-size:.875rem;color:#fff}.schedule-teachers-page .day-header .day-date{font-weight:500;font-size:.75rem;color:#fff;margin-top:2px}.schedule-teachers-page .schedule-grid-table td.lesson-cell{background:#f8fafc;font-weight:500;text-align:center;vertical-align:middle}.schedule-teachers-page .lesson-name{font-weight:600;color:#1e293b}.schedule-teachers-page .lesson-desc{font-size:.75rem;color:#64748b;margin-top:.25rem}.schedule-teachers-page .schedule-cell{min-height:60px;height:auto;background:#fff;transition:background-color .2s ease;vertical-align:top;padding:.5rem}.schedule-teachers-page .schedule-cell.has-schedule{background:#f0f9ff}.schedule-teachers-page .schedule-badge-wrapper{position:relative;margin-bottom:.5rem;cursor:pointer}.schedule-teachers-page .schedule-badge-wrapper:last-child{margin-bottom:0}.schedule-teachers-page .schedule-badge{display:flex;flex-direction:column;padding:.5rem .75rem;background:linear-gradient(135deg,#075079,#0a6ca0);color:#fff;border-radius:6px;font-size:.75rem;cursor:pointer;transition:all .2s ease;text-align:left;min-width:0;width:100%;box-sizing:border-box}.schedule-teachers-page .schedule-badge:hover{transform:scale(1.02);box-shadow:0 4px 8px #0750794d}.schedule-teachers-page .schedule-badge.assistant-badge{background:linear-gradient(135deg,#ea580c,#f97316)}.schedule-teachers-page .schedule-badge.assistant-badge:hover{box-shadow:0 4px 8px #ea580c4d}.schedule-teachers-page .schedule-badge.off-day-badge{background:linear-gradient(135deg,#dc2626,#ef4444)}.schedule-teachers-page .schedule-badge.off-day-badge:hover{box-shadow:0 4px 8px #dc26264d}.schedule-teachers-page .schedule-badge.off-day-badge .time-range{font-weight:700;font-size:.8rem;color:#fff}.schedule-teachers-page .schedule-badge.substitute-badge{background:linear-gradient(135deg,#7c3aed,#a855f7)}.schedule-teachers-page .schedule-badge.substitute-badge:hover{box-shadow:0 4px 8px #7c3aed4d}.schedule-teachers-page .schedule-badge.substitute-badge .substitute-label{font-size:.65rem;font-weight:600;color:#fff;background:#0003;padding:1px 4px;border-radius:3px;margin-top:2px}.schedule-teachers-page .schedule-badge .school-name{font-weight:600;color:#fff;margin-bottom:.125rem;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.schedule-teachers-page .schedule-badge .grade-name{font-size:.7rem;color:#ffffffe6}.schedule-teachers-page .schedule-badge .time-range{font-size:.7rem;color:#ffffffd9;margin-top:.125rem}.schedule-teachers-page .schedule-badge-wrapper[data-tooltip]:not([data-tooltip=""]):hover:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.75rem;white-space:pre-line;z-index:1000;min-width:150px;max-width:250px;text-align:left;pointer-events:none}.schedule-teachers-page .schedule-badge-wrapper[data-tooltip]:not([data-tooltip=""]):hover:before{content:"";position:absolute;top:calc(100% + 2px);left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#000000e6;z-index:1000;pointer-events:none}.schedule-teachers-page .empty-state{text-align:center;padding:3rem;color:#6b7280;font-size:1rem}.schedule-teachers-page .empty-schedule-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:12px;margin-top:1rem}.schedule-teachers-page .empty-schedule-state .empty-icon{width:64px;height:64px;color:#9ca3af;margin-bottom:1rem}.schedule-teachers-page .empty-schedule-state .empty-title{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 .5rem}.schedule-teachers-page .empty-schedule-state .empty-subtitle{font-size:.875rem;color:#6b7280;margin:0;text-align:center;max-width:400px}.schedule-teachers-page .st-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem;animation:modalOverlayFadeIn .25s ease forwards}@keyframes modalOverlayFadeIn{0%{background:#0000}to{background:#00000080}}.schedule-teachers-page .st-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalContentSlideIn .25s ease}@keyframes modalContentSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.schedule-teachers-page .st-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#075985,#0369a1);color:#fff}.schedule-teachers-page .st-modal-header h3{margin:0;font-size:1rem;font-weight:600}.schedule-teachers-page .st-modal-header-actions{display:flex;align-items:center;gap:.5rem}.schedule-teachers-page .st-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#fff;transition:background-color .2s ease}.schedule-teachers-page .st-modal-close:hover{background:#fff3}.schedule-teachers-page .st-modal-close svg{width:20px;height:20px}.schedule-teachers-page .st-btn-copy-image{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#fff;transition:background-color .2s ease}.schedule-teachers-page .st-btn-copy-image:hover{background:#fff3}.schedule-teachers-page .st-modal-body{padding:20px;overflow-y:auto}.schedule-teachers-page .st-detail-content{display:flex;flex-direction:column;gap:20px}.schedule-teachers-page .st-detail-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.schedule-teachers-page .st-detail-section-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:#075079;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.schedule-teachers-page .st-detail-section-title svg{color:#075079;width:20px;height:20px}.schedule-teachers-page .st-detail-row{display:flex;align-items:flex-start;gap:12px;padding:8px 0}.schedule-teachers-page .st-detail-row:not(:last-child){border-bottom:1px dashed #e5e7eb}.schedule-teachers-page .st-detail-label{font-size:.8125rem;font-weight:500;color:#6b7280;min-width:100px;flex-shrink:0}.schedule-teachers-page .st-detail-value{font-size:.875rem;font-weight:500;color:#1f2937;flex:1}.schedule-teachers-page .st-detail-sub{font-size:.8125rem;color:#6b7280;font-weight:400}.schedule-teachers-page .st-location-actions{display:flex;align-items:center;gap:.75rem}.schedule-teachers-page .st-detail-link{display:inline-flex;align-items:center;gap:6px;color:#075079;text-decoration:none;font-weight:600}.schedule-teachers-page .st-detail-link:hover{text-decoration:underline;color:#0a6ca0}.schedule-teachers-page .st-btn-copy-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease}.schedule-teachers-page .st-btn-copy-link:hover{background:#e5e7eb;color:#075079;border-color:#075079}.schedule-teachers-page .st-curriculum-list{display:flex;flex-direction:column;gap:8px}.schedule-teachers-page .st-curriculum-item{display:flex;align-items:center;gap:6px}.schedule-teachers-page .st-curriculum-item svg{color:#075079;flex-shrink:0}.schedule-teachers-page .st-curriculum-name{font-weight:500;color:#1f2937}.schedule-teachers-page .st-curriculum-links{display:inline-flex;gap:4px;margin-left:4px}.schedule-teachers-page .st-curriculum-link{color:#075079;text-decoration:none;font-weight:600;font-size:.8125rem;transition:color .2s ease}.schedule-teachers-page .st-curriculum-link:hover{color:#0a6ca0;text-decoration:underline}@media (max-width: 768px){.schedule-teachers-page .filters-container{flex-wrap:wrap}.schedule-teachers-page .filter-group.with-label{width:100%;flex-wrap:wrap}.schedule-teachers-page .filter-group.with-label:last-child{margin-left:0}.schedule-teachers-page .filter-label{width:100%;margin-bottom:.25rem}.schedule-teachers-page .week-nav-wrapper{width:100%;justify-content:space-between}.schedule-teachers-page .week-range{flex:1;justify-content:center}.schedule-teachers-page .filter-input.date-picker{min-width:110px;flex:1}.schedule-teachers-page .filter-select{width:100%}.schedule-teachers-page .st-modal-content{max-width:100%;margin:16px}.schedule-teachers-page .st-detail-row{flex-direction:column;gap:4px}.schedule-teachers-page .st-detail-label{min-width:auto}}.my-timeline-page{width:100%;padding:0}.my-timeline-page .filter-bar{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.my-timeline-page .filter-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.my-timeline-page .filter-group{display:flex;align-items:center}.my-timeline-page .filter-input{height:42px;padding:0 .875rem;font-size:.875rem;line-height:1.5;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;min-width:150px;box-sizing:border-box}.my-timeline-page .filter-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.my-timeline-page .filter-input::placeholder{color:#9ca3af}.my-timeline-page .date-input{min-width:150px}.my-timeline-page .btn-reset-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0}.my-timeline-page .btn-reset-filter svg{width:20px;height:20px}.my-timeline-page .btn-reset-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.my-timeline-page .btn-reset-filter:active{background:#e5e7eb}.my-timeline-page .table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 3px #0000001a;transition:opacity .2s ease}.my-timeline-page .table-container.loading{opacity:.6;pointer-events:none}.my-timeline-page .data-table{width:100%;border-collapse:collapse;font-size:.875rem;table-layout:auto}.my-timeline-page .data-table thead{background:linear-gradient(135deg,#075079,#0a6ca0)}.my-timeline-page .data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff;border-bottom:2px solid #075079;white-space:nowrap}.my-timeline-page .data-table td{padding:1rem;color:#4b5563}.my-timeline-page .data-table tbody tr{border-bottom:1px solid #e5e7eb}.my-timeline-page .data-table tbody tr:nth-child(2n){background:#f9fafb}.my-timeline-page .data-table tbody tr:last-child{border-bottom:none}.my-timeline-page .data-table tbody tr:hover{background:#f0f9ff}.my-timeline-page .clickable-row{cursor:pointer;transition:background-color .2s ease}.my-timeline-page .clickable-row:hover{background-color:#f0f9ff}.my-timeline-page .stt-col{width:50px;min-width:50px;text-align:center;font-weight:500}.my-timeline-page .date-col{width:100px;min-width:100px;white-space:nowrap}.my-timeline-page .day-col{width:80px;min-width:80px;white-space:nowrap}.my-timeline-page .data-table th.bonus-col,.my-timeline-page .data-table td.bonus-col{width:120px;min-width:120px;text-align:left!important}.my-timeline-page .data-table td.bonus-col{color:#059669;font-weight:500}.my-timeline-page .data-table th:last-child,.my-timeline-page .data-table td:last-child{width:140px!important;min-width:140px!important}.my-timeline-page .lesson-cell .lesson-name{font-weight:500;color:#1f2937}.my-timeline-page .lesson-cell .lesson-time{font-size:.8125rem;color:#6b7280;margin-top:2px}.my-timeline-page .status-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.my-timeline-page .status-confirmed{background-color:#d1fae5;color:#065f46}.my-timeline-page .status-cancelled{background-color:#fee2e2;color:#991b1b}.my-timeline-page .status-pending{background-color:#fef3c7;color:#92400e}.my-timeline-page .today-row{background-color:#fef3c7!important}.my-timeline-page .today-row:hover{background-color:#fde68a!important}.my-timeline-page .today-badge{font-weight:600;color:#92400e;font-size:.75rem}.my-timeline-page .substitute-badge{font-size:.75rem;color:#ea580c;font-weight:500;background:#fff7ed;padding:2px 8px;border-radius:4px}.my-timeline-page .assistant-badge{font-size:.75rem;color:#16a34a;font-weight:500;background:#f0fdf4;padding:2px 8px;border-radius:4px}.my-timeline-page .empty-state{text-align:center;padding:3rem!important;color:#9ca3af;font-style:italic}.my-timeline-page .mt-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem;animation:mtModalOverlayFadeIn .25s ease forwards}@keyframes mtModalOverlayFadeIn{0%{background:#0000}to{background:#00000080}}.my-timeline-page .mt-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:mtModalContentSlideIn .25s ease}@keyframes mtModalContentSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.my-timeline-page .mt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#075985,#0369a1);color:#fff}.my-timeline-page .mt-modal-header h3{margin:0;font-size:1rem;font-weight:600}.my-timeline-page .mt-modal-header-actions{display:flex;align-items:center;gap:.5rem}.my-timeline-page .mt-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#fff;transition:background-color .2s ease}.my-timeline-page .mt-modal-close:hover{background:#fff3}.my-timeline-page .mt-modal-close svg{width:20px;height:20px}.my-timeline-page .mt-btn-copy-image{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#fff;transition:background-color .2s ease}.my-timeline-page .mt-btn-copy-image:hover{background:#fff3}.my-timeline-page .mt-modal-body{padding:20px;overflow-y:auto}.my-timeline-page .mt-detail-content{display:flex;flex-direction:column;gap:20px}.my-timeline-page .mt-detail-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.my-timeline-page .mt-detail-section-title{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:#075079;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.my-timeline-page .mt-detail-section-title svg{color:#075079;width:20px;height:20px}.my-timeline-page .mt-detail-row{display:flex;align-items:flex-start;gap:12px;padding:8px 0}.my-timeline-page .mt-detail-row:not(:last-child){border-bottom:1px dashed #e5e7eb}.my-timeline-page .mt-detail-label{font-size:.8125rem;font-weight:500;color:#6b7280;min-width:100px;flex-shrink:0}.my-timeline-page .mt-detail-value{font-size:.875rem;font-weight:500;color:#1f2937;flex:1}.my-timeline-page .mt-detail-sub{font-size:.8125rem;color:#6b7280;font-weight:400}.my-timeline-page .mt-location-actions{display:flex;align-items:center;gap:.75rem}.my-timeline-page .mt-detail-link{display:inline-flex;align-items:center;gap:6px;color:#075079;text-decoration:none;font-weight:600}.my-timeline-page .mt-detail-link:hover{text-decoration:underline;color:#0a6ca0}.my-timeline-page .mt-btn-copy-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease}.my-timeline-page .mt-btn-copy-link:hover{background:#e5e7eb;color:#075079;border-color:#075079}.my-timeline-page .mt-status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8rem}.my-timeline-page .mt-curriculum-list{display:flex;flex-direction:column;gap:8px}.my-timeline-page .mt-curriculum-item{display:flex;align-items:center;gap:6px}.my-timeline-page .mt-curriculum-item svg{color:#075079;flex-shrink:0}.my-timeline-page .mt-curriculum-name{font-weight:500;color:#1f2937}.my-timeline-page .mt-curriculum-links{display:inline-flex;gap:4px;margin-left:4px}.my-timeline-page .mt-curriculum-link{color:#075079;text-decoration:none;font-weight:600;font-size:.8125rem;transition:color .2s ease}.my-timeline-page .mt-curriculum-link:hover{color:#0a6ca0;text-decoration:underline}.my-timeline-page .note-cell{min-width:150px;max-width:200px}.my-timeline-page .partner-info{font-size:.8125rem;font-weight:500;padding:4px 8px;border-radius:4px;margin-bottom:4px;display:inline-block}.my-timeline-page .partner-info.main-teacher{color:#075079;background:#f0f9ff}.my-timeline-page .partner-info.assistant-teacher{color:#ea580c;background:#fff7ed}.my-timeline-page .partner-info.substitute-teacher{color:#7c3aed;background:#f5f3ff}.my-timeline-page .note-text{font-size:.8125rem;color:#6b7280;font-style:italic}@media (max-width: 768px){.my-timeline-page .filters-container{flex-direction:column;align-items:stretch}.my-timeline-page .filter-group{width:100%}.my-timeline-page .filter-input,.my-timeline-page .filter-select{flex:1;width:100%}.my-timeline-page .mt-modal-content{max-width:100%;margin:16px}.my-timeline-page .mt-detail-row{flex-direction:column;gap:4px}.my-timeline-page .mt-detail-label{min-width:auto}}.my-statistics-page{width:100%;padding:0}.my-statistics-page .filter-bar{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.my-statistics-page .filter-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.my-statistics-page .filter-group{display:flex;align-items:center;gap:.5rem}.my-statistics-page .filter-group label{font-size:.875rem;font-weight:500;color:#4b5563;white-space:nowrap}.my-statistics-page .filter-input{height:42px;padding:0 .875rem;font-size:.875rem;line-height:1.5;border:1px solid #d1d5db;border-radius:8px;transition:all .2s ease;background:#fff;color:#1f2937;min-width:150px;box-sizing:border-box}.my-statistics-page .filter-input:focus{outline:none;border-color:#075079;box-shadow:0 0 0 3px #0750791a}.my-statistics-page .date-input{min-width:150px}.my-statistics-page .btn-filter{display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 1.25rem;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#075079,#0a6ca0);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.my-statistics-page .btn-filter:hover{background:linear-gradient(135deg,#064060,#085a85);box-shadow:0 2px 8px #0750794d}.my-statistics-page .btn-filter:disabled{opacity:.6;cursor:not-allowed}.my-statistics-page .btn-reset-filter{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;color:#4b5563;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s ease;box-sizing:border-box;flex-shrink:0}.my-statistics-page .btn-reset-filter svg{width:20px;height:20px}.my-statistics-page .btn-reset-filter:hover{background:#f3f4f6;color:#075079;border-color:#9ca3af}.my-statistics-page .stats-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.my-statistics-page .summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.my-statistics-page .summary-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;flex-shrink:0}.my-statistics-page .summary-icon svg{width:24px;height:24px}.my-statistics-page .summary-icon.sessions{background:#dbeafe;color:#1d4ed8}.my-statistics-page .summary-icon.substitute{background:#fef3c7;color:#d97706}.my-statistics-page .summary-icon.cancelled{background:#fee2e2;color:#dc2626}.my-statistics-page .summary-icon.hours{background:#ede9fe;color:#7c3aed}.my-statistics-page .summary-content{display:flex;flex-direction:column}.my-statistics-page .summary-value{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1.2}.my-statistics-page .summary-label{font-size:.8125rem;color:#6b7280;margin-top:.125rem}.my-statistics-page .table-container{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 3px #0000001a}.my-statistics-page .data-table{width:100%;border-collapse:collapse;font-size:.875rem}.my-statistics-page .data-table thead{background:linear-gradient(135deg,#075079,#0a6ca0)}.my-statistics-page .data-table th{padding:1rem;text-align:left;font-weight:600;color:#fff;border-bottom:2px solid #075079;white-space:nowrap}.my-statistics-page .data-table td{padding:1rem;color:#4b5563;border-bottom:1px solid #e5e7eb}.my-statistics-page .data-table tbody tr:last-child td{border-bottom:none}.my-statistics-page .data-table tbody tr:nth-child(2n){background:#f9fafb}.my-statistics-page .data-table tbody tr:hover{background:#f0f9ff}.my-statistics-page .data-table td{text-align:left}.my-statistics-page .data-table th:nth-child(3),.my-statistics-page .data-table th:nth-child(4),.my-statistics-page .data-table th:nth-child(5),.my-statistics-page .data-table th:nth-child(6),.my-statistics-page .data-table th:nth-child(7),.my-statistics-page .data-table td:nth-child(3),.my-statistics-page .data-table td:nth-child(4),.my-statistics-page .data-table td:nth-child(5),.my-statistics-page .data-table td:nth-child(6),.my-statistics-page .data-table td:nth-child(7){text-align:center}.my-statistics-page .substitute-badge{display:inline-block;padding:2px 8px;background:#fef3c7;color:#d97706;border-radius:12px;font-size:.75rem;font-weight:600}.my-statistics-page .cancelled-text{color:#dc2626;font-weight:600}.my-statistics-page .stats-total-row{background:#f3f4f6}.my-statistics-page .stats-total-row td{border-top:2px solid #e5e7eb;font-weight:600;color:#1f2937}.my-statistics-page .bonus-col,.my-statistics-page .data-table th:last-child,.my-statistics-page .data-table td:last-child{text-align:center!important}.my-statistics-page .bonus-col{color:#059669;font-weight:500}.my-statistics-page .empty-state{text-align:center;padding:3rem;color:#9ca3af}.my-statistics-page .empty-state svg{width:48px;height:48px;margin:0 auto 1rem;display:block;opacity:.5}.my-statistics-page .empty-state p{font-size:.9375rem;margin:0}@media (max-width: 1024px){.my-statistics-page .stats-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.my-statistics-page .filter-row{flex-direction:column;align-items:stretch}.my-statistics-page .filter-group{width:100%}.my-statistics-page .filter-input{flex:1;width:100%}.my-statistics-page .btn-filter{width:100%}.my-statistics-page .stats-summary{grid-template-columns:1fr}}.curriculum-page{width:100%;padding:0}.curriculum-name{font-weight:500;color:#1f2937}.curriculum-description-cell{font-size:.875rem;color:#6b7280;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.curriculum-page .clickable-row{cursor:pointer;transition:background-color .15s ease}.curriculum-page .clickable-row:hover{background-color:#f3f4f6}.curriculum-links{display:flex;flex-wrap:wrap;gap:.5rem}.curriculum-link{color:#075079;text-decoration:none;font-weight:500;display:inline-block;padding:.25rem .5rem;background:#e0f2fe;border-radius:4px;font-size:.8125rem;transition:all .2s ease}.curriculum-link:hover{background:#075079;color:#fff;text-decoration:none}.curriculum-page .data-table th:nth-child(1),.curriculum-page .data-table td:nth-child(1){width:1%;white-space:nowrap;text-align:center}.curriculum-page .data-table th:last-child,.curriculum-page .data-table td:last-child{width:1%;white-space:nowrap}.curriculum-page .data-table{margin:0}.curriculum-page .data-table tbody tr:last-child{border-bottom:1px solid #e5e7eb}.curriculum-page .data-table tbody tr:nth-child(2n){background:#f9fafb}.curriculum-page .data-table tbody tr:hover{background:#f0f9ff}.curriculum-page .pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;flex-wrap:wrap;gap:1rem;margin-top:0}
