:root{--color-black: #0A0A0A;--color-gray-900: #111827;--color-gray-800: #1F2937;--color-gray-700: #374151;--color-gray-600: #4B5563;--color-gray-500: #6B7280;--color-gray-400: #9CA3AF;--color-gray-300: #D1D5DB;--color-gray-200: #E5E7EB;--color-gray-100: #F3F4F6;--color-gray-50: #F9FAFB;--color-white: #FFFFFF;--color-red-900: #7F1D1D;--color-red-800: #991B1B;--color-red-700: #DC2626;--color-red-600: #EF4444;--color-red-500: #F87171;--color-red-200: #FECACA;--color-red-100: #FEE2E2;--color-red-50: #FEF2F2;--color-primary: var(--color-red-700);--color-primary-hover: var(--color-red-800);--color-primary-light: var(--color-red-100);--color-success: #10B981;--color-success-hover: #059669;--color-success-light: #D1FAE5;--color-success-dark: #065F46;--color-success-bg: #F0FDF4;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-warning-dark: #92400E;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-error-dark: #991B1B;--color-info: #3B82F6;--color-info-light: #DBEAFE;--color-info-dark: #1E40AF;--color-info-hover: #1D4ED8;--color-indigo: #4F46E5;--color-indigo-light: #EEF2FF;--color-violet: #8B5CF6;--color-violet-light: #F5F3FF;--color-text-primary: var(--color-gray-900);--color-text-secondary: var(--color-gray-500);--color-text-muted: var(--color-gray-400);--color-text-inverse: var(--color-white);--color-text-label: var(--color-gray-700);--color-surface: var(--color-white);--color-surface-raised: var(--color-gray-50);--color-surface-sunken: var(--color-gray-100);--color-border: var(--color-gray-300);--color-border-light: var(--color-gray-200);--color-sidebar-bg-from: var(--color-gray-900);--color-sidebar-bg-to: var(--color-black);--color-sidebar-student: #1A1A2E;--color-sidebar-admin-from: #1A1A2E;--color-sidebar-admin-to: #16213E;--color-sidebar-border: rgba(255, 255, 255, .08);--color-sidebar-text: rgba(255, 255, 255, .65);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-2xs: .6875rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: clamp(1.125rem, 1.5vw + .5rem, 1.5rem);--font-size-3xl: clamp(1.5rem, 2vw + .5rem, 2rem);--font-size-4xl: clamp(1.75rem, 2.5vw + .5rem, 2.5rem);--font-size-5xl: clamp(2rem, 3vw + .5rem, 3rem);--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold:800;--spacing-2xs: .125rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-0-75: .75rem;--spacing-1-25: 1.25rem;--page-padding: clamp(1rem, 2vw, 1.5rem);--card-padding: clamp(.875rem, 1.5vw, 1.5rem);--avatar-size: 2.25rem;--btn-padding-v: .625rem;--modal-max-width: 43.75rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--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);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-card: 0 1px 4px rgba(0, 0, 0, .06);--shadow-card-hover: 0 6px 16px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .28s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 13.75rem;--topbar-height: 4.375rem;--topbar-height-mobile: 3.5rem;--z-dropdown: 50;--z-overlay: 99;--z-sidebar: 100;--z-modal: 200;--z-toast: 300}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{height:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{height:100%;font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-surface-sunken);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}img,video,svg{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer}a{color:inherit;text-decoration:none}:focus:not(:focus-visible){outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.btn:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 5px var(--color-primary-light)}.nav-item:focus-visible{outline:2px solid var(--color-white);outline-offset:-2px}.form-input:focus,.form-input:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-between-start{display:flex;justify-content:space-between;align-items:flex-start}.flex-center{display:flex;justify-content:center;align-items:center}.inline-flex-center{display:inline-flex;align-items:center;justify-content:center}.grid{display:grid}.grid-full-span{grid-column:1 / -1}.mb-0{margin-bottom:0}.mb-2xs{margin-bottom:var(--spacing-2xs)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mb-2xl{margin-bottom:var(--spacing-2xl)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.p-2xl{padding:var(--spacing-2xl)}.px-sm{padding-left:var(--spacing-sm);padding-right:var(--spacing-sm)}.px-md{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.py-sm{padding-top:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.py-md{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-0-75{gap:var(--spacing-0-75)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.text-2xs{font-size:var(--font-size-2xs)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.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)}.text-4xl{font-size:var(--font-size-4xl)}.text-5xl{font-size:var(--font-size-5xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-extrabold{font-weight:var(--font-weight-extrabold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-tight{line-height:1.2}.leading-snug{line-height:1.375}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-label{color:var(--color-text-label)}.text-inverse{color:var(--color-text-inverse)}.text-success{color:var(--color-success-dark)}.text-warning{color:var(--color-warning-dark)}.text-error{color:var(--color-error-dark)}.text-info{color:var(--color-info-dark)}.text-white{color:var(--color-white)}.text-indigo{color:var(--color-indigo)}.text-violet{color:var(--color-violet)}.bg-white{background-color:var(--color-white)}.bg-surface{background-color:var(--color-surface-raised)}.bg-sunken{background-color:var(--color-surface-sunken)}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.bg-success-light{background-color:var(--color-success-light)}.bg-success-bg{background-color:var(--color-success-bg)}.bg-warning-light{background-color:var(--color-warning-light)}.bg-error-light{background-color:var(--color-error-light)}.bg-info-light{background-color:var(--color-info-light)}.bg-indigo-light{background-color:var(--color-indigo-light)}.bg-violet-light{background-color:var(--color-violet-light)}.border{border:1px solid var(--color-border)}.border-light{border:1px solid var(--color-border-light)}.border-none{border:none}.border-bottom{border-bottom:1px solid var(--color-border-light)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.w-full{width:100%}.h-full{height:100%}.min-w-0{min-width:0}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}.overflow-y-auto{overflow-y:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.select-none{-webkit-user-select:none;user-select:none}.whitespace-nowrap{white-space:nowrap}.resize-vertical{resize:vertical}.opacity-50{opacity:.5}.pointer-events-none{pointer-events:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-card{box-shadow:var(--shadow-card)}.app{display:flex;height:100vh;height:100dvh;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:linear-gradient(180deg,var(--color-sidebar-bg-from) 0%,var(--color-sidebar-bg-to) 100%);color:var(--color-white);display:flex;flex-direction:column;box-shadow:2px 0 12px #0003}.sidebar--student{background:var(--color-sidebar-student)}.sidebar--admin{background:linear-gradient(180deg,var(--color-sidebar-admin-from) 0%,var(--color-sidebar-admin-to) 100%)}.sidebar-brand{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-sidebar-border);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);min-height:var(--topbar-height)}.sidebar-brand-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.sidebar-brand-label{font-size:var(--font-size-xs);color:#fff9;letter-spacing:.06em;text-transform:uppercase;font-weight:var(--font-weight-medium)}.sidebar-logo{height:3rem;width:auto;max-width:9rem;object-fit:contain}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:var(--radius-full)}.nav-item{padding:var(--btn-padding-v) var(--spacing-md);margin-bottom:var(--spacing-xs);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base);color:var(--color-sidebar-text);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background-color:#ffffff17;color:var(--color-white)}.nav-item.active{background-color:var(--color-primary);color:var(--color-white);font-weight:var(--font-weight-semibold)}.nav-item-locked{opacity:.45;cursor:not-allowed;pointer-events:none}.nav-divider{margin-top:var(--spacing-xl);padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1)}.nav-lock-badge{margin-left:auto;flex-shrink:0;font-size:var(--font-size-2xs);opacity:.65;display:flex;align-items:center;gap:var(--spacing-2xs)}.main-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar-height);flex-shrink:0;background-color:var(--color-surface);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);box-shadow:var(--shadow-sm);gap:var(--spacing-md)}.topbar-title{flex:1;min-width:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-actions{flex-shrink:0;display:flex;align-items:center;gap:var(--spacing-lg)}.topbar-badge{flex-shrink:0;display:inline-flex;align-items:center;padding:.2rem var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;line-height:1}.topbar-badge--primary{background-color:var(--color-primary);color:var(--color-white)}.topbar-badge--success{background-color:var(--color-success);color:var(--color-white)}.topbar-badge--warning{background-color:var(--color-warning);color:var(--color-white)}.user-menu{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:background-color var(--transition-base);border:none;background:none;font-family:inherit;text-align:left}.user-menu:hover{background-color:var(--color-surface-sunken)}.user-avatar{width:var(--avatar-size);height:var(--avatar-size);flex-shrink:0;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-red-900));color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);text-transform:uppercase}.user-info{display:flex;flex-direction:column;line-height:1.3}.user-info-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.2}.user-info-action{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.2}.mobile-nav-trigger{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-sm);flex-direction:column;gap:.3125rem;min-width:2.75rem;min-height:2.75rem;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background-color var(--transition-fast);flex-shrink:0}.mobile-nav-trigger:hover{background-color:var(--color-surface-sunken)}.sidebar .mobile-nav-trigger:hover{background-color:#ffffff1a}.mobile-nav-trigger span{display:block;width:1.375rem;height:2px;background:var(--color-gray-600);border-radius:2px;transition:transform var(--transition-fast),opacity var(--transition-fast)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:var(--z-overlay);animation:overlayFadeIn var(--transition-base) ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.sidebar-overlay.sidebar-open{display:block}.page-content{flex:1;overflow-y:auto;padding:var(--page-padding);scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}.page-content::-webkit-scrollbar{width:6px}.page-content::-webkit-scrollbar-track{background:transparent}.page-content::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.page-header-actions{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.2}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--card-padding);margin-bottom:var(--card-padding)}.card-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--btn-padding-v) var(--spacing-lg);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:1;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none;font-family:inherit}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.btn-secondary{background-color:var(--color-gray-600);color:var(--color-white);border-color:var(--color-gray-600)}.btn-outline{background-color:transparent;color:var(--color-text-primary);border-color:var(--color-border)}.btn-danger{background-color:var(--color-error);color:var(--color-white);border-color:var(--color-error)}.btn-success{background-color:var(--color-success);color:var(--color-white);border-color:var(--color-success)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-700);border-color:var(--color-gray-700)}.btn-outline:hover:not(:disabled){background-color:var(--color-surface-sunken);border-color:var(--color-gray-400)}.btn-danger:hover:not(:disabled){background-color:var(--color-red-700);border-color:var(--color-red-700);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-success:hover:not(:disabled){background-color:var(--color-success-hover);border-color:var(--color-success-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-primary)}.form-input,.input{width:100%;padding:var(--btn-padding-v) var(--spacing-md);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);font-family:inherit;color:var(--color-text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder,.input::placeholder{color:var(--color-text-muted)}.form-input:hover:not(:disabled),.input:hover:not(:disabled){border-color:var(--color-gray-400)}.form-input:disabled,.input:disabled{background-color:var(--color-surface-sunken);color:var(--color-text-secondary);cursor:not-allowed}.input:focus,.input:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}select.form-input,select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239CA3AF'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem;cursor:pointer}.form-error{color:var(--color-error);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.form-help{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border-light);vertical-align:middle}.table th{font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background-color:var(--color-surface-sunken);white-space:nowrap}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-surface-sunken)}.table tbody tr:last-child td{border-bottom:none}.table-cell-accent{font-weight:var(--font-weight-semibold);color:var(--color-primary)}.badge{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;line-height:1.4}.badge-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.badge-error{background-color:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background-color:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background-color:var(--color-gray-200);color:var(--color-gray-700)}.login-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-gray-900) 0%,var(--color-black) 100%);padding:clamp(1rem,4vw,2rem)}.login-card{width:100%;max-width:28.125rem;background-color:var(--color-surface);padding:clamp(1.5rem,5vw,3rem);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl)}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);line-height:1.2}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-md)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,10rem),1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.kpi-card{padding:var(--card-padding);border-radius:var(--radius-xl);border:none;cursor:pointer;box-shadow:var(--shadow-card);transition:transform var(--transition-base),box-shadow var(--transition-base);text-align:left;font-family:inherit;width:100%}.kpi-card:hover{transform:translateY(-.25rem);box-shadow:var(--shadow-card-hover)}.kpi-card:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.kpi-card--blue{background-color:var(--color-info-light)}.kpi-card--green{background-color:var(--color-success-light)}.kpi-card--yellow{background-color:var(--color-warning-light)}.kpi-card--rose{background-color:var(--color-red-100)}.kpi-icon{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm);line-height:1}.kpi-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:1.1;margin-bottom:var(--spacing-xs)}.kpi-value--blue{color:var(--color-info-dark)}.kpi-value--green{color:var(--color-success-dark)}.kpi-value--yellow{color:var(--color-warning-dark)}.kpi-value--rose{color:var(--color-red-900)}.kpi-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.lecon-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.lecon-item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-surface-sunken);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);border:none;font-family:inherit;text-align:left;width:100%}.lecon-item:hover{background-color:var(--color-gray-200)}.lecon-item-info{flex:1;min-width:0}.lecon-date{font-weight:var(--font-weight-semibold);color:var(--color-primary);font-size:var(--font-size-sm);white-space:nowrap}.lecon-name{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-top:var(--spacing-2xs)}.lecon-moniteur{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.0625rem}.state-message{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.state-message--lg{padding:var(--spacing-2xl)}.loading-spinner,.spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .6s linear infinite}.loading-spinner--sm,.spinner--sm{width:1.25rem;height:1.25rem;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.alert-success,.alert-warning,.alert-error,.alert-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);border-width:1px;border-style:solid}.alert-success{background-color:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success-dark)}.alert-warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning-dark)}.alert-error{background-color:var(--color-error-light);border-color:var(--color-error);color:var(--color-error-dark)}.alert-info{background-color:var(--color-info-light);border-color:var(--color-info);color:var(--color-info-dark)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:overlayFadeIn var(--transition-base) ease;padding:var(--spacing-md)}.modal-content{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-height:90vh;overflow-y:auto;padding:var(--spacing-xl);width:100%;max-width:var(--modal-max-width)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light);flex-wrap:wrap}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md)}.form-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,15rem),1fr));gap:var(--spacing-md)}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,12.5rem),1fr));gap:var(--spacing-md);align-items:end}.inscription-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,23.75rem),1fr));gap:var(--spacing-xl);max-width:62.5rem;width:100%}.grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,12.5rem),1fr));gap:var(--spacing-lg)}.grid-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,9.375rem),1fr));gap:var(--spacing-md)}.grid-cols-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,16.25rem),1fr));gap:var(--spacing-lg)}.grid-3-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,13.75rem),1fr));gap:var(--spacing-lg)}.grid-dashboard-mid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,18.75rem),1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,12.5rem),1fr));gap:var(--spacing-lg)}.grid-cards-lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,17.5rem),1fr));gap:var(--spacing-lg)}.calendar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.print-only{display:none}@media print{.print-only{display:block}.sidebar,.topbar,.mobile-nav-trigger,.sidebar-overlay,.btn{display:none!important}.page-content{padding:0;overflow:visible}.card{box-shadow:none;break-inside:avoid}body{background:#fff;color:#000;font-size:12pt}}@media(max-width:768px){.mobile-nav-trigger{display:flex}.sidebar{position:fixed;left:calc(-1 * var(--sidebar-width));top:0;bottom:0;z-index:var(--z-sidebar);transition:left var(--transition-slow)}.sidebar.sidebar-open{left:0}.topbar{height:var(--topbar-height-mobile);padding:0 var(--spacing-md)}.modal-content{width:96%;max-width:none;padding:var(--spacing-lg)}.login-container{align-items:center;padding:var(--spacing-xl) var(--spacing-md)}}@media(max-width:360px){.user-info{display:none}.btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.topbar-title{font-size:var(--font-size-lg)}.topbar-badge{display:none}}
