:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-light: #60a5fa;--color-primary-bg: #eff6ff;--color-success: #10b981;--color-success-bg: #d1fae5;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-danger: #ef4444;--color-danger-bg: #fee2e2;--color-info: #06b6d4;--color-info-bg: #cffafe;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-text: var(--color-gray-900);--color-text-muted: var(--color-gray-600);--color-text-light: var(--color-gray-500);--color-bg: #ffffff;--color-bg-secondary: var(--color-gray-50);--color-border: var(--color-gray-200);--color-border-dark: var(--color-gray-300);--color-dark-bg: #0f172a;--color-dark-border: #1e293b;--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-heading: var(--font-family-base);--font-family-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--border-width-thin: 1px;--border-width-medium: 2px;--border-width-thick: 4px;--border-radius-sm: .25rem;--border-radius-md: .375rem;--border-radius-lg: .5rem;--border-radius-xl: .75rem;--border-radius-2xl: 1rem;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 280px;--header-height: 72px;--container-max-width: 1400px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.text-light{color:var(--color-text-light)}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.mt-0{margin-top:var(--space-0)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:var(--space-0)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded-md{border-radius:var(--border-radius-md)}.rounded-lg{border-radius:var(--border-radius-lg)}.rounded-full{border-radius:var(--border-radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.hidden{display:none!important}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.h-full{height:100%}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-slide-in{animation:slideInRight .4s ease-out forwards}.glass{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.gradient-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.gradient-dark{background:linear-gradient(135deg,#0f172a,#1e293b)}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}body{font-family:var(--font-family-base);color:var(--color-text);background-color:var(--color-bg-secondary);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin-bottom:var(--space-4)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{margin-bottom:var(--space-4);line-height:var(--line-height-normal)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}ul,ol{list-style:none}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}button:focus,input:focus,textarea:focus,select:focus{outline:2px solid var(--color-primary);outline-offset:2px}table{border-collapse:collapse;width:100%}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;background:var(--color-bg-secondary)}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}}.sidebar{background:var(--color-dark-bg);color:#fff;padding:var(--space-6);border-right:1px solid var(--color-dark-border);display:flex;flex-direction:column;gap:var(--space-8);position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar__logo{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#fff;margin-bottom:var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.sidebar__logo .app-logo{width:60%;max-height:80px;height:auto;border-radius:var(--border-radius-md);object-fit:contain}.sidebar__logo .school-name{text-align:center;width:100%;white-space:normal;word-wrap:break-word}.sidebar__nav{display:flex;flex-direction:column;gap:var(--space-2);flex:1}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--border-radius-lg);color:#94a3b8;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.sidebar__nav-item:hover{background:#ffffff0d;color:#fff;transform:translate(-4px);text-shadow:0 2px 8px rgba(0,0,0,.3)}.sidebar__nav-item--active{background:#3b82f61a;color:var(--color-primary-light)}.sidebar__nav-item svg{width:20px;height:20px;flex-shrink:0}.sidebar__nav-item img{width:56px;height:56px;flex-shrink:0;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:12px;padding:8px;background:#ffffff0d;box-shadow:0 2px 4px #0000001a}.sidebar__nav-item:hover img{transform:translate(-8px) translateZ(20px) scale(1.15);box-shadow:0 12px 24px #0006,0 6px 12px #0000004d,0 0 0 1px #ffffff1a;background:#ffffff26;border-radius:14px}.sidebar__nav-item--active img{background:#3b82f633;box-shadow:0 4px 8px #3b82f64d}.sidebar__divider{height:1px;background:#ffffff1a;margin:var(--space-4) 0}.sidebar__section-title{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:var(--space-2);padding:0 var(--space-4)}.main-content{display:flex;flex-direction:column;min-height:100vh}.header{background:#fff;border-bottom:1px solid var(--color-border);padding:var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);position:sticky;top:0;z-index:var(--z-sticky)}.header__title{margin:0}.header__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.header__user{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;padding:var(--space-2) var(--space-3);border-radius:var(--border-radius-lg);transition:background var(--transition-fast)}.header__user:hover{background:var(--color-gray-50)}.header__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.header__avatar{width:40px;height:40px;border-radius:var(--border-radius-full);background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm)}.content{flex:1;padding:var(--space-6);max-width:var(--container-max-width);width:100%;margin:0 auto}@media(max-width:768px){.content{padding:var(--space-4)}}.container{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-4)}.grid{display:grid;gap:var(--space-6)}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}.card{background:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm)}.card__header{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.card__footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end}@media(max-width:1024px){.sidebar{position:fixed;left:-100%;width:var(--sidebar-width);z-index:var(--z-modal);transition:left var(--transition-base)}.sidebar--open{left:0}.app-shell{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--border-radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn--secondary{background:var(--color-gray-100);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-gray-200)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background:#dc2626}.btn--success{background:var(--color-success);color:#fff}.btn--success:hover:not(:disabled){background:#059669}.btn--ghost{background:transparent;color:var(--color-text)}.btn--ghost:hover:not(:disabled){background:var(--color-gray-100)}.btn--gray{background:var(--color-gray-500);color:#fff}.btn--gray:hover:not(:disabled){background:var(--color-gray-600)}.btn--warning{background:var(--color-warning);color:#fff}.btn--warning:hover:not(:disabled){background:#d97706}.btn--sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.btn--lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base)}.btn--block{width:100%}.input,.select,.textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--border-radius-md);background:#fff;transition:all var(--transition-fast)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.input:disabled,.select:disabled,.textarea:disabled{background:var(--color-gray-100);cursor:not-allowed}.input--error{border-color:var(--color-danger)}.input--error:focus{box-shadow:0 0 0 3px #ef44441a}.textarea{resize:vertical;min-height:100px}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2);color:var(--color-text)}.password-container{position:relative;display:flex;align-items:center}.password-toggle{position:absolute;right:var(--space-3);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.password-toggle:hover{color:var(--color-primary)}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-1)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--border-radius-full);text-transform:uppercase;letter-spacing:.025em}.badge--primary{background:var(--color-primary-bg);color:var(--color-primary-dark)}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:#d97706}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--gray{background:var(--color-gray-100);color:var(--color-gray-700)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table thead{background:var(--color-gray-50);border-bottom:2px solid var(--color-border)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text)}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.table tbody tr:hover{background:var(--color-gray-50)}.table--striped tbody tr:nth-child(2n){background:var(--color-gray-50)}.alert{padding:var(--space-4);border-radius:var(--border-radius-md);border:1px solid transparent;display:flex;align-items:flex-start;gap:var(--space-3)}.alert__icon{flex-shrink:0;width:20px;height:20px}.alert__content{flex:1}.alert__title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.alert--info{background:var(--color-info-bg);border-color:var(--color-info);color:#0e7490}.alert--success{background:var(--color-success-bg);border-color:var(--color-success);color:#065f46}.alert--warning{background:var(--color-warning-bg);border-color:var(--color-warning);color:#92400e}.alert--danger{background:var(--color-danger-bg);border-color:var(--color-danger);color:#991b1b}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4);opacity:0;transition:opacity var(--transition-base)}.modal-backdrop--open{opacity:1}.modal{background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform var(--transition-base)}.modal-backdrop--open .modal{transform:scale(1)}.modal__header{padding:var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.modal__close{width:32px;height:32px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--transition-fast)}.modal__close:hover{background:var(--color-gray-100);color:var(--color-text)}.modal__body{padding:var(--space-6)}.modal__footer{padding:var(--space-6);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end}.modal--dashboard{max-width:90vw;max-height:90vh;width:100%}.modal--dashboard .modal__body{padding:var(--space-8);min-height:60vh}.modal-expand-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted)}.modal-expand-btn:hover{color:var(--color-primary)}.modal-expand-btn svg{transition:transform var(--transition-fast)}.modal-expand-btn:hover svg{transform:scale(1.1)}.tabs{border-bottom:1px solid var(--color-border);display:flex;gap:var(--space-2);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--color-text)}.tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--border-radius-full);animation:spin .8s linear infinite}.spinner--sm{width:16px;height:16px;border-width:2px}.spinner--lg{width:40px;height:40px;border-width:4px}.toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--space-3);max-width:400px}.toast{background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-4);display:flex;align-items:flex-start;gap:var(--space-3);border-left:4px solid var(--color-primary);animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast--success{border-left-color:var(--color-success)}.toast--warning{border-left-color:var(--color-warning)}.toast--danger{border-left-color:var(--color-danger)}.toast__content{flex:1}.toast__title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.toast__message{font-size:var(--font-size-sm);color:var(--color-text-muted)}.schedule-card-compact{position:relative}.schedule-card-compact .expanded-content{display:none}.schedule-card-compact.expanded .expanded-content{display:block}.schedule-card-compact.expanded .expand-icon{transform:rotate(180deg)}.schedule-card-compact .expand-icon{transition:transform .2s}.dashboard-container{padding:var(--space-8) var(--space-6);max-width:1600px;margin:0 auto;animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:var(--space-10)}.dashboard-header__content{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-6);flex-wrap:wrap}.dashboard-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-black);color:var(--color-text);letter-spacing:-.025em;margin:0}.dashboard-subtitle{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);margin:var(--space-2) 0 0}.dashboard-header__actions{display:flex;align-items:center;gap:var(--space-4)}.date-range-selector{display:flex;align-items:center;gap:var(--space-3);background:#fff;padding:var(--space-2);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.date-range-selector__field{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);border-right:1px solid var(--color-border)}.date-range-selector__field:last-of-type{border-right:none}.date-range-selector__label{font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.05em}.date-range-selector__input{border:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text);outline:none;background:transparent}.print-header{display:none;margin-bottom:var(--space-10);padding-bottom:var(--space-6);border-bottom:2px solid var(--color-text)}.print-header__content{display:flex;justify-content:space-between;align-items:flex-end}.print-header__title{font-size:2.5rem;font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:-.05em;margin:0 0 var(--space-2)}.print-header__period{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.print-header__org{font-size:var(--font-size-sm);font-weight:var(--font-weight-black);text-transform:uppercase}.print-header__date{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;color:var(--color-text-muted);margin-top:var(--space-1)}.dashboard-filters{background:#fff;padding:var(--space-6);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);margin-bottom:var(--space-10)}.dashboard-filters__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6)}.dashboard-filters__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text);margin:0}.dashboard-filters__subtitle{font-size:10px;color:var(--color-text-muted);margin:var(--space-1) 0 0}.dashboard-filters__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.filter-field{position:relative}.filter-field__label{display:block;font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-2);letter-spacing:.05em}.filter-field__input,.filter-field__select{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);outline:none;transition:border-color var(--transition-fast)}.filter-field__input:focus,.filter-field__select:focus{border-color:var(--color-primary)}.search-results,#studentResults{position:absolute;z-index:1000;width:100%;margin-top:var(--space-1);background:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;display:block}.search-results.hidden,.search-results--hidden,#studentResults.hidden{display:none!important}.student-result-item{padding:var(--space-3);cursor:pointer;border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.student-result-item:last-child{border-bottom:none}.student-result-item:hover{background-color:var(--color-gray-50)}.selected-tag{margin-top:var(--space-2);display:flex;align-items:center;justify-content:space-between;padding:var(--space-2);background-color:var(--color-primary-bg);border-radius:var(--border-radius-lg)}.selected-tag--hidden{display:none}.selected-tag__text{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary-dark)}.selected-tag__remove{background:none;border:none;color:var(--color-primary-dark);cursor:pointer;font-size:var(--font-size-lg);line-height:1;padding:0;transition:color var(--transition-fast)}.selected-tag__remove:hover{color:var(--color-primary)}.quick-date-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.quick-date-btn{padding:var(--space-2) var(--space-2);font-size:10px;font-weight:var(--font-weight-bold);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);background:#fff;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.quick-date-btn:hover{background-color:var(--color-gray-50);border-color:var(--color-primary)}.quick-date-btn--alert{background-color:#fef2f2;color:#ef4444;border-color:#fecaca}.quick-date-btn--alert:hover{background-color:#ef4444;color:#fff!important;border-color:#ef4444}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);margin-bottom:var(--space-10)}.kpi-card{position:relative;background:#fff;padding:var(--space-6);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-card__icon{position:absolute;right:-16px;bottom:-16px;font-size:4.5rem;opacity:0;transition:opacity var(--transition-base)}.kpi-card:hover .kpi-card__icon{opacity:.1}.kpi-card__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-2)}.kpi-card__value{font-size:2.25rem;font-weight:var(--font-weight-black);color:var(--color-text);line-height:1}.kpi-card__subtitle{font-size:10px;font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;margin-top:var(--space-2)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-10);margin-bottom:var(--space-10)}.chart-card{background:#fff;padding:var(--space-8);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.chart-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6)}.chart-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-black);color:var(--color-text);margin:0}.chart-card__subtitle{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-muted);margin:var(--space-1) 0 0}.chart-card__icon{font-size:1.5rem}.chart-card__body{height:350px;position:relative}.data-tables-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);margin-bottom:var(--space-10)}.data-table-card{background:#fff;padding:var(--space-6);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;flex-direction:column}.data-table-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.data-table-card__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text);margin:0}.data-table-card__subtitle{font-size:10px;color:var(--color-text-muted);margin:var(--space-1) 0 0}.data-table-card__selector{font-size:10px;font-weight:var(--font-weight-bold);background-color:var(--color-danger-bg);color:var(--color-danger-dark);padding:var(--space-1) var(--space-2);border-radius:var(--border-radius-md);border:none;outline:none;cursor:pointer}.data-table-card__body{flex-grow:1;overflow-y:auto;max-height:400px}.data-table-card__body::-webkit-scrollbar{width:4px}.data-table-card__body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}.missing-registers-alert{background:linear-gradient(135deg,#fef2f2,#fee2e2);padding:var(--space-8);border-radius:var(--border-radius-2xl);border:1px solid #fecaca;position:relative;overflow:hidden}.missing-registers-alert__content{position:relative;z-index:1}.missing-registers-alert__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:-.025em;color:#7f1d1d;margin:0 0 var(--space-2)}.missing-registers-alert__description{color:#991b1b;font-weight:var(--font-weight-medium);margin:0 0 var(--space-6)}.missing-registers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.btn-text{background:none;border:none;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color var(--transition-fast)}.btn-text--muted{color:var(--color-text-muted)}.btn-text--muted:hover{color:var(--color-text)}.btn--icon{display:flex;align-items:center;gap:var(--space-2)}.loading-placeholder{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}@media print{.no-print{display:none!important}.print-only{display:block!important}.dashboard-container{padding:0}.kpi-grid,.charts-grid,.data-tables-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:20px!important;break-inside:avoid}.kpi-card,.chart-card,.data-table-card{border:1px solid var(--color-border)!important;margin-bottom:2rem!important;break-inside:avoid;box-shadow:none!important}.chart-card__body canvas{max-width:100%!important;height:auto!important}.data-table-card__body{max-height:none!important;overflow:visible!important}}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.data-tables-grid{grid-template-columns:1fr}.dashboard-filters__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-header__content{flex-direction:column}.dashboard-filters__grid,.kpi-grid,.charts-grid{grid-template-columns:1fr}.date-range-selector{flex-direction:column;align-items:stretch}.date-range-selector__field{border-right:none;border-bottom:1px solid var(--color-border)}.date-range-selector__field:last-of-type{border-bottom:none}}.teacher-audit-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-bottom:1px solid var(--color-border)}.teacher-audit-item:last-child{border-bottom:none}.teacher-audit-item__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);flex-shrink:0}.teacher-audit-item__content{flex-grow:1}.teacher-audit-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.teacher-audit-item__name{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text)}.teacher-audit-item__stats{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.teacher-audit-item__progress{height:6px;background:var(--color-gray-100);border-radius:10px;overflow:hidden}.teacher-audit-item__progress-bar{height:100%;transition:width var(--transition-base)}.critical-student-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:#fff;border-radius:var(--border-radius-lg);border:1px solid var(--color-gray-100);transition:all var(--transition-fast)}.critical-student-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.critical-student-item__name{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text)}.critical-student-item__group{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.critical-student-item__count{display:flex;align-items:center;gap:var(--space-2)}.critical-student-item__number{font-size:var(--font-size-lg);font-weight:var(--font-weight-black);color:var(--color-danger)}.observation-item{padding:var(--space-3);border-bottom:1px solid var(--color-border)}.observation-item:last-child{border-bottom:none}.observation-item__header{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-muted);margin-bottom:var(--space-2)}.observation-item__content{font-size:var(--font-size-sm);color:var(--color-text);font-style:italic;margin:var(--space-2) 0}.observation-item__footer{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-2)}.missing-register-item{background:#fff;padding:var(--space-4);border-radius:var(--border-radius-lg);border:1px solid #fecaca}.missing-register-item__time{font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;color:#dc2626;margin-bottom:var(--space-1)}.missing-register-item__subject{font-size:var(--font-size-sm);font-weight:var(--font-weight-black);color:#7f1d1d;margin-bottom:var(--space-1)}.missing-register-item__teacher{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#991b1b}.success-message{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:var(--border-radius-lg);color:#166534;font-weight:var(--font-weight-bold)}.success-message svg{color:#16a34a}.bg-emerald-500{background-color:#10b981}.bg-amber-500{background-color:#f59e0b}.bg-red-500{background-color:#ef4444}.text-danger{color:var(--color-danger)}.text-muted{color:var(--color-text-muted)}.badge--danger{background-color:var(--color-danger-bg);color:var(--color-danger-dark)}.badge--warning{background-color:#fef3c7;color:#92400e}.badge--gray{background-color:var(--color-gray-100);color:var(--color-text-muted)}.badge--indigo{background-color:#e0e7ff;color:#4338ca}.text-slate-800{color:#1e293b}.text-slate-400{color:#94a3b8}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.hover\:bg-slate-50:hover{background-color:#f8fafc}.cursor-pointer{cursor:pointer}.border-b{border-bottom-width:1px}.border-slate-100{border-color:#f1f5f9}.last\:border-0:last-child{border:0}.p-3{padding:var(--space-3)}.text-center{text-align:center}.view--hidden{display:none!important}.dashboard-nav{display:flex;gap:var(--space-2);margin:var(--space-6) 0;border-bottom:2px solid var(--color-gray-100);padding-bottom:2px}.nav-link{padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-4px;transition:all var(--transition-base)}.nav-link:hover{color:var(--color-primary)}.nav-link--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.dashboard-header-modern{display:flex;justify-content:flex-end;margin-bottom:var(--space-4)}.attendance-detail-section{margin:var(--space-10) 0;padding:var(--space-6);background:#fff;border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.attendance-detail-section__header{margin-bottom:var(--space-8)}.attendance-detail-section__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:-.025em;color:var(--color-text);margin:0 0 var(--space-1)}.attendance-detail-section__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.attendance-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}.attendance-summary-card{padding:var(--space-6);border-radius:var(--border-radius-xl);border-left:5px solid;box-shadow:var(--shadow-sm);transition:transform var(--transition-base)}.attendance-summary-card:hover{transform:translateY(-2px)}.attendance-summary-card--total{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left-color:#2563eb}.attendance-summary-card--present{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-left-color:#16a34a}.attendance-summary-card--absent{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-left-color:#dc2626}.attendance-summary-card--late{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-left-color:#d97706}.attendance-summary-card__label{font-size:11px;font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.attendance-summary-card--total .attendance-summary-card__label{color:#1e40af}.attendance-summary-card--present .attendance-summary-card__label{color:#166534}.attendance-summary-card--absent .attendance-summary-card__label{color:#991b1b}.attendance-summary-card--late .attendance-summary-card__label{color:#92400e}.attendance-summary-card__value{font-size:2.25rem;font-weight:var(--font-weight-black);line-height:1}.attendance-summary-card--total .attendance-summary-card__value{color:#1e3a8a}.attendance-summary-card--present .attendance-summary-card__value{color:#064e3b}.attendance-summary-card--absent .attendance-summary-card__value{color:#7f1d1d}.attendance-summary-card--late .attendance-summary-card__value{color:#78350f}.attendance-table-container{overflow-x:auto;border-radius:var(--border-radius-xl);border:1px solid var(--color-border)}.attendance-table{width:100%;border-collapse:collapse;text-align:left}.attendance-table__head{background-color:#6a994e}.attendance-table__th{padding:var(--space-4) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:#fff;text-transform:capitalize}.attendance-table__body tr{border-bottom:1px solid var(--color-gray-100)}.attendance-table__body tr:hover{background-color:#f8fafc}.attendance-table__td{padding:var(--space-4) var(--space-6);font-size:var(--font-size-sm);vertical-align:middle}.attendance-table__student-name{font-weight:var(--font-weight-bold);color:var(--color-dark-bg)}.attendance-table__status-badge{display:inline-flex;align-items:center;padding:4px 14px;border-radius:20px;font-size:11px;font-weight:var(--font-weight-black);text-transform:uppercase;letter-spacing:.025em;border:1px solid transparent}.attendance-table__status-badge--present{background-color:#ecfdf5;color:#10b981;border-color:#a7f3d0}.attendance-table__status-badge--absent{background-color:#fef2f2;color:#ef4444;border-color:#fecaca}.attendance-table__status-badge--late{background-color:#fffbeb;color:#f59e0b;border-color:#fde68a}.attendance-table__status-badge--none{background-color:#f9fafb;color:#6b7280;border-color:#e5e7eb}.attendance-table__comments{color:var(--color-text-muted);font-size:var(--font-size-xs);line-height:1.5}.incid-date{font-weight:var(--font-weight-black);color:var(--color-text);margin-right:4px;font-size:10px}.attendance-incidents-list{font-size:11px;line-height:1.6}.text-emerald-500{color:#10b981}.font-bold{font-weight:var(--font-weight-bold)}@media(max-width:1024px){.attendance-summary-grid{grid-template-columns:repeat(2,1fr)}}.seguimiento-layout{display:flex;flex-direction:column;gap:var(--space-6);animation:fadeIn var(--transition-normal)}.seguimiento-main{width:100%}.critical-students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.filter-group-local select,.filter-group-local input{background-color:#fff!important;border:1px solid var(--color-border)!important;transition:all var(--transition-fast)}.filter-group-local select:focus,.filter-group-local input:focus{border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #6366f11a;outline:none}@media print{.sidebar,.header,.btn,.modal-backdrop,.toast,.spinner,nav,.tabs{display:none!important}.card,.table{box-shadow:none!important;border:1px solid #e5e7eb}.app-shell{grid-template-columns:1fr!important}.content{max-width:100%!important;padding:0!important}body{font-size:11pt;line-height:1.4;color:#000;background:#fff}h1{font-size:18pt;margin-bottom:12pt}h2{font-size:14pt;margin-bottom:10pt}h3{font-size:12pt;margin-bottom:8pt}.table{width:100%;border-collapse:collapse;page-break-inside:avoid}.table th,.table td{padding:6pt 8pt;border:1px solid #d1d5db;text-align:left}.table thead{background:#f3f4f6!important;font-weight:700}.table tbody tr:nth-child(2n){background:#f9fafb!important}.badge{border:1px solid currentColor;padding:2pt 4pt;font-size:9pt}.badge--success{color:#059669}.badge--danger{color:#dc2626}.badge--warning{color:#d97706}.badge--primary{color:#2563eb}.card{page-break-inside:avoid;margin-bottom:12pt}@page{margin:1.5cm;size:A4}@page{@bottom-right{content:"Página " counter(page);font-size:9pt;color:#6b7280}}.grid--3,.grid--4{display:grid;grid-template-columns:repeat(auto-fit,minmax(150pt,1fr));gap:8pt}a[href]:after{content:""}input,select,textarea{border:1px solid #d1d5db}canvas,svg{max-width:100%;page-break-inside:avoid}.app-logo{max-width:80pt;height:auto}.hidden,[style*="display: none"]{display:none!important}.text-danger{color:#dc2626!important}.text-success{color:#059669!important}.text-warning{color:#d97706!important}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
