#root{min-height:100vh;display:flex;flex-direction:column}@media screen and (max-width:767px){input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],select,textarea{font-size:16px}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base)}.slide-down{animation:slideDown var(--transition-base)}.slide-up{animation:slideUp var(--transition-base)}@media print{nav,aside,.no-print{display:none!important}body{background:#fff;color:#000}.card,table,.no-break{page-break-inside:avoid}}.spinner-container{display:inline-flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.spinner-container--centered{width:100%;justify-content:center;padding:var(--spacing-xl) 0}.spinner{display:inline-block;position:relative;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner__circle{box-sizing:border-box;display:block;width:100%;height:100%;border-radius:50%;border-style:solid}.spinner--sm{width:16px;height:16px}.spinner--sm .spinner__circle{border-width:2px}.spinner--md{width:24px;height:24px}.spinner--md .spinner__circle{border-width:3px}.spinner--lg{width:32px;height:32px}.spinner--lg .spinner__circle{border-width:3px}.spinner--xl{width:48px;height:48px}.spinner--xl .spinner__circle{border-width:4px}.spinner--primary .spinner__circle{border-color:var(--color-border-light);border-top-color:var(--color-primary)}.spinner--white .spinner__circle{border-color:#ffffff4d;border-top-color:#fff}.spinner--current .spinner__circle{border-color:currentColor;border-top-color:transparent;opacity:.3}.spinner--current .spinner__circle{opacity:1}.spinner__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);border-radius:var(--radius-full);font-weight:var(--font-weight-medium);line-height:1;white-space:nowrap;vertical-align:middle}.badge--sm{padding:2px var(--spacing-sm);font-size:var(--font-size-xs)}.badge--md{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.badge--lg{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base)}.badge--default{background-color:var(--color-background-tertiary);color:var(--color-text-secondary)}.badge--primary{background-color:var(--color-primary-lightest);color:var(--color-primary)}.badge--success{background-color:var(--color-success-light);color:var(--color-success)}.badge--warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge--error{background-color:var(--color-error-light);color:var(--color-error)}.badge--info{background-color:var(--color-info-light);color:var(--color-info)}.badge--dot{padding-left:var(--spacing-xs)}.badge__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge--success .badge__dot{background-color:var(--color-success)}.badge--warning .badge__dot{background-color:var(--color-warning)}.badge--error .badge__dot{background-color:var(--color-error)}.badge--info .badge__dot{background-color:var(--color-info)}.badge--primary .badge__dot{background-color:var(--color-primary)}.badge--default .badge__dot{background-color:var(--color-text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);border:none;background:none;cursor:pointer;font-family:inherit;text-decoration:none;-webkit-user-select:none;user-select:none;font-weight:var(--font-weight-medium);line-height:1;transition:all var(--transition-fast);border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent}.btn--sm{height:var(--button-height-sm);padding:0 var(--spacing-md);font-size:var(--font-size-sm);min-width:80px}.btn--md{height:var(--button-height-md);padding:0 var(--spacing-lg);font-size:var(--font-size-base);min-width:100px}.btn--lg{height:var(--button-height-lg);padding:0 var(--spacing-xl);font-size:var(--font-size-lg);min-width:120px}.btn--full-width{width:100%;min-width:auto}.btn--primary{background-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn--secondary{background-color:var(--color-secondary);color:#fff;box-shadow:var(--shadow-sm)}.btn--secondary:hover:not(:disabled){background-color:var(--color-secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--secondary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn--danger{background-color:var(--color-error);color:#fff;box-shadow:var(--shadow-sm)}.btn--danger:hover:not(:disabled){background-color:#dc2626;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--danger:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn--success{background-color:var(--color-success);color:#fff;box-shadow:var(--shadow-sm)}.btn--success:hover:not(:disabled){background-color:#059669;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--success:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn--outline{background-color:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn--outline:hover:not(:disabled){background-color:var(--color-primary-lightest);border-color:var(--color-primary-dark);color:var(--color-primary-dark)}.btn--outline:active:not(:disabled){background-color:var(--color-primary-lightest)}.btn--ghost{background-color:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background-color:var(--color-background-secondary);color:var(--color-text-primary)}.btn--ghost:active:not(:disabled){background-color:var(--color-background-tertiary)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn--loading{position:relative;color:transparent!important;pointer-events:none}.btn__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn--loading .btn__text,.btn--loading .btn__icon{opacity:0}.btn__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.btn__icon svg{width:1em;height:1em;fill:currentColor}.btn__text{display:inline-flex;align-items:center}.btn:focus-visible{outline:3px solid var(--color-primary-lightest);outline-offset:2px}@media(hover:none)and (pointer:coarse){.btn--sm{min-height:44px}.btn--md{min-height:48px}.btn--lg{min-height:52px}}@media(min-width:1024px){.btn{gap:var(--spacing-xs)}}.theme-toggle{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);color:var(--color-text-secondary);background-color:transparent;border:1px solid transparent}.theme-toggle:hover{background-color:var(--color-background-secondary);color:var(--color-text-primary);border-color:var(--color-border)}.theme-toggle:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary)}.theme-toggle svg{transition:transform var(--transition-fast)}.theme-toggle:hover svg{transform:scale(1.1)}@media(max-width:767px){.header__right .theme-toggle{padding:var(--spacing-xs);min-width:40px;min-height:40px}.header__right .theme-toggle svg{width:16px;height:16px}}@media(max-width:479px){.theme-toggle{padding:var(--spacing-xs);min-width:44px;min-height:44px;touch-action:manipulation}.theme-toggle svg{width:18px;height:18px}}@media(min-width:480px)and (max-width:767px){.theme-toggle{padding:var(--spacing-sm);min-width:48px;min-height:48px;touch-action:manipulation}.theme-toggle svg{width:20px;height:20px}}@media(min-width:768px)and (max-width:1023px){.theme-toggle{padding:var(--spacing-sm);min-width:48px;min-height:48px;touch-action:manipulation}.theme-toggle svg{width:20px;height:20px}}@media(min-width:1024px){.theme-toggle{padding:var(--spacing-sm);min-width:48px;min-height:48px;touch-action:manipulation}.theme-toggle svg{width:20px;height:20px}}@media(min-width:1440px){.theme-toggle{padding:var(--spacing-md);min-width:52px;min-height:52px;touch-action:manipulation}.theme-toggle svg{width:22px;height:22px}}.header{position:sticky;top:0;left:0;right:0;height:var(--header-height);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--spacing-sm);z-index:var(--z-index-header);box-shadow:var(--shadow-sm)}.header__left{display:flex;align-items:center;gap:var(--spacing-md)}.header__menu-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:none;color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.header__menu-button:hover{background-color:var(--color-background)}.header__menu-button:active{transform:scale(.95)}.header__logo{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.header__logo-image{height:30px;width:30px;object-fit:cover;border-radius:50%}.header__right{display:flex;align-items:center;gap:var(--spacing-xs);margin-left:auto}.header__notifications{position:relative}.header__icon-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:none;color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast);outline:none}.header__icon-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.header__icon-button:hover{background-color:var(--color-background)}.header__badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;background-color:var(--color-error);color:#fff;font-size:11px;font-weight:var(--font-weight-semibold);border-radius:9px;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-surface)}.header__user{position:relative}.header__user-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border:none;background:none;cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast);outline:none}.header__user-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.header__user-button:hover{background-color:var(--color-background)}.header__user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.header__user-avatar--large{width:48px;height:48px;font-size:var(--font-size-lg)}.header__user-info{display:flex!important;flex-direction:column!important;align-items:flex-start;gap:4px;justify-content:center}.header__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;display:block;width:100%}.header__user-chevron{color:var(--color-text-secondary);transition:transform var(--transition-fast)}.header__user-button:hover .header__user-chevron{transform:translateY(2px)}.header__dropdown{position:absolute;top:calc(100% + var(--spacing-xs));right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:280px;max-width:320px;z-index:var(--z-index-dropdown);animation:slideDown var(--transition-base);overflow:hidden}.header__dropdown--notifications{max-height:400px;display:flex;flex-direction:column}.header__dropdown--user{min-width:260px}.header__dropdown-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.header__dropdown-header h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.header__dropdown-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);background-color:var(--color-background);padding:2px 8px;border-radius:var(--radius-full);font-weight:var(--font-weight-medium)}.header__dropdown-content{padding:var(--spacing-xs);overflow-y:auto;max-height:300px}.header__dropdown-footer{padding:var(--spacing-sm);border-top:1px solid var(--color-border-light)}.header__dropdown-link{display:block;text-align:center;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;padding:var(--spacing-xs);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.header__dropdown-link:hover{background-color:var(--color-background)}.header__dropdown-user-info{display:flex;gap:var(--spacing-md);align-items:flex-start}.header__dropdown-user-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 4px}.header__dropdown-user-email{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.header__dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:none;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.header__dropdown-item:hover{background-color:var(--color-background)}.header__dropdown-item svg{color:var(--color-text-secondary);flex-shrink:0}.header__dropdown-item--danger{color:var(--color-error)}.header__dropdown-item--danger svg{color:var(--color-error)}.header__dropdown-item--danger:hover{background-color:var(--color-error-light)}.notification-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.notification-item:hover{background-color:var(--color-background)}.notification-item--unread{background-color:var(--color-primary-light)}.notification-item__icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-item__icon--info{background-color:var(--color-info-light);color:var(--color-info)}.notification-item__icon--success{background-color:var(--color-success-light);color:var(--color-success)}.notification-item__icon--warning{background-color:var(--color-warning-light);color:var(--color-warning)}.notification-item__content{flex:1;min-width:0}.notification-item__text{font-size:var(--font-size-sm);color:var(--color-text-primary);margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.notification-item__time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media(max-width:767px){.header__dropdown{position:fixed;top:var(--header-height);left:var(--spacing-sm);right:var(--spacing-sm);min-width:auto;max-width:none}.header__user-info{display:none!important}}@media(min-width:768px){.header{position:sticky;grid-area:header;padding:0 var(--spacing-lg)}.hidden-mobile{display:flex}.header__menu-button{display:none}.header__logo-image{height:50px;width:50px}.header__right{gap:var(--spacing-md);margin-left:auto}}@media(min-width:1024px){.header{padding:0 var(--spacing-xl)}.header__dropdown{min-width:320px}}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-index-overlay);animation:fadeIn var(--transition-fast)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:var(--z-index-sidebar);display:flex;flex-direction:column;transform:translate(-100%);transition:transform var(--transition-base);overflow-y:auto}.sidebar--open{transform:translate(0);box-shadow:var(--shadow-xl)}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-md);border-bottom:1px solid var(--color-border-light);min-height:var(--header-height)}.sidebar__logo{display:flex;flex-direction:column}.sidebar__logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0;line-height:1}.sidebar__logo-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.sidebar__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.sidebar__close:hover{background-color:var(--color-background);color:var(--color-text-primary)}.sidebar__toggle{display:none;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;height:40px;border:none;background-color:var(--color-background-secondary);color:var(--color-text-secondary);cursor:pointer;border-radius:0;transition:all var(--transition-fast);border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.sidebar__toggle:hover{background-color:var(--color-primary-lightest);color:var(--color-primary)}.sidebar__toggle-text{white-space:nowrap}.sidebar__nav{flex:1;padding:var(--spacing-md) 0;overflow-y:auto}.sidebar__menu{list-style:none;margin:0;padding:0}.sidebar__menu-item{margin-bottom:4px}.sidebar__link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);margin:0 var(--spacing-sm);transition:all var(--transition-fast);position:relative}.sidebar__link:hover{background-color:var(--color-primary-lightest);color:var(--color-text-primary)}.sidebar__link--active{background-color:var(--color-primary-lightest);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}.sidebar__link--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background-color:var(--color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.sidebar__link-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.sidebar__link-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar--collapsed .sidebar__logo,.sidebar--collapsed .sidebar__link-text,.sidebar--collapsed .sidebar__footer-text,.sidebar--collapsed .sidebar__footer-copyright,.sidebar--collapsed .sidebar__toggle-text{display:none}.sidebar--collapsed .sidebar__toggle,.sidebar--collapsed .sidebar__link{justify-content:center;padding:var(--spacing-sm)}.sidebar--collapsed .sidebar__link:before{display:none}.sidebar__footer{padding:var(--spacing-md);border-top:1px solid var(--color-border-light);margin-top:auto}.sidebar__footer-info{text-align:center}.sidebar__footer-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0 0 4px;font-weight:var(--font-weight-medium)}.sidebar__footer-copyright{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}@media(min-width:768px){.sidebar-overlay{display:none}.sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;grid-area:sidebar;transform:translate(0);box-shadow:none;transition:width var(--transition-base);z-index:var(--z-index-sticky)}.sidebar--collapsed{width:70px}.sidebar__header,.sidebar__close{display:none}.sidebar__toggle{display:flex;margin-top:var(--spacing-md);border-top:none}.sidebar--collapsed .sidebar__toggle{padding:var(--spacing-md) var(--spacing-sm)}.sidebar__nav{padding-top:0}.sidebar__link{font-size:var(--font-size-base);padding:var(--spacing-md)}.sidebar--collapsed .sidebar__link{position:relative}.sidebar--collapsed .sidebar__link:hover:after{content:attr(title);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background-color:var(--color-text-primary);color:var(--color-text-inverse);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);white-space:nowrap;z-index:var(--z-index-tooltip);box-shadow:var(--shadow-lg);pointer-events:none}}@media(min-width:1024px){.sidebar{width:var(--sidebar-width-expanded)}.sidebar--collapsed{width:70px}.sidebar__link{gap:var(--spacing-lg)}}.sidebar__nav::-webkit-scrollbar{width:6px}.sidebar__nav::-webkit-scrollbar-track{background:transparent}.sidebar__nav::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full)}.sidebar__nav::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-tertiary)}.main-layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-background-secondary)}.main-layout__content{flex:1;margin-top:var(--header-height);padding:var(--spacing-sm);min-height:calc(100vh - var(--header-height));overflow-x:hidden}@media(min-width:768px){.main-layout{display:flex;flex-direction:column}.main-layout__content{margin-top:var(--header-height);margin-left:var(--sidebar-width-tablet);padding:var(--spacing-lg);min-height:calc(100vh - var(--header-height));transition:margin-left var(--transition-base)}.sidebar--collapsed~.main-layout__content,body:has(.sidebar--collapsed) .main-layout__content{margin-left:70px}}@media(min-width:1024px){.main-layout__content{margin-left:var(--sidebar-width-desktop);padding:var(--spacing-xl)}.sidebar--collapsed~.main-layout__content,body:has(.sidebar--collapsed) .main-layout__content{margin-left:70px}}.main-layout__content{overflow-y:auto}.main-layout__content::-webkit-scrollbar{width:8px;height:8px}.main-layout__content::-webkit-scrollbar-track{background:var(--color-background-secondary)}.main-layout__content::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full)}.main-layout__content::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-tertiary)}.input-container{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-container--full-width{width:100%}.input-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.input-label__required{color:var(--color-error);margin-left:var(--spacing-xs)}.input-wrapper{position:relative;display:flex;align-items:center}.input{width:100%;font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);outline:none;font-size:16px}.input::placeholder{color:var(--color-text-tertiary)}.input--sm{height:var(--input-height-sm);padding:0 var(--spacing-sm);font-size:var(--font-size-sm)}.input--md{height:var(--input-height-md);padding:0 var(--spacing-md)}.input--lg{height:var(--input-height-lg);padding:0 var(--spacing-lg);font-size:var(--font-size-lg)}.input--has-start-icon{padding-left:40px}.input--has-end-icon{padding-right:40px}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-lightest)}.input-container--focused .input-label{color:var(--color-primary)}.input-container--error .input{border-color:var(--color-error)}.input-container--error .input:focus{box-shadow:0 0 0 3px var(--color-error-light)}.input-container--error .input-label{color:var(--color-error)}.input:disabled{background-color:var(--color-background-tertiary);cursor:not-allowed;opacity:.6}.input-container--disabled .input-label{opacity:.6}.input-icon{position:absolute;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);pointer-events:none;transition:color var(--transition-fast)}.input-icon--start{left:var(--spacing-sm)}.input-icon--end{right:var(--spacing-sm)}.input-icon svg{width:20px;height:20px;fill:currentColor}.input-icon--button{pointer-events:all;cursor:pointer;background:none;border:none;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.input-icon--button:hover{color:var(--color-text-primary);background-color:var(--color-background-secondary)}.input-icon--button:active{background-color:var(--color-background-tertiary)}.input-icon--button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.input-container--focused .input-icon{color:var(--color-primary)}.input-container--error .input-icon{color:var(--color-error)}.input-message{font-size:var(--font-size-sm);margin-top:var(--spacing-xs);display:block}.input-message--error{color:var(--color-error)}.input-message--helper{color:var(--color-text-secondary)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=date],input[type=datetime-local],input[type=time]{cursor:pointer}input[type=file]{padding:var(--spacing-sm);cursor:pointer}.input:-webkit-autofill,.input:-webkit-autofill:hover,.input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0px 1000px var(--color-background) inset;-webkit-text-fill-color:var(--color-text-primary);transition:background-color 5000s ease-in-out 0s}@media(min-width:768px){.input{font-size:var(--font-size-base)}.input--sm{font-size:var(--font-size-sm)}}@media(min-width:1024px){.input{font-size:var(--font-size-base)}}.alert{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid transparent;animation:slideDown var(--transition-base)}.alert--success{background-color:var(--color-success-light);border-color:var(--color-success);color:#065f46}.alert--success .alert__icon{color:var(--color-success)}.alert--warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:#92400e}.alert--warning .alert__icon{color:var(--color-warning)}.alert--error{background-color:var(--color-error-light);border-color:var(--color-error);color:#991b1b}.alert--error .alert__icon{color:var(--color-error)}.alert--info{background-color:var(--color-info-light);border-color:var(--color-info);color:#1e40af}.alert--info .alert__icon{color:var(--color-info)}.alert__icon{flex-shrink:0;width:20px;height:20px;margin-top:2px}.alert__icon svg{width:100%;height:100%}.alert__content{flex:1;min-width:0}.alert__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.alert__message{font-size:var(--font-size-sm);line-height:var(--line-height-normal)}.alert__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:none;color:currentColor;opacity:.6;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.alert__close:hover{opacity:1;background-color:#0000001a}.alert__close:active{background-color:#00000026}.alert__close:focus-visible{outline:2px solid currentColor;outline-offset:2px}@media(min-width:768px){.alert{padding:var(--spacing-lg)}.alert__title{font-size:var(--font-size-lg)}.alert__message{font-size:var(--font-size-base)}}.card{display:flex;flex-direction:column;background-color:var(--color-background);border-radius:var(--radius-lg);transition:all var(--transition-base);width:100%}.card--default{border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.card--outlined{border:2px solid var(--color-border)}.card--elevated{border:none;box-shadow:var(--shadow-md)}.card--padding-none .card__content{padding:0}.card--padding-sm .card__content{padding:var(--spacing-sm)}.card--padding-md .card__content{padding:var(--spacing-md)}.card--padding-lg .card__content{padding:var(--spacing-lg)}.card__header,.card__footer{padding:var(--spacing-md)}.card--padding-sm .card__header,.card--padding-sm .card__footer{padding:var(--spacing-sm)}.card--padding-lg .card__header,.card--padding-lg .card__footer{padding:var(--spacing-lg)}.card__header{border-bottom:1px solid var(--color-border-light)}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0 0}.card__content{flex:1}.card__footer{border-top:1px solid var(--color-border-light);margin-top:auto}.card--hoverable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card--clickable{cursor:pointer;text-align:left;border:none;padding:0;background:var(--color-background)}.card--clickable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card--clickable:active{transform:translateY(0);box-shadow:var(--shadow-md)}.card--clickable:focus-visible{outline:3px solid var(--color-primary-lightest);outline-offset:2px}@media(min-width:768px){.card__title{font-size:var(--font-size-xl)}.card--padding-md .card__content{padding:var(--spacing-lg)}.card--padding-lg .card__content{padding:var(--spacing-xl)}.card__header,.card__footer{padding:var(--spacing-lg)}}@media(min-width:1024px){.card--padding-lg .card__content{padding:var(--spacing-2xl)}.card--padding-lg .card__header,.card--padding-lg .card__footer{padding:var(--spacing-xl)}}.card--no-shadow{box-shadow:none!important}.card--border-primary{border-left:4px solid var(--color-primary)}.card--border-success{border-left:4px solid var(--color-success)}.card--border-warning{border-left:4px solid var(--color-warning)}.card--border-error{border-left:4px solid var(--color-error)}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:var(--spacing-md);overflow:hidden;position:relative}.login-theme-toggle{position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:10}.login-container{width:100%;max-width:450px}.login-card{animation:slideUp var(--transition-base);border:2px solid var(--color-border);box-shadow:0 10px 25px #0000001a;background-color:var(--color-surface)}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-logo{margin-bottom:var(--spacing-md)}.login-logo-image{width:120px;height:120px;margin-bottom:var(--spacing-sm);display:block;margin-left:auto;margin-right:auto;border-radius:50%;object-fit:cover}.login-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-sm) 0 0 0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-options{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.login-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.login-checkbox input[type=checkbox]{width:auto;cursor:pointer;margin:0}.login-checkbox:hover{color:var(--color-text-primary)}.login-link{font-size:var(--font-size-sm);color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}.login-link:hover{color:var(--color-primary-dark);text-decoration:underline}.login-footer{margin-top:var(--spacing-2xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.login-footer-text{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0;line-height:var(--line-height-relaxed)}.login-footer-text small{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}@media(min-width:768px){.login-page{padding:var(--spacing-xl)}.login-title{font-size:var(--font-size-3xl)}.login-subtitle{font-size:var(--font-size-base)}.login-options{flex-wrap:nowrap}}@media(min-width:1024px){.login-container{max-width:500px}}@media(max-width:479px){.login-theme-toggle{top:var(--spacing-sm);right:var(--spacing-sm)}}@media(min-width:480px)and (max-width:767px){.login-theme-toggle{top:var(--spacing-sm);right:var(--spacing-sm)}}@media(min-width:768px)and (max-width:1023px){.login-theme-toggle{top:var(--spacing-md);right:var(--spacing-md)}}@media(min-width:1024px){.login-theme-toggle{top:var(--spacing-md);right:var(--spacing-md)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard{max-width:1400px;margin:0 auto;padding:var(--spacing-md)}.dashboard__loading-full,.dashboard__error-full{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-md);color:var(--color-text-secondary)}.dashboard__error-full{color:var(--color-danger)}.dashboard__error-full button{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-md);cursor:pointer;font-size:var(--font-size-sm)}.dashboard__error-full button:hover{background-color:var(--color-primary-dark)}.dashboard__header{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.dashboard__header-left{flex:1}.dashboard__header-right{display:flex;align-items:center}.dashboard__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.dashboard__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.dashboard__periodo-select{padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-xl);border:1px solid var(--color-border);border-radius:var(--border-radius-md);background-color:var(--color-surface);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;min-width:140px;transition:all var(--transition-fast);appearance:none;-webkit-appearance:none;-moz-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 var(--spacing-sm) center}.dashboard__periodo-select:hover{border-color:var(--color-primary-400);background-color:var(--color-surface)}.dashboard__periodo-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.dashboard__periodo-select option{padding:var(--spacing-sm);background-color:var(--color-surface);color:var(--color-text-primary)}.theme-dark .dashboard__periodo-select{background-color:var(--color-surface-dark);border-color:var(--color-border-dark);color:var(--color-text-primary-dark);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='%239CA3AF' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.theme-dark .dashboard__periodo-select:hover{border-color:var(--color-primary-400);background-color:#37415180}.theme-dark .dashboard__periodo-select:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2563eb33}.theme-dark .dashboard__periodo-select option{background-color:var(--color-surface-dark);color:var(--color-text-primary-dark)}.dashboard__welcome{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;margin-bottom:var(--spacing-lg);animation:welcomeSlideIn .6s ease-out;transform-origin:top}@keyframes welcomeSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}50%{transform:translateY(5px) scale(1.01)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes welcomeSlideOut{0%{opacity:1;transform:translateY(0) scale(1);max-height:200px;margin-bottom:var(--spacing-lg)}50%{transform:translateY(-10px) scale(.98)}to{opacity:0;transform:translateY(-30px) scale(.95);max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0}}.dashboard__welcome--exiting{animation:welcomeSlideOut .5s ease-in forwards}.dashboard__welcome-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-md) 0;color:#fff}.dashboard__welcome-text{font-size:var(--font-size-base);margin:0 0 var(--spacing-sm) 0;color:#fffffff2}.dashboard__welcome-email{font-size:var(--font-size-sm);margin:0;color:#fffc}.dashboard__kpis{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard__kpi{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);min-height:100px}.dashboard__kpi-icon{width:48px;height:48px;border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.dashboard__kpi-icon--primary{background-color:var(--color-primary-100);color:var(--color-primary)}.dashboard__kpi-icon--info{background-color:#dbeafe;color:#2563eb}.dashboard__kpi-icon--success{background-color:#dcfce7;color:#16a34a}.dashboard__kpi-icon--warning{background-color:#fef3c7;color:#d97706}.dashboard__kpi-icon--danger{background-color:#fee2e2;color:#dc2626}.dashboard__kpi-icon--pending{background-color:var(--color-primary-100);color:var(--color-primary)}.dashboard__kpi-content{flex:1;min-width:0;overflow:hidden}.dashboard__kpi-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin:0 0 var(--spacing-xs) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard__kpi-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:1.2;word-break:break-word}.dashboard__kpi-subtitle{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:var(--spacing-xs) 0 0 0}.dashboard__kpi--success .dashboard__kpi-value{color:#16a34a}.dashboard__kpi--danger .dashboard__kpi-value{color:#dc2626}.dashboard__kpi--warning .dashboard__kpi-value{color:#d97706}.dashboard__variacion{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.dashboard__variacion--positive{color:#16a34a}.dashboard__variacion--negative{color:#dc2626}.dashboard__charts{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.dashboard__chart{min-height:300px;overflow:hidden}.dashboard__chart--wide{grid-column:1 / -1}.dashboard__chart-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.dashboard__chart-container{position:relative;height:250px;width:100%}.dashboard__chart-container--doughnut{height:220px;max-width:400px;margin:0 auto}.dashboard__chart-summary{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.dashboard__ocupacion{margin-bottom:var(--spacing-lg)}.dashboard__ocupacion-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard__ocupacion-stat{text-align:center;padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-md)}.dashboard__ocupacion-stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.dashboard__ocupacion-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.dashboard__ocupacion-stat--success .dashboard__ocupacion-stat-value{color:#16a34a}.dashboard__ocupacion-stat--warning .dashboard__ocupacion-stat-value{color:#d97706}.dashboard__ocupacion-stat--danger .dashboard__ocupacion-stat-value{color:#dc2626}.dashboard__grupos-criticos{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.dashboard__grupos-criticos h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.dashboard__grupos-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.dashboard__grupo-item{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-md)}.dashboard__grupo-info{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center}.dashboard__grupo-codigo{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.dashboard__grupo-curso{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dashboard__grupo-municipio{font-size:var(--font-size-xs);color:var(--color-text-tertiary);background-color:var(--color-bg-tertiary);padding:2px 8px;border-radius:var(--border-radius-sm)}.dashboard__grupo-ocupacion{position:relative;height:24px;background-color:var(--color-bg-tertiary);border-radius:var(--border-radius-sm);overflow:hidden}.dashboard__grupo-bar{position:absolute;left:0;top:0;height:100%;background-color:#fbbf24;transition:width .3s ease}.dashboard__grupo-ocupacion span{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;height:100%;padding:0 var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.dashboard__cursos{margin-bottom:var(--spacing-lg)}.dashboard__cursos-table{overflow-x:auto}.dashboard__cursos-table table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.dashboard__cursos-table th,.dashboard__cursos-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.dashboard__cursos-table th{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background-color:var(--color-bg-secondary);text-transform:uppercase;font-size:var(--font-size-xs);letter-spacing:.05em}.dashboard__cursos-table td{color:var(--color-text-primary)}.dashboard__cursos-table tr:hover td{background-color:var(--color-bg-secondary)}.theme-dark .dashboard__kpi-icon--primary{background-color:#3b82f633}.theme-dark .dashboard__kpi-icon--info{background-color:#2563eb33}.theme-dark .dashboard__kpi-icon--success{background-color:#16a34a33}.theme-dark .dashboard__kpi-icon--warning{background-color:#d9770633}.theme-dark .dashboard__kpi-icon--danger{background-color:#dc262633}.theme-dark .dashboard__kpi-icon--pending{background-color:#3b82f633}.theme-dark .dashboard__ocupacion-stat,.theme-dark .dashboard__grupo-item{background-color:var(--color-bg-tertiary)}.theme-dark .dashboard__grupo-ocupacion{background-color:#0003}@media(max-width:479px){.dashboard{padding:var(--spacing-sm)}.dashboard__header{margin-bottom:var(--spacing-md)}.dashboard__title,.dashboard__welcome-title{font-size:var(--font-size-lg)}.dashboard__welcome-text{font-size:var(--font-size-sm)}.dashboard__kpis{gap:var(--spacing-sm)}.dashboard__kpi{padding:var(--spacing-sm)}.dashboard__kpi-icon{width:40px;height:40px;font-size:1.25rem}.dashboard__kpi-value{font-size:var(--font-size-xl)}.dashboard__kpi-title{font-size:var(--font-size-xs)}.dashboard__charts{gap:var(--spacing-md)}.dashboard__chart-container{height:220px}.dashboard__chart-container--doughnut{height:200px}.dashboard__ocupacion-summary{grid-template-columns:1fr;gap:var(--spacing-sm)}.dashboard__ocupacion-stat{padding:var(--spacing-sm)}.dashboard__ocupacion-stat-value{font-size:var(--font-size-xl)}.dashboard__periodo-select{width:100%;min-width:unset}.dashboard__cursos-table{font-size:var(--font-size-xs)}.dashboard__cursos-table th,.dashboard__cursos-table td{padding:var(--spacing-xs) var(--spacing-sm)}}@media(min-width:480px)and (max-width:767px){.dashboard{padding:var(--spacing-md)}.dashboard__kpis,.dashboard__ocupacion-summary{grid-template-columns:repeat(2,1fr)}.dashboard__charts{grid-template-columns:1fr}.dashboard__chart-container{height:240px}}@media(min-width:768px){.dashboard{padding:var(--spacing-lg)}.dashboard__header{flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl)}.dashboard__title{font-size:var(--font-size-2xl)}.dashboard__kpis{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.dashboard__charts{grid-template-columns:repeat(2,1fr)}.dashboard__chart-container{height:280px}.dashboard__ocupacion-summary{grid-template-columns:repeat(3,1fr)}.dashboard__grupo-item{flex-direction:row;align-items:center;justify-content:space-between}.dashboard__grupo-ocupacion{width:200px;flex-shrink:0}}@media(min-width:1024px){.dashboard{padding:var(--spacing-xl)}.dashboard__title{font-size:var(--font-size-3xl)}.dashboard__kpis{grid-template-columns:repeat(4,1fr);gap:var(--spacing-xl)}.dashboard__chart-container{height:300px}.dashboard__ocupacion-summary{grid-template-columns:repeat(5,1fr)}}@media(min-width:1280px){.dashboard__charts{gap:var(--spacing-xl)}.dashboard__chart-container{height:320px}.dashboard__grupo-ocupacion{width:250px}}@media(min-width:1440px){.dashboard{padding:var(--spacing-2xl)}.dashboard__header{margin-bottom:var(--spacing-2xl)}.dashboard__title{font-size:var(--font-size-4xl)}.dashboard__kpis,.dashboard__charts{gap:var(--spacing-2xl)}.dashboard__chart-container{height:350px}}@media(max-width:767px){.dashboard__cursos-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.dashboard__cursos-table table{min-width:500px}}@media(max-width:767px){.dashboard__header-right,.dashboard__periodo-select{width:100%}}.phone-input__country-code{font-weight:600;color:var(--text-secondary);-webkit-user-select:none;user-select:none;padding-right:4px;border-right:1px solid var(--border-color);margin-right:8px;font-size:.95em}[data-theme=dark] .phone-input__country-code{color:var(--text-primary);border-right-color:var(--border-color)}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-index-modal-backdrop);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);overflow-y:auto;animation:fadeIn var(--transition-base)}.modal{background-color:var(--color-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;max-height:calc(100vh - var(--spacing-xl));width:100%;position:relative;z-index:var(--z-index-modal);animation:slideUp var(--transition-base)}.modal--sm{max-width:var(--max-width-modal-sm)}.modal--md{max-width:var(--max-width-modal-md)}.modal--lg{max-width:var(--max-width-modal-lg)}.modal--xl{max-width:var(--max-width-modal-xl)}.modal--full{max-width:100%;max-height:100%;height:100%;border-radius:0}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.modal__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-right:var(--spacing-md)}.modal__close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:none;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.modal__close-button:hover{background-color:var(--color-background-secondary);color:var(--color-text-primary)}.modal__close-button:active{background-color:var(--color-background-tertiary)}.modal__close-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.modal__content{padding:var(--spacing-lg);overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--color-border-dark) transparent}.modal__content::-webkit-scrollbar{width:6px}.modal__content::-webkit-scrollbar-track{background:transparent}.modal__content::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}.modal__content::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border-light);flex-shrink:0;flex-wrap:wrap}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:767px){.modal-backdrop{padding:0;align-items:flex-end}.modal{max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUpMobile var(--transition-base)}.modal--full{max-height:100vh;border-radius:0}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal__footer{flex-direction:column-reverse}.modal__footer>*{width:100%}}@media(min-width:768px){.modal-backdrop{padding:var(--spacing-xl)}.modal{max-height:calc(100vh - var(--spacing-2xl))}.modal__header,.modal__content{padding:var(--spacing-xl)}.modal__footer{padding:var(--spacing-xl);gap:var(--spacing-md)}.modal__title{font-size:var(--font-size-2xl)}}@media(min-width:1024px){.modal__content{padding:var(--spacing-2xl)}}.modal--centered{margin:auto}.modal--confirm .modal__content{text-align:center;padding:var(--spacing-2xl)}.modal--confirm .modal__footer{justify-content:center}.pagination{display:flex;flex-direction:column;align-items:stretch;gap:var(--spacing-md);padding:var(--spacing-md) 0}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.pagination-button{padding:var(--spacing-sm);border:1px solid var(--color-border);background-color:var(--color-background);color:var(--color-text-primary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);min-width:36px;height:36px;display:flex;align-items:center;justify-content:center}.pagination-button:hover:not(:disabled){background-color:var(--color-background-secondary);border-color:var(--color-primary);color:var(--color-primary)}.pagination-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-ellipsis{padding:var(--spacing-sm);color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.pagination-pages{display:flex;align-items:center;gap:var(--spacing-xs)}@media(min-width:768px){.pagination{flex-direction:row;align-items:center;justify-content:space-between}.pagination-info{text-align:left}.pagination-button{min-width:40px;height:40px;font-size:var(--font-size-base)}}@media(min-width:900px){.pagination-controls{gap:var(--spacing-sm)}.pagination-pages{gap:var(--spacing-xs)}}@media(min-width:1024px){.pagination{padding:var(--spacing-lg) 0}}@media(min-width:1440px){.pagination-button{min-width:44px;height:44px}}.theme-dark .pagination-button{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.theme-dark .pagination-button:hover:not(:disabled){background-color:var(--color-background-tertiary);border-color:var(--color-primary)}.theme-dark .pagination-button.active{background-color:var(--color-primary);color:#fff}.search-bar{position:relative;display:flex;align-items:center;width:100%}.search-bar__icon{position:absolute;left:var(--spacing-md);display:flex;align-items:center;color:var(--color-text-tertiary);pointer-events:none;transition:color var(--transition-fast)}.search-bar__input{width:100%;height:44px;padding:var(--spacing-sm) var(--spacing-md);padding-left:44px;padding-right:44px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:16px;color:var(--color-text-primary);background-color:var(--color-surface);transition:all var(--transition-fast)}.search-bar__input::placeholder{color:var(--color-text-tertiary)}.search-bar__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-lightest)}.search-bar__input:focus~.search-bar__icon{color:var(--color-primary)}.search-bar__clear{position:absolute;right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.search-bar__clear:hover{background-color:var(--color-background-secondary);color:var(--color-text-primary)}.search-bar__clear:active{transform:scale(.95)}.search-bar__clear:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(min-width:768px){.search-bar{max-width:400px}.search-bar__input{height:40px;font-size:var(--font-size-base)}}@media(min-width:900px){.search-bar{max-width:450px}}@media(min-width:1024px){.search-bar{max-width:500px}}@media(min-width:1440px){.search-bar{max-width:600px}.search-bar__input{height:44px}}.theme-dark .search-bar__input{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.theme-dark .search-bar__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb33}.theme-dark .search-bar__clear:hover{background-color:var(--color-background-tertiary)}.select{display:flex;flex-direction:column;gap:var(--spacing-xs)}.select__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.select__required{color:var(--color-error-500);margin-left:var(--spacing-xs)}.select__wrapper{position:relative;display:inline-block;width:100%}.select__field{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-2xl);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);outline:none;cursor:pointer;transition:all var(--transition-fast);appearance:none;-webkit-appearance:none;-moz-appearance:none}.select__field:hover:not(:disabled){border-color:var(--color-primary-400)}.select__field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.select__field:disabled{background-color:var(--color-background-disabled);color:var(--color-text-disabled);cursor:not-allowed;opacity:.6}.select__field option{padding:var(--spacing-sm);background-color:var(--color-surface);color:var(--color-text-primary);font-weight:var(--font-weight-normal)}.select__field option:checked{background:linear-gradient(0deg,var(--color-primary-500) 0%,var(--color-primary-500) 100%);color:#fff;font-weight:var(--font-weight-medium)}.select__field option:hover{background-color:var(--color-primary-50);color:var(--color-text-primary)}.select__field option:disabled{color:var(--color-text-disabled);background-color:var(--color-background-secondary)}.select__arrow{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.select__field:focus~.select__arrow{color:var(--color-primary-500)}.select__helper-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0}.select__error-text{font-size:var(--font-size-xs);color:var(--color-error-500);margin:0;display:flex;align-items:center;gap:var(--spacing-xs)}.select--sm .select__field{height:var(--input-height-sm);padding:var(--spacing-xs) var(--spacing-sm);padding-right:var(--spacing-xl);font-size:var(--font-size-sm)}.select--sm .select__arrow{right:var(--spacing-sm)}.select--md .select__field{height:var(--input-height-md)}.select--lg .select__field{height:var(--input-height-lg);padding:var(--spacing-md) var(--spacing-lg);padding-right:var(--spacing-2xl);font-size:var(--font-size-lg)}.select--lg .select__arrow{right:var(--spacing-lg)}.select--full-width{width:100%}.select--error .select__field{border-color:var(--color-error-500)}.select--error .select__field:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-100)}.select--disabled .select__field{cursor:not-allowed}.theme-dark .select__field{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.theme-dark .select__field:hover:not(:disabled){border-color:var(--color-primary-400)}.theme-dark .select__field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2563eb33}.theme-dark .select__field option{background-color:var(--color-surface);color:var(--color-text-primary)}.theme-dark .select__field option:checked{background:linear-gradient(0deg,var(--color-primary-500) 0%,var(--color-primary-500) 100%);color:#fff}.theme-dark .select__field option:hover{background-color:#2563eb1a;color:var(--color-text-primary)}.theme-dark .select__arrow{color:var(--color-text-secondary)}.theme-dark .select__label{color:var(--color-text-primary)}.theme-dark .select__helper-text{color:var(--color-text-secondary)}@media(max-width:767px){.select__field{min-height:44px;font-size:16px}.select--sm .select__field{min-height:40px}.select--lg .select__field{min-height:52px}}@media(min-width:768px){.select__field{font-size:var(--font-size-base)}.select--sm .select__field{font-size:var(--font-size-sm)}}@media(min-width:1024px){.select__label{font-size:var(--font-size-sm)}}@media(min-width:1440px){.select--lg .select__field{height:52px}}.table-wrapper{width:100%;overflow-x:auto;background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table__head{background-color:var(--color-background-secondary);border-bottom:2px solid var(--color-border)}.table__header{padding:var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap}.table__header--actions{text-align:center;width:60px}.table__body{background-color:var(--color-surface)}.table__row{border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.table__row:last-child{border-bottom:none}.table__row:hover{background-color:var(--color-background-secondary)}.table__row--clickable{cursor:pointer}.table__cell{padding:var(--spacing-md);color:var(--color-text-secondary);vertical-align:middle}.table__cell--actions{text-align:center;white-space:nowrap}.table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);gap:var(--spacing-md)}.table-loading p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);gap:var(--spacing-md)}.table-empty svg{color:var(--color-text-tertiary)}.table-empty p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}@media(max-width:767px){.table-wrapper{border:none;border-radius:0;background-color:var(--color-bg-primary, #1a1a2e)}.table__head{display:none}.table__body{display:block}.table__row{display:block;margin-bottom:12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface);box-shadow:0 12px 0 0 var(--color-bg-primary, #111827)}.table__row:last-child{margin-bottom:0;box-shadow:none}.table__cell{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.table__cell:last-child{border-bottom:none}.table__cell:before{content:attr(data-label);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-right:var(--spacing-md)}.table__cell--actions{justify-content:center}.table__cell--actions:before{content:"";margin:0}}@media(min-width:768px){.table{font-size:var(--font-size-base)}.table__header,.table__cell{padding:var(--spacing-md) var(--spacing-lg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);min-height:400px}.empty-state__icon{color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg)}.empty-state__default-icon{opacity:.5}.empty-state__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm)}.empty-state__description{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:400px;margin:0 0 var(--spacing-lg);line-height:var(--line-height-relaxed)}.empty-state__action{margin-top:var(--spacing-md)}@media(max-width:768px){.empty-state{padding:var(--spacing-2xl) var(--spacing-md);min-height:300px}.empty-state__title{font-size:var(--font-size-lg)}.empty-state__description{font-size:var(--font-size-sm)}.empty-state__icon svg{width:48px;height:48px}}.theme-dark .empty-state__title{color:var(--color-text-primary-dark)}.theme-dark .empty-state__description{color:var(--color-text-secondary-dark)}.theme-dark .empty-state__icon{color:var(--color-text-tertiary-dark)}.confirm-dialog{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md) 0}.confirm-dialog__content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.confirm-dialog__icon{flex-shrink:0}.confirm-dialog__icon--danger{color:var(--color-error-500)}.confirm-dialog__icon--warning{color:var(--color-warning-500)}.confirm-dialog__icon--info{color:var(--color-info-500)}.confirm-dialog__message{font-size:var(--font-size-base);color:var(--color-text-primary);margin:0;line-height:var(--line-height-relaxed)}.confirm-dialog__actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm)}@media(max-width:640px){.confirm-dialog__actions{flex-direction:column-reverse;gap:var(--spacing-sm)}}.theme-dark .confirm-dialog__message{color:var(--color-text-primary-dark)}.date-picker{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-picker__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.date-picker__required{color:var(--color-error-500);margin-left:var(--spacing-xs)}.date-picker__wrapper{position:relative;display:inline-block;width:100%;overflow:visible}.date-picker__field{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-xl);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);outline:none;transition:all var(--transition-fast);cursor:pointer}.date-picker__field:hover:not(:disabled){border-color:var(--color-primary-400)}.date-picker__field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.date-picker__field:disabled{background-color:var(--color-background-disabled);color:var(--color-text-disabled);cursor:not-allowed;opacity:.6}.date-picker__icon{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);pointer-events:auto;cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-fast);padding:var(--spacing-xs);border-radius:var(--border-radius-sm)}.date-picker__icon:hover{background-color:var(--color-primary-50);color:var(--color-primary-600)}.date-picker__field:focus~.date-picker__icon{color:var(--color-primary-500)}.date-picker__field::-webkit-calendar-picker-indicator{position:absolute;right:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1}.date-picker__field::-moz-calendar-picker-indicator{display:none}.date-picker__helper-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0}.date-picker__error-text{font-size:var(--font-size-xs);color:var(--color-error-500);margin:0;display:flex;align-items:center;gap:var(--spacing-xs)}.date-picker--sm .date-picker__field{height:var(--input-height-sm);padding:var(--spacing-xs) var(--spacing-sm);padding-right:var(--spacing-xl);font-size:var(--font-size-sm)}.date-picker--sm .date-picker__icon{right:var(--spacing-sm)}.date-picker--md .date-picker__field{height:var(--input-height-md)}.date-picker--lg .date-picker__field{height:var(--input-height-lg);padding:var(--spacing-md) var(--spacing-lg);padding-right:var(--spacing-2xl);font-size:var(--font-size-lg)}.date-picker--lg .date-picker__icon{right:var(--spacing-lg)}.date-picker--full-width{width:100%}.date-picker--error .date-picker__field{border-color:var(--color-error-500)}.date-picker--error .date-picker__field:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-100)}.date-picker--disabled .date-picker__field{cursor:not-allowed}.theme-dark .date-picker__field{background-color:var(--color-surface-dark);border-color:var(--color-border-dark);color:var(--color-text-primary-dark);color-scheme:dark}.theme-dark .date-picker__field:hover:not(:disabled){border-color:var(--color-primary-400)}.theme-dark .date-picker__field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2563eb33}.theme-dark .date-picker__icon{color:var(--color-text-secondary-dark)}.theme-dark .date-picker__label{color:var(--color-text-primary-dark)}.theme-dark .date-picker__helper-text{color:var(--color-text-secondary-dark)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.form-actions--left{justify-content:flex-start}.form-actions--center{justify-content:center}.form-actions--right{justify-content:flex-end}@media(max-width:640px){.form-actions{flex-direction:column-reverse;gap:var(--spacing-sm)}.form-actions button{width:100%}}.theme-dark .form-actions{border-top-color:var(--color-border-dark)}.autocomplete{display:flex;flex-direction:column;gap:var(--spacing-xs);position:relative}.autocomplete__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.autocomplete__required{color:var(--color-error-500);margin-left:var(--spacing-xs)}.autocomplete__input-wrapper{position:relative}.autocomplete__input{width:100%;height:var(--input-height-md);padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-2xl);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);outline:none;transition:all var(--transition-fast)}.autocomplete__input::placeholder{color:var(--color-text-tertiary)}.autocomplete__input:hover:not(:disabled){border-color:var(--color-primary-400)}.autocomplete__input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.autocomplete__input:disabled{background-color:var(--color-background-disabled);color:var(--color-text-disabled);cursor:not-allowed;opacity:.6}.autocomplete__icons{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:var(--spacing-xs)}.autocomplete__clear{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.autocomplete__clear:hover{background-color:var(--color-background-hover);color:var(--color-text-primary)}.autocomplete__clear:active{transform:scale(.95)}.autocomplete__dropdown{position:absolute;top:calc(100% + var(--spacing-xs));left:0;right:0;z-index:1000;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);max-height:300px;overflow-y:auto;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.autocomplete__list{list-style:none;margin:0;padding:var(--spacing-xs)}.autocomplete__item{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border-radius:var(--border-radius-sm);transition:background-color var(--transition-fast);color:var(--color-text-primary);font-size:var(--font-size-sm)}.autocomplete__item:hover,.autocomplete__item--selected{background-color:var(--color-primary-50);color:var(--color-primary-700)}.autocomplete__item:active{background-color:var(--color-primary-100)}.autocomplete__helper-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0}.autocomplete__error-text{font-size:var(--font-size-xs);color:var(--color-error-500);margin:0;display:flex;align-items:center;gap:var(--spacing-xs)}.autocomplete--full-width{width:100%}.autocomplete--error .autocomplete__input{border-color:var(--color-error-500)}.autocomplete--error .autocomplete__input:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px var(--color-error-100)}.autocomplete--disabled .autocomplete__input{cursor:not-allowed}.autocomplete__dropdown::-webkit-scrollbar{width:8px}.autocomplete__dropdown::-webkit-scrollbar-track{background:transparent}.autocomplete__dropdown::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--border-radius-full)}.autocomplete__dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.theme-dark .autocomplete__input{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.theme-dark .autocomplete__input:hover:not(:disabled){border-color:var(--color-primary-light)}.theme-dark .autocomplete__input:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #2563eb33}.theme-dark .autocomplete__dropdown{background-color:var(--color-surface);border-color:var(--color-border);box-shadow:0 10px 25px #00000080}.theme-dark .autocomplete__item{color:var(--color-text-primary)}.theme-dark .autocomplete__item:hover,.theme-dark .autocomplete__item--selected{background-color:#2563eb33;color:var(--color-primary-lighter)}.theme-dark .autocomplete__label{color:var(--color-text-primary)}.theme-dark .autocomplete__helper-text,.theme-dark .autocomplete__clear{color:var(--color-text-secondary)}.theme-dark .autocomplete__clear:hover{background-color:#ffffff1a;color:var(--color-text-primary)}.estado-cuenta-modal{display:flex;flex-direction:column;gap:var(--spacing-lg)}.estado-cuenta-modal__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-3xl);color:var(--color-text-secondary)}.estado-cuenta-resumen{padding:var(--spacing-lg)!important;background:linear-gradient(135deg,var(--color-background-secondary) 0%,var(--color-background) 100%);border-radius:var(--radius-lg)}.resumen__header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.resumen__estudiante{display:flex;flex-direction:column;gap:var(--spacing-sm)}.resumen__estudiante h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.resumen__stats{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.stat-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm);background-color:var(--color-background);border-radius:var(--radius-md)}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium)}.stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.stat-value--total{color:var(--color-primary)}.estado-cuenta-historial{display:flex;flex-direction:column;gap:var(--spacing-md);min-height:0}.historial__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.historial__table-container{max-height:400px;overflow-y:auto;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);scrollbar-width:thin;scrollbar-color:var(--color-border-dark) transparent}.historial__table-container::-webkit-scrollbar{width:6px;height:6px}.historial__table-container::-webkit-scrollbar-track{background:transparent}.historial__table-container::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}.historial__table-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.saldo-pendiente{color:var(--color-warning);font-weight:var(--font-weight-semibold)}.saldo-cero{color:var(--color-success);font-weight:var(--font-weight-semibold)}.estado-cuenta-modal__actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media(min-width:480px){.resumen__stats{grid-template-columns:repeat(2,1fr)}.estado-cuenta-modal__actions{flex-direction:row;justify-content:flex-end}}@media(min-width:768px){.resumen__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.resumen__estudiante h3{font-size:var(--font-size-xl)}.resumen__stats{grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.stat-value{font-size:var(--font-size-xl)}.stat-item{padding:var(--spacing-md)}}@media(min-width:1024px){.estado-cuenta-modal{gap:var(--spacing-xl)}.estado-cuenta-resumen{padding:var(--spacing-xl)!important}.historial__title{font-size:var(--font-size-lg)}.stat-value{font-size:var(--font-size-2xl)}}.theme-dark .estado-cuenta-resumen{background:linear-gradient(135deg,var(--color-background-tertiary) 0%,var(--color-background-secondary) 100%)}.theme-dark .stat-item{background-color:var(--color-surface)}.theme-dark .resumen__header{border-bottom-color:var(--color-border)}.theme-dark .estado-cuenta-modal__actions{border-top-color:var(--color-border)}.matricula-detalle-modal__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.matricula-detalle-modal__loading p{color:var(--color-text-secondary);font-size:.875rem}.matricula-detalle-modal__content{display:flex;flex-direction:column;gap:1.5rem}.matricula-detalle-section{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background-color:var(--color-background);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.matricula-detalle-section__title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.matricula-detalle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.matricula-detalle-field{display:flex;flex-direction:column;gap:.25rem}.matricula-detalle-field--full{grid-column:1 / -1}.matricula-detalle-field label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.matricula-detalle-field span{font-size:.9375rem;color:var(--color-text);font-weight:400}.matricula-detalle-field__highlight{font-weight:600!important;color:var(--color-primary)!important}.matricula-detalle-field__amount{font-size:1.125rem!important;font-weight:600!important;font-family:Courier New,monospace}.matricula-detalle-field__amount--total{color:var(--color-primary)!important;font-size:1.25rem!important}.matricula-detalle-field__amount--pending{color:var(--color-danger)!important}.matricula-detalle-field__amount--paid{color:var(--color-success)!important}.matricula-detalle-field__status{font-weight:600;text-transform:capitalize}.matricula-detalle-field__status--success{color:var(--color-success)}.matricula-detalle-field__status--warning{color:var(--color-warning)}.matricula-detalle-field__status--error{color:var(--color-danger)}.matricula-detalle-field__status--info{color:var(--color-info)}.matricula-detalle-field__status--default{color:var(--color-text-secondary)}@media(max-width:768px){.matricula-detalle-grid{grid-template-columns:1fr}.matricula-detalle-section{padding:1rem}.matricula-detalle-field__amount{font-size:1rem!important}.matricula-detalle-field__amount--total{font-size:1.125rem!important}}.matriculas-grupo-modal__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.matriculas-grupo-modal__loading p{color:var(--color-text-secondary);font-size:.875rem}.matriculas-grupo-modal__content{display:flex;flex-direction:column;gap:1.5rem}.matriculas-grupo-modal__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:1rem;background-color:var(--color-background);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-item label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.stat-value--success{color:var(--color-success)}.stat-value--warning{color:var(--color-warning)}.stat-value--error{color:var(--color-danger)}.estudiante-cell{display:flex;flex-direction:column;gap:.25rem}.estudiante-nombre{font-weight:500;color:var(--color-text)}.estudiante-documento{font-size:.8125rem;color:var(--color-text-secondary)}.valor-total{font-weight:600;color:var(--color-text);font-family:Courier New,monospace}.saldo-pendiente{font-weight:600;color:var(--color-danger);font-family:Courier New,monospace}.saldo-pagado{font-weight:600;color:var(--color-success);font-family:Courier New,monospace}@media(max-width:768px){.matriculas-grupo-modal__stats{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.25rem}}.exportar-estudiantes-modal{display:flex;flex-direction:column;gap:var(--spacing-md)}.exportar-estudiantes-modal__description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0;line-height:1.5}.exportar-estudiantes-modal__tipo{padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.exportar-estudiantes-modal__info{color:var(--color-text-secondary);font-size:.75rem;line-height:1.4;margin:0 0 var(--spacing-sm) 0;padding:.5rem .75rem;background-color:var(--color-info-light, #dbeafe);border-radius:var(--border-radius-sm, .25rem);border-left:3px solid var(--color-info, #3b82f6);max-width:100%;word-wrap:break-word}.exportar-estudiantes-modal__options{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.exportar-estudiantes-modal__checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary)}.exportar-estudiantes-modal__checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.exportar-estudiantes-modal__checkbox span{-webkit-user-select:none;user-select:none}.exportar-estudiantes-modal__filters{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius-md);transition:opacity .2s ease}.exportar-estudiantes-modal__filters--disabled{opacity:.5;pointer-events:none}.exportar-estudiantes-modal__filters-title{margin:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.exportar-estudiantes-modal__row{width:100%}.exportar-estudiantes-modal__row--dates{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.exportar-estudiantes-modal__actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm)}@media(max-width:480px){.exportar-estudiantes-modal__row--dates{grid-template-columns:1fr}.exportar-estudiantes-modal__actions{flex-direction:column}.exportar-estudiantes-modal__actions .btn{width:100%}}.estudiante-form__success{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background-color:var(--color-success-light);color:var(--color-success);border-radius:var(--radius-lg);font-weight:var(--font-weight-medium);animation:slideDown .3s ease-out;box-shadow:var(--shadow-md)}.estudiante-form__success svg{flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.estudiante-form__success{position:fixed;top:var(--spacing-md);left:var(--spacing-md);right:var(--spacing-md);z-index:9999;margin-bottom:0;box-shadow:var(--shadow-xl)}}.estudiante-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.estudiante-form__fields{display:flex;flex-direction:column;gap:var(--spacing-xl)}.estudiante-form__section{display:flex;flex-direction:column;gap:var(--spacing-md)}.estudiante-form__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.estudiante-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.theme-dark .estudiante-form__section-title{color:var(--color-text-primary-dark);border-bottom-color:var(--color-border-dark)}@media(max-width:768px){.estudiante-form__row{grid-template-columns:1fr}}.estudiantes-page{padding:var(--spacing-md);max-width:var(--container-wide);margin:0 auto}.estudiantes-header{margin-bottom:var(--spacing-lg)}.estudiantes-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.estudiantes-header p{color:var(--color-text-secondary);font-size:var(--font-size-base)}.estudiantes-filters{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.estudiantes-page__filters{display:flex;gap:var(--spacing-md);align-items:center;padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap}.estudiantes-page__filters>*{flex:1 1 100%;min-width:0}.estudiantes-page__filters-card .card__content{padding:var(--spacing-sm) var(--spacing-md)}.estudiantes-page__filters-card{margin-bottom:var(--spacing-lg)}.estudiantes-page__create-button{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.estudiantes-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap}.estudiantes-content{margin-top:var(--spacing-md);background-color:var(--color-background);border-radius:var(--radius-lg);overflow:hidden}.estudiante-estado-badge{text-transform:capitalize}.estudiante-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.estudiantes-page__icon-view{color:var(--color-primary);transition:transform var(--transition-fast)}.estudiantes-page__icon-view:hover{transform:scale(1.1);color:var(--color-primary-dark)}@media(max-width:640px){.estudiantes-page__icon-view svg{width:18px;height:18px}}.estudiantes-page{padding:var(--spacing-sm)}.estudiantes-header h1{font-size:var(--font-size-lg)}.estudiantes-filters{gap:var(--spacing-sm)}.estudiantes-actions{flex-direction:column;width:100%}.estudiantes-actions>*{width:100%}.estudiante-actions{flex-direction:column;width:100%}.estudiante-actions>button{width:100%}@media(min-width:480px){.estudiantes-page{padding:var(--spacing-md)}.estudiantes-header h1{font-size:var(--font-size-xl)}.estudiantes-actions{flex-direction:row;width:auto}.estudiantes-actions>*{width:auto}.estudiante-actions{flex-direction:row;width:auto}.estudiante-actions>button{width:auto}}@media(min-width:768px){.estudiantes-page{padding:var(--spacing-lg)}.estudiantes-header h1{font-size:var(--font-size-2xl)}.estudiantes-filters{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}}@media(min-width:900px){.estudiantes-filters{grid-template-columns:repeat(3,1fr)}.estudiantes-page__filters{flex-wrap:wrap}.estudiantes-page__filters>*{flex:1 1 calc(33.333% - var(--spacing-md));min-width:150px}.estudiantes-page__filters>*:first-child{flex:1 1 calc(40% - var(--spacing-md));min-width:200px}}@media(min-width:1024px){.estudiantes-page{padding:var(--spacing-xl)}.estudiantes-header h1{font-size:var(--font-size-3xl)}.estudiantes-filters{grid-template-columns:2fr 1fr 1fr 1fr}.estudiantes-header{display:flex;justify-content:space-between;align-items:flex-start}}@media(min-width:1280px){.estudiantes-filters{grid-template-columns:2fr 1fr 1fr 1fr 1fr}}@media(min-width:1440px){.estudiantes-page{padding:var(--spacing-2xl)}.estudiantes-header,.estudiantes-page__filters-card{margin-bottom:var(--spacing-xl)}}.estudiante-create-page{padding:var(--spacing-lg);max-width:var(--container-md);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.estudiante-create-page__header{display:flex;align-items:center;gap:var(--spacing-md)}.estudiante-create-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.estudiante-create-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.estudiante-create-form__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.estudiante-create-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.estudiante-create-form__field{display:flex;flex-direction:column}.estudiante-create-form__field--full{grid-column:1 / -1}.estudiante-create-form__actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}@media(max-width:640px){.estudiante-create-page{padding:var(--spacing-md);gap:var(--spacing-md)}.estudiante-create-page__header{flex-direction:column;align-items:flex-start}.estudiante-create-page__title{font-size:var(--font-size-xl)}.estudiante-create-form__grid{grid-template-columns:1fr;gap:var(--spacing-md)}.estudiante-create-form__actions{flex-direction:column-reverse}.estudiante-create-form__actions>*{width:100%}}@media(min-width:768px){.estudiante-create-page{padding:var(--spacing-xl)}.estudiante-create-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1024px){.estudiante-create-form__grid{grid-template-columns:repeat(3,1fr)}}.acudiente-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.acudiente-form__fields{display:flex;flex-direction:column;gap:var(--spacing-md)}.acudiente-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.acudiente-form__checkbox{padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.acudiente-form__checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.acudiente-form__checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary-500)}.acudiente-form__checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.acudiente-form__checkbox-helper{margin:var(--spacing-xs) 0 0 26px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.theme-dark .acudiente-form__checkbox{background-color:#ffffff0d;border-color:var(--color-border-dark)}.theme-dark .acudiente-form__checkbox-label{color:var(--color-text-primary-dark)}.theme-dark .acudiente-form__checkbox-helper{color:var(--color-text-secondary-dark)}@media(max-width:768px){.acudiente-form__row{grid-template-columns:1fr}}.acudientes-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.acudientes-list__header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.acudientes-list__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.acudientes-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.acudiente-card{display:flex;flex-direction:column;gap:var(--spacing-md)}.acudiente-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.acudiente-card__name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.acudiente-card__relation{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;text-transform:capitalize}.acudiente-card__info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.acudiente-card__info-item{display:flex;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.acudiente-card__info-label{font-weight:var(--font-weight-medium);color:var(--color-text-secondary);min-width:75px}.acudiente-card__info-value{color:var(--color-text-primary)}.acudiente-card__actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.theme-dark .acudientes-list__title,.theme-dark .acudiente-card__name{color:var(--color-text-primary-dark)}.theme-dark .acudiente-card__relation,.theme-dark .acudiente-card__info-label{color:var(--color-text-secondary-dark)}.theme-dark .acudiente-card__info-value{color:var(--color-text-primary-dark)}.theme-dark .acudiente-card__actions{border-top-color:var(--color-border-dark)}@media(max-width:768px){.acudientes-list__header{flex-direction:column;align-items:stretch}.acudientes-list__grid{grid-template-columns:1fr}}.estudiante-matriculas{display:flex;flex-direction:column;gap:var(--spacing-md)}.estudiante-matriculas__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-sm);color:var(--color-text-secondary)}.estudiante-matriculas__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.estudiante-matriculas__title{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.estudiante-matriculas__list{display:flex;flex-direction:column;gap:var(--spacing-md)}.matricula-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);transition:border-color .2s ease,box-shadow .2s ease}.matricula-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00000014}.matricula-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.matricula-card__curso{display:flex;flex-direction:column;gap:2px}.matricula-card__curso-nombre{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary)}.matricula-card__grupo-codigo{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-family:Courier New,monospace}.matricula-card__info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.matricula-card__info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.matricula-card__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.matricula-card__value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.matricula-card__value--money{font-weight:600}.matricula-card__value--success{color:var(--color-success);font-weight:600}.matricula-card__value--danger{color:var(--color-error);font-weight:600}.matricula-card__actions{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}@media(max-width:768px){.estudiante-matriculas__header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.matricula-card__header{flex-direction:column;gap:var(--spacing-sm)}.matricula-card__info{grid-template-columns:1fr}.matricula-card__actions{flex-wrap:wrap}.matricula-card__actions button{flex:1;min-width:100px}}@media(max-width:480px){.matricula-card{padding:var(--spacing-sm)}.matricula-card__info-row{flex-direction:column;align-items:flex-start;gap:2px}}.estudiante-detalle-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto}.estudiante-detalle-page__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.estudiante-detalle-page__actions{display:flex;gap:var(--spacing-sm)}.estudiante-detalle__info-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.estudiante-detalle__name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.estudiante-detalle__codigo{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.estudiante-detalle__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.estudiante-detalle__info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.estudiante-detalle__info-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.estudiante-detalle__info-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.estudiante-detalle__section{display:flex;flex-direction:column;gap:var(--spacing-md)}.estudiante-detalle__section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.estudiante-detalle__empty{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-xl);font-style:italic}.estudiante-detalle__matriculas{display:flex;flex-direction:column;gap:var(--spacing-md)}.matricula-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:all var(--transition-base)}.matricula-item:hover{background-color:var(--color-background-tertiary);box-shadow:var(--shadow-sm)}.matricula-item__info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.matricula-item__info strong{font-size:var(--font-size-base);color:var(--color-text-primary)}.matricula-item__grupo,.matricula-item__fecha{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media(max-width:640px){.estudiante-detalle-page{padding:var(--spacing-md)}.estudiante-detalle-page__header{flex-direction:column;align-items:stretch}.estudiante-detalle-page__actions{flex-direction:column;width:100%}.estudiante-detalle-page__actions>*{width:100%}.estudiante-detalle__info-header{flex-direction:column;gap:var(--spacing-md)}.estudiante-detalle__name{font-size:var(--font-size-xl)}.estudiante-detalle__info-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.matricula-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}@media(min-width:768px){.estudiante-detalle-page{padding:var(--spacing-xl)}.estudiante-detalle-page__header{flex-direction:row}.estudiante-detalle__name{font-size:var(--font-size-3xl)}.estudiante-detalle__info-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.estudiante-detalle__info-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.estudiante-detalle-page{padding:var(--spacing-2xl) var(--spacing-xl)}}.estado-cuenta-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto}.estado-cuenta-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.estado-cuenta-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.estado-cuenta-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.estado-cuenta-page__actions{display:flex;gap:var(--spacing-sm)}.estado-cuenta__resumen{margin-bottom:var(--spacing-xl)}.estado-cuenta__resumen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.estado-cuenta__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.estado-cuenta__resumen-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.estado-cuenta__resumen-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-background-subtle);border-radius:var(--border-radius-md);border-left:4px solid var(--color-border)}.estado-cuenta__resumen-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.estado-cuenta__resumen-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.estado-cuenta__resumen-value--debe{color:var(--color-text-secondary)}.estado-cuenta__resumen-value--pagado{color:var(--color-success)}.estado-cuenta__resumen-value--pendiente{color:var(--color-error)}.estado-cuenta__resumen-value--success{color:var(--color-success)}.estado-cuenta__resumen-date{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--spacing-xs)}.estado-cuenta__content-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.estado-cuenta__matriculas{display:flex;flex-direction:column;gap:var(--spacing-md)}.estado-cuenta__matriculas-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.estado-cuenta__matricula-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md);background:var(--color-background-subtle);border-radius:var(--border-radius-md);border:1px solid var(--color-border);transition:all .2s ease}.estado-cuenta__matricula-item:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000000d}.estado-cuenta__matricula-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.estado-cuenta__matricula-curso{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.estado-cuenta__matricula-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.estado-cuenta__matricula-fecha{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.estado-cuenta__matricula-precio{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.estado-cuenta__pagos{display:flex;flex-direction:column;gap:var(--spacing-md)}.estado-cuenta__pagos-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:500px;overflow-y:auto}.estado-cuenta__pago-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background-subtle);border-radius:var(--border-radius-md);border:1px solid var(--color-border);transition:all .2s ease}.estado-cuenta__pago-item:hover{border-color:var(--color-success);box-shadow:0 2px 8px #0000000d}.estado-cuenta__pago-fecha{min-width:100px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);padding-right:var(--spacing-md);border-right:2px solid var(--color-border)}.estado-cuenta__pago-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.estado-cuenta__pago-monto{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-success)}.estado-cuenta__pago-metodo{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:capitalize}.estado-cuenta__pago-concepto{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.estado-cuenta__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-2xl);text-align:center;color:var(--color-text-secondary)}.estado-cuenta__empty p{margin:0;font-size:var(--font-size-base)}.estado-cuenta__footer{display:flex;justify-content:flex-start;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}@media(max-width:1024px){.estado-cuenta__content-grid{grid-template-columns:1fr}.estado-cuenta__resumen-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.estado-cuenta-page{padding:var(--spacing-md)}.estado-cuenta-page__header{flex-direction:column;align-items:flex-start}.estado-cuenta-page__actions{width:100%;flex-direction:column}.estado-cuenta-page__actions button{width:100%}.estado-cuenta__resumen-grid{grid-template-columns:1fr}.estado-cuenta__matricula-item{flex-direction:column;gap:var(--spacing-md)}.estado-cuenta__matricula-precio{align-self:flex-start}.estado-cuenta__pago-item{flex-direction:column;gap:var(--spacing-sm)}.estado-cuenta__pago-fecha{min-width:auto;padding-right:0;border-right:none;border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-sm)}}.estado-cuenta__pagos-list::-webkit-scrollbar{width:8px}.estado-cuenta__pagos-list::-webkit-scrollbar-track{background:var(--color-background-subtle);border-radius:var(--border-radius-sm)}.estado-cuenta__pagos-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--border-radius-sm)}.estado-cuenta__pagos-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.curso-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.curso-form__fields{display:flex;flex-direction:column;gap:var(--spacing-md)}.curso-form__checkbox{padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.curso-form__checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.curso-form__checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary-500)}.curso-form__checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.curso-form__checkbox-helper{margin:var(--spacing-xs) 0 0 26px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.theme-dark .curso-form__checkbox{background-color:#ffffff0d;border-color:var(--color-border-dark)}.theme-dark .curso-form__checkbox-label{color:var(--color-text-primary-dark)}.theme-dark .curso-form__checkbox-helper{color:var(--color-text-secondary-dark)}.curso-edit-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.curso-edit-form__fields{display:flex;flex-direction:column;gap:var(--spacing-md)}.curso-edit-form__estado-activo{background-color:var(--color-success-50);border-color:var(--color-success-200)}.curso-edit-form__estado-inactivo{background-color:var(--color-error-50);border-color:var(--color-error-200)}.theme-dark .curso-edit-form__estado-activo{background-color:#22c55e1a;border-color:var(--color-success-600)}.theme-dark .curso-edit-form__estado-inactivo{background-color:#ef44441a;border-color:var(--color-error-600)}.cursos-page{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl)}.cursos-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.cursos-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.cursos-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.cursos-page__filters{display:flex;gap:var(--spacing-md);align-items:flex-end}.cursos-page__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.cursos__valor{font-weight:var(--font-weight-semibold);color:var(--color-success-600)}.cursos-page__pagination{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.theme-dark .cursos-page__title{color:var(--color-text-primary-dark)}.theme-dark .cursos-page__subtitle{color:var(--color-text-secondary-dark)}.theme-dark .cursos__valor{color:var(--color-success-400)}.theme-dark .cursos-page__pagination{border-top-color:var(--color-border-dark)}.curso-details{display:flex;flex-direction:column;gap:var(--spacing-md)}.curso-details__row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.curso-details__row:last-child{border-bottom:none}.curso-details__label{font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.curso-details__value{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-align:right}.theme-dark .curso-details__row{border-bottom-color:var(--color-border-dark)}.theme-dark .curso-details__label{color:var(--color-text-secondary-dark)}.theme-dark .curso-details__value{color:var(--color-text-primary-dark)}.cursos-page{padding:var(--spacing-md);gap:var(--spacing-lg);max-width:1400px;margin:0 auto}.cursos-page__header{flex-direction:column;align-items:stretch}.cursos-page__title{font-size:var(--font-size-xl)}.cursos-page__filters{flex-direction:column;align-items:stretch}.cursos-page__actions{flex-direction:column}@media(min-width:480px){.cursos-page__filters{flex-direction:row;flex-wrap:wrap}.cursos-page__filters>*{flex:1 1 200px}.cursos-page__actions{flex-direction:row}}@media(min-width:768px){.cursos-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.cursos-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.cursos-page__title{font-size:var(--font-size-2xl)}}@media(min-width:900px){.cursos-page__filters{flex-wrap:nowrap}.cursos-page__filters>*{flex:1}}@media(min-width:1024px){.cursos-page{padding:var(--spacing-xl)}.cursos-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1440px){.cursos-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}}.grupos-page{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-md);max-width:1400px;margin:0 auto}.grupos-page__header{display:flex;flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.grupos-page__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.grupos-page__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.grupos-page__header-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.grupos-page__header-actions .btn{width:100%;justify-content:center}.grupos-page__filters{display:flex;flex-direction:column;gap:var(--spacing-md);align-items:stretch}.grupos-page__actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.grupos__curso-nivel{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-xs);text-transform:capitalize}.grupos__horario{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.grupos-page__pagination{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media(min-width:480px){.grupos-page__header-actions{flex-direction:row;flex-wrap:wrap}.grupos-page__header-actions .btn{width:auto}.grupos-page__filters{flex-direction:row;flex-wrap:wrap}.grupos-page__filters>*{flex:1 1 200px;min-width:180px}.grupos-page__actions{flex-direction:row;justify-content:flex-end}}@media(min-width:768px){.grupos-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.grupos-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.grupos-page__title{font-size:var(--font-size-2xl)}.grupos-page__subtitle{font-size:var(--font-size-base)}}@media(min-width:900px){.grupos-page__filters{flex-wrap:nowrap}.grupos-page__filters>*{flex:1;min-width:auto}.grupos-page__pagination{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}}@media(min-width:1024px){.grupos-page{padding:var(--spacing-xl)}.grupos-page__title{font-size:var(--font-size-3xl)}.grupos-page__header-actions{gap:var(--spacing-md)}}@media(min-width:1280px){.grupos-page{gap:var(--spacing-xl)}}@media(min-width:1440px){.grupos-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}.grupos-page__header{margin-bottom:var(--spacing-md)}}.theme-dark .grupos-page__title{color:var(--color-text-primary)}.theme-dark .grupos-page__subtitle,.theme-dark .grupos__curso-nivel,.theme-dark .grupos__horario{color:var(--color-text-secondary)}.theme-dark .grupos-page__pagination{border-top-color:var(--color-border)}.grupo-create-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.grupo-create-page__header{display:flex;align-items:center;gap:var(--spacing-lg)}.grupo-create-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.grupo-create-page__form-header{padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.grupo-create-page__form-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.grupo-create-page__form-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.grupo-create-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.grupo-create-form__fields{display:flex;flex-direction:column;gap:var(--spacing-md)}.grupo-create-form__cupo-row,.grupo-create-form__date-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.grupo-create-form__horario-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.grupo-create-form__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.grupo-create-form__sublabel{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);display:block}.grupo-create-form__horas-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.grupo-create-form__horario-preview{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-50);border-radius:var(--border-radius-md);border:1px solid var(--color-primary-200)}.grupo-create-form__preview-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary-700);text-transform:uppercase;letter-spacing:.05em}.grupo-create-form__preview-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-900);flex:1}.grupo-create-form__helper-text{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}.theme-dark .grupo-create-form__horario-section{background-color:var(--color-background-tertiary)}.theme-dark .grupo-create-form__dia-btn{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-secondary)}.theme-dark .grupo-create-form__dia-btn:hover:not(:disabled){background-color:#3b82f61a;border-color:var(--color-primary-400);color:var(--color-primary-400)}.theme-dark .grupo-create-form__horario-preview{background-color:#3b82f61a;border-color:#3b82f64d}.theme-dark .grupo-create-form__preview-label{color:var(--color-primary-400)}.theme-dark .grupo-create-form__preview-value{color:var(--color-primary-300)}@media(max-width:640px){.grupo-create-page{padding:var(--spacing-md);gap:var(--spacing-md)}.grupo-create-page__header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.grupo-create-page__title{font-size:var(--font-size-xl)}.grupo-create-page__form-title{font-size:var(--font-size-lg)}.grupo-create-form__cupo-row,.grupo-create-form__date-row,.grupo-create-form__horas-row{grid-template-columns:1fr}.grupo-create-form__dias-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.grupo-create-page{padding:var(--spacing-xl)}.grupo-create-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1280px){.grupo-create-page{padding:var(--spacing-2xl) var(--spacing-xl)}}.grupo-detalle-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.grupo-detalle-page__header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.grupo-detalle-page__actions{display:flex;gap:var(--spacing-sm)}.grupo-detalle__info-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.grupo-detalle__name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.grupo-detalle__municipio{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.grupo-detalle__badges{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.grupo-detalle__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.grupo-detalle__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grupo-detalle__info-grid--small{gap:var(--spacing-md)}.grupo-detalle__info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.grupo-detalle__info-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.grupo-detalle__info-label svg{color:var(--color-text-tertiary)}.grupo-detalle__info-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.grupo-detalle__info-value--highlight{color:var(--color-primary);font-weight:var(--font-weight-bold)}.grupo-detalle__empty{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-lg);font-style:italic;grid-column:1 / -1}.theme-dark .grupo-detalle__info-label svg{color:var(--color-text-secondary)}@media(max-width:640px){.grupo-detalle-page{padding:var(--spacing-md);gap:var(--spacing-md)}.grupo-detalle-page__header{flex-direction:column;align-items:stretch}.grupo-detalle-page__actions{width:100%}.grupo-detalle-page__actions>*{flex:1}.grupo-detalle__info-header{flex-direction:column;gap:var(--spacing-md)}.grupo-detalle__name{font-size:var(--font-size-xl)}.grupo-detalle__info-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}@media(min-width:768px){.grupo-detalle-page{padding:var(--spacing-xl)}.grupo-detalle__name{font-size:var(--font-size-3xl)}.grupo-detalle__info-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.grupo-detalle__info-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.grupo-detalle-page{padding:var(--spacing-2xl) var(--spacing-xl)}}.grupo-edit-page{padding:var(--spacing-lg);max-width:var(--container-md);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.grupo-edit-page__loading{display:flex;justify-content:center;padding:3rem}.grupo-edit-page__header{display:flex;align-items:center;gap:var(--spacing-md)}.grupo-edit-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.grupo-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.grupo-edit-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grupo-edit-form__field{display:flex;flex-direction:column}.grupo-edit-form__field--full{grid-column:1 / -1}.grupo-edit-form__horario-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.grupo-edit-form__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.grupo-edit-form__sublabel{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);display:block}.grupo-edit-form__horas-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.grupo-edit-form__horario-preview{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-50);border-radius:var(--border-radius-md);border:1px solid var(--color-primary-200)}.grupo-edit-form__preview-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary-700);text-transform:uppercase;letter-spacing:.05em}.grupo-edit-form__preview-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-900);flex:1}.grupo-edit-form__helper-text{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}.theme-dark .grupo-edit-form__horario-section{background-color:var(--color-background-tertiary)}.theme-dark .grupo-edit-form__horario-preview{background-color:#3b82f61a;border-color:#3b82f64d}.theme-dark .grupo-edit-form__preview-label{color:var(--color-primary-400)}.theme-dark .grupo-edit-form__preview-value{color:var(--color-primary-300)}.grupo-edit-form__actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}@media(max-width:640px){.grupo-edit-page{padding:var(--spacing-md);gap:var(--spacing-md)}.grupo-edit-page__header{flex-direction:column;align-items:flex-start}.grupo-edit-page__title{font-size:var(--font-size-xl)}.grupo-edit-form__grid{grid-template-columns:1fr;gap:var(--spacing-md)}.grupo-edit-form__horas-row{grid-template-columns:1fr}.grupo-edit-form__dias-grid{grid-template-columns:repeat(2,1fr)}.grupo-edit-form__actions{flex-direction:column-reverse}.grupo-edit-form__actions>*{width:100%}}@media(min-width:768px){.grupo-edit-page{padding:var(--spacing-xl)}.grupo-edit-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1024px){.grupo-edit-form__grid{grid-template-columns:repeat(3,1fr)}}.union-grupos-page{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl)}.union-grupos-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.union-grupos-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.union-grupos-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.union-grupos-page__header-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.union-grupos-page__info{background:var(--color-info-bg);border:1px solid var(--color-info-border)}.union-grupos-page__info-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.union-grupos-page__info-icon{color:var(--color-info);flex-shrink:0;margin-top:var(--spacing-xs)}.union-grupos-page__info-content h3{margin:0 0 var(--spacing-sm);color:var(--color-text-primary);font-size:var(--font-size-lg)}.union-grupos-page__info-content ul{margin:0;padding-left:var(--spacing-lg);color:var(--color-text-secondary)}.union-grupos-page__info-content li{margin-bottom:var(--spacing-xs)}.union-grupos-page__filters{display:flex;gap:var(--spacing-md);align-items:flex-end}.union-grupos-page__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.union-grupos-page__section-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.union-grupos__curso-nombre{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.union-grupos__modal-info{background:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg)}.union-grupos__modal-info p{margin:0;margin-bottom:var(--spacing-xs)}.union-grupos__modal-info p:last-child{margin-bottom:0}.union-grupos__simulacion{display:flex;flex-direction:column;gap:var(--spacing-lg)}.union-grupos__simulacion-status{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-radius:var(--border-radius-md);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.union-grupos__simulacion-status.success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.union-grupos__simulacion-status.error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}.union-grupos__simulacion-detalle{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--spacing-lg);align-items:center}.union-grupos__simulacion-grupo{background:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--border-radius-md);border:2px solid var(--color-border);min-width:280px}.union-grupos__simulacion-grupo--origen{border-color:var(--color-error-border);background:var(--color-error-bg)}.union-grupos__simulacion-grupo--destino{border-color:var(--color-success-border);background:var(--color-success-bg)}.union-grupos__simulacion-grupo-header{margin-bottom:var(--spacing-sm)}.union-grupos__simulacion-grupo h4{margin:0 0 var(--spacing-xs);color:var(--color-text-primary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;opacity:.7}.union-grupos__simulacion-grupo-codigo{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.union-grupos__simulacion-grupo-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.union-grupos__simulacion-grupo-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.union-grupos__simulacion-grupo-row .label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.union-grupos__simulacion-grupo-row .value{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.union-grupos__simulacion-grupo-row.highlight{background:#ffffff1a;margin:0 calc(-1 * var(--spacing-md));padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm)}.union-grupos__simulacion-grupo-row.highlight .value{font-weight:var(--font-weight-bold);color:var(--color-primary)}.union-grupos__simulacion-grupo-divider{height:1px;background:var(--color-border);margin:var(--spacing-sm) 0}.union-grupos__simulacion-flecha{color:var(--color-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs)}.union-grupos__simulacion-flecha-text{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;opacity:.7}.union-grupos__simulacion-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.union-grupos__confirm,.union-grupos__confirm-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.union-grupos__confirm-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.union-grupos__confirm-field label{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.union-grupos__checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-weight:400}.union-grupos__checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.union-grupos__confirm-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.theme-dark .union-grupos-page__title{color:var(--color-text-primary-dark)}.theme-dark .union-grupos-page__subtitle,.theme-dark .union-grupos__curso-nombre{color:var(--color-text-secondary-dark)}.theme-dark .union-grupos__simulacion-grupo{background:var(--color-bg-secondary-dark);border-color:var(--color-border-dark)}.theme-dark .union-grupos__simulacion-grupo--origen{border-color:var(--color-error);background:#ef44441a}.theme-dark .union-grupos__simulacion-grupo--destino{border-color:var(--color-success);background:#22c55e1a}.theme-dark .union-grupos__simulacion-grupo h4,.theme-dark .union-grupos__simulacion-grupo-codigo{color:var(--color-text-primary-dark)}.theme-dark .union-grupos__simulacion-grupo-row .label{color:var(--color-text-secondary-dark)}.theme-dark .union-grupos__simulacion-grupo-row .value{color:var(--color-text-primary-dark)}.theme-dark .union-grupos__simulacion-grupo-row.highlight{background:#ffffff0d}.theme-dark .union-grupos__simulacion-grupo-divider{background:var(--color-border-dark)}.theme-dark .union-grupos__modal-info{background:var(--color-bg-secondary-dark)}@media(max-width:768px){.union-grupos-page{padding:var(--spacing-md);gap:var(--spacing-lg)}.union-grupos-page__header{flex-direction:column;align-items:stretch}.union-grupos-page__header-actions{flex-direction:column}.union-grupos-page__header-actions .btn{width:100%;justify-content:center}.union-grupos-page__title{font-size:var(--font-size-xl)}.union-grupos-page__filters{flex-direction:column;align-items:stretch}.union-grupos-page__info-content{flex-direction:column}.union-grupos__simulacion-detalle{grid-template-columns:1fr;gap:var(--spacing-md)}.union-grupos__simulacion-grupo{min-width:auto}.union-grupos__simulacion-flecha{flex-direction:row;padding:var(--spacing-sm) 0}.union-grupos__simulacion-flecha svg{transform:rotate(90deg)}.union-grupos__simulacion-actions,.union-grupos__confirm-actions{flex-direction:column}.union-grupos__simulacion-actions .btn,.union-grupos__confirm-actions .btn{width:100%;justify-content:center}}.matriculas-container{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.matriculas-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.header-content h1{margin:0 0 var(--spacing-xs) 0;color:var(--color-text-primary);font-size:var(--font-size-2xl);font-weight:600}.subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-base)}.filtros-container{padding:var(--spacing-md)}.filtros-container h3{margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:600}.filtros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);align-items:end}.filter-actions{grid-column:1 / -1}.table-scroll-wrapper{max-height:calc(100vh - 400px);min-height:400px;overflow-y:auto;overflow-x:hidden;border-top:1px solid var(--color-border-light)}.table-info{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border-light);margin-bottom:0}.pagination-container{text-align:center;padding:var(--spacing-lg);border-top:1px solid var(--color-border-light)}.loading-more{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-text-secondary)}.table-scroll-wrapper::-webkit-scrollbar{width:8px}.table-scroll-wrapper::-webkit-scrollbar-track{background:var(--color-background);border-radius:var(--radius-md)}.table-scroll-wrapper::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-md)}.table-scroll-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-tertiary)}.filter-actions{display:flex;align-items:flex-end;padding-bottom:var(--spacing-xs)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);gap:var(--spacing-md)}.table-info{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-md)}.table-info p{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.estudiante-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.estudiante-nombre{font-weight:600;color:var(--color-text-primary)}.estudiante-codigo{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-family:Courier New,monospace}.grupo-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.grupo-codigo{font-weight:600;color:var(--color-text-primary);font-family:Courier New,monospace}.curso-nombre{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.financiero-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.valor-row{display:flex;align-items:center;gap:var(--spacing-sm)}.valor-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);min-width:60px}.valor-total{font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-sm)}.valor-pendiente{font-weight:600;font-size:var(--font-size-sm)}.valor-pendiente.con-deuda{color:var(--color-error)}.valor-pendiente.sin-deuda{color:var(--color-success)}.acciones-cell{display:flex;gap:var(--spacing-xs);flex-direction:row;flex-wrap:nowrap;justify-content:flex-end}.matriculas-container{padding:var(--spacing-sm);max-width:1400px;margin:0 auto}.matriculas-header{flex-direction:column;align-items:stretch}.header-content h1{font-size:var(--font-size-lg)}.filtros-grid{grid-template-columns:1fr}.acciones-cell{flex-direction:column}.acciones-cell button{width:100%}@media(min-width:480px){.matriculas-container{padding:var(--spacing-md)}.header-content h1{font-size:var(--font-size-xl)}.filtros-grid{grid-template-columns:repeat(2,1fr)}.acciones-cell{flex-direction:row}.acciones-cell button{width:auto}}@media(min-width:768px){.matriculas-container{padding:var(--spacing-lg)}.matriculas-header{flex-direction:row;justify-content:space-between;align-items:flex-start}.header-content h1{font-size:var(--font-size-2xl)}.filtros-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(min-width:900px){.filtros-grid{grid-template-columns:repeat(3,1fr)}.table-scroll-wrapper{max-height:calc(100vh - 350px)}}@media(min-width:1024px){.matriculas-container{padding:var(--spacing-xl);gap:var(--spacing-xl)}.header-content h1{font-size:var(--font-size-3xl)}.filtros-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1280px){.filtros-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:1440px){.matriculas-container{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}.table-scroll-wrapper{max-height:calc(100vh - 300px)}}.matricula-form-container{max-width:900px;margin:0 auto;padding:var(--spacing-lg)}.matricula-form-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-md)}.matricula-form-header{margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-md)}.matricula-form-header h1{margin:0 0 var(--spacing-xs) 0;color:var(--color-text-primary);font-size:var(--font-size-2xl);font-weight:600}.matricula-form-subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-base)}.matricula-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-section h3{margin:0;color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:600}.estudiante-autocomplete-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md);background-color:var(--color-background);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color .2s ease}.estudiante-autocomplete-item:hover{background-color:var(--color-primary)}.estudiante-autocomplete-item:hover .estudiante-info strong,.estudiante-autocomplete-item:hover .estudiante-documento-label,.estudiante-autocomplete-item:hover .estudiante-codigo,.estudiante-autocomplete-item:hover .estudiante-municipio{color:#fff}.estudiante-info{display:flex;flex-direction:column;gap:2px;flex:1}.estudiante-info strong{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:600}.estudiante-documento-label{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:600}.estudiante-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.estudiante-codigo{color:var(--color-text-primary);font-size:var(--font-size-xs);font-family:Courier New,monospace;background-color:var(--color-background-secondary);padding:2px 6px;border-radius:var(--border-radius-sm);font-weight:500}.estudiante-municipio{color:var(--color-text-primary);font-size:var(--font-size-xs);font-weight:500}.selected-estudiante-card{margin-top:var(--spacing-md);background-color:var(--color-background-secondary);border:1px solid var(--color-primary);border-radius:var(--border-radius-md);overflow:hidden}.selected-estudiante-header{background-color:var(--color-primary);padding:var(--spacing-xs) var(--spacing-md)}.selected-label{color:#fff;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.selected-estudiante-body{padding:var(--spacing-md)}.selected-estudiante-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.selected-estudiante-details{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.selected-estudiante-info{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap}.selected-grupo-card{margin-top:var(--spacing-md);background-color:var(--color-background-secondary);border:1px solid var(--color-primary);border-radius:var(--border-radius-md);overflow:hidden}.selected-grupo-header{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-primary);padding:var(--spacing-xs) var(--spacing-md)}.selected-grupo-body{padding:var(--spacing-md)}.selected-grupo-title{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.grupo-codigo-display{font-size:var(--font-size-sm);font-family:Courier New,monospace;color:var(--color-primary);font-weight:600;background-color:var(--color-primary-light, rgba(59, 130, 246, .1));padding:2px 8px;border-radius:var(--border-radius-sm);width:fit-content}.grupo-curso-display{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.selected-grupo-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-sm)}.grupo-detail-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.detail-icon{font-size:var(--font-size-base)}.grupo-detail-price{color:var(--color-success);font-weight:600}.precio-valor{font-size:var(--font-size-base);font-weight:700}.grupo-info-card{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);margin-top:var(--spacing-md)}.grupo-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.grupo-info-header h4{margin:0;color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:600}.grupo-info-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-value{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:500}.info-value-price{color:var(--color-success);font-size:var(--font-size-lg);font-weight:700}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.readonly-field{background-color:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:var(--spacing-md)}.readonly-value{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.financial-summary{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-top:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.summary-item{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:150px;flex:1}.summary-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.summary-value-success{color:var(--color-success)}.summary-value-danger{color:var(--color-error)}.summary-value-discount{color:var(--color-warning)}.summary-value-primary{color:var(--color-primary);font-size:var(--font-size-2xl)}.summary-item-total{padding-top:var(--spacing-md);border-top:2px solid var(--color-border);width:100%}.valor-curso-display{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--color-primary-50);border-radius:var(--border-radius-md);border:1px solid var(--color-primary-200);margin-bottom:var(--spacing-md)}.valor-curso-label{font-size:var(--font-size-base);font-weight:500;color:var(--color-text-secondary)}.valor-curso-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary)}.theme-dark .valor-curso-display{background-color:#3b82f61a;border-color:#3b82f64d}@media(max-width:768px){.matricula-form-container{padding:var(--spacing-md)}.matricula-form-header h1{font-size:var(--font-size-xl)}.grupo-info-details{grid-template-columns:1fr}.estudiante-autocomplete-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.estudiante-meta{flex-direction:row;align-items:center;gap:var(--spacing-sm)}.selected-estudiante-card{margin-top:var(--spacing-sm)}.selected-estudiante-name{font-size:var(--font-size-base)}.selected-grupo-card{margin-top:var(--spacing-sm)}.selected-grupo-details{grid-template-columns:1fr 1fr}.grupo-curso-display{font-size:var(--font-size-base)}.form-grid{grid-template-columns:1fr}.financial-summary{flex-direction:column}.summary-item{min-width:100%;flex-direction:row;justify-content:space-between;align-items:center}.summary-value{font-size:var(--font-size-lg)}}@media(max-width:480px){.matricula-form-container{padding:var(--spacing-sm)}.grupo-info-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.readonly-field{padding:var(--spacing-sm)}.readonly-value{font-size:var(--font-size-base)}}.pago-form{display:flex;flex-direction:column;gap:2rem}.pago-form__section{display:flex;flex-direction:column;gap:1rem}.pago-form__section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.pago-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.pago-form__field{display:flex;flex-direction:column;gap:.5rem}.pago-form__field--full{grid-column:1 / -1}.pago-form__label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.pago-form__textarea{padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;background-color:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.pago-form__textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.pago-form__textarea::placeholder{color:var(--text-tertiary)}.pago-form__estudiante-info{display:flex;flex-wrap:wrap;gap:.5rem}.pago-form__selection-container{display:flex;flex-direction:column;gap:1rem}.pago-form__estudiante-card{padding:1rem!important;background-color:var(--bg-secondary);border:1px solid var(--border-color);margin-top:.5rem}.estudiante-card__header{margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.estudiante-card__header strong{font-size:1rem;color:var(--text-primary)}.estudiante-card__info{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;font-weight:500}.info-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.pago-form__loading{display:flex;align-items:center;gap:.75rem;padding:1rem;background-color:var(--bg-secondary);border-radius:6px;color:var(--text-secondary);font-size:.875rem}.pago-form__matricula-card{padding:1rem!important;background-color:var(--bg-secondary);border:1px solid var(--border-color);margin-top:.5rem}.matricula-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.matricula-card__header strong{font-size:1rem;color:var(--text-primary)}.matricula-card__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;font-weight:500}.detail-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.detail-value--highlight{color:var(--success-color);font-weight:600}@media(max-width:768px){.pago-form__grid{grid-template-columns:1fr}.pago-form__field--full{grid-column:1}.estudiante-card__info,.matricula-card__details{grid-template-columns:1fr}}.pagos-filters{margin-bottom:1.5rem}.pagos-filters__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.pagos-filters__title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.pagos-filters__content{display:flex;flex-direction:column;gap:1rem}.pagos-filters__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.pagos-filters__field{min-width:0}.pagos-filters__field--date{max-width:200px}.pagos-filters__advanced{padding-top:1rem;border-top:1px solid var(--border-color)}.pagos-filters__actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}@media(max-width:768px){.pagos-filters__row{grid-template-columns:1fr}.pagos-filters__field--date{max-width:100%}.pagos-filters__actions{flex-direction:column}.pagos-filters__actions button{width:100%}}.pagos-page{padding:var(--spacing-md);max-width:1400px;margin:0 auto}.pagos-page__header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.pagos-page__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.pagos-page__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.pagos-page__filters{display:flex;flex-direction:column;gap:var(--spacing-md)}.pagos-page__filters>*{flex:1;min-width:100%}.pagos-page__actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pagos-page__pagination{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.pago-detalle{display:flex;flex-direction:column;gap:var(--spacing-lg)}.pago-detalle__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.pago-detalle__comprobante{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.pago-detalle__grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.pago-detalle__item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.pago-detalle__item--full{grid-column:1}.pago-detalle__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.025em}.pago-detalle__value{font-size:var(--font-size-base);color:var(--color-text-primary)}.pago-detalle__value--monto{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success)}.pago-detalle__actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media(min-width:480px){.pagos-page__filters{flex-direction:row;flex-wrap:wrap}.pagos-page__filters>*{flex:1 1 200px;min-width:200px}.pagos-page__actions{flex-direction:row;justify-content:flex-end}.pago-detalle__grid{grid-template-columns:repeat(2,1fr)}.pago-detalle__item--full{grid-column:1 / -1}.pago-detalle__actions{flex-direction:row;justify-content:flex-end}}@media(min-width:768px){.pagos-page{padding:var(--spacing-lg)}.pagos-page__header{flex-direction:row;justify-content:space-between;align-items:center}.pagos-page__title{font-size:var(--font-size-2xl)}.pagos-page__filters>*{flex:1 1 180px;min-width:180px}}@media(min-width:900px){.pagos-page__filters{flex-wrap:nowrap}.pagos-page__filters>*{flex:1;min-width:auto}.pago-detalle__grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.pagos-page{padding:var(--spacing-xl)}.pagos-page__title{font-size:var(--font-size-3xl)}.pago-detalle__comprobante{font-size:var(--font-size-2xl)}}@media(min-width:1280px){.pago-detalle__grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1440px){.pagos-page{padding:var(--spacing-2xl)}.pagos-page__header{margin-bottom:var(--spacing-xl)}.pagos-page__pagination{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}}.theme-dark .pagos-page__title{color:var(--color-text-primary)}.theme-dark .pagos-page__subtitle{color:var(--color-text-secondary)}.theme-dark .pago-detalle__header{border-bottom-color:var(--color-border)}.theme-dark .pago-detalle__actions,.theme-dark .pagos-page__pagination{border-top-color:var(--color-border)}.pago-edit-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.pago-edit-form__info{display:flex;justify-content:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.pago-edit-form__field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.pago-edit-form__field label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.pago-edit-form__actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.theme-dark .pago-edit-form__info{border-bottom-color:var(--color-border)}.theme-dark .pago-edit-form__actions{border-top-color:var(--color-border)}.profesor-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.profesor-form__fields{display:flex;flex-direction:column;gap:var(--spacing-xl)}.profesor-form__section{display:flex;flex-direction:column;gap:var(--spacing-md)}.profesor-form__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.profesor-form__checkbox{padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.profesor-form__checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.profesor-form__checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary-500)}.profesor-form__checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.profesor-form__checkbox-helper{margin:var(--spacing-xs) 0 0 26px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.theme-dark .profesor-form__section-title{color:var(--color-text-primary-dark);border-bottom-color:var(--color-border-dark)}.theme-dark .profesor-form__checkbox{background-color:#ffffff0d;border-color:var(--color-border-dark)}.theme-dark .profesor-form__checkbox-label{color:var(--color-text-primary-dark)}.theme-dark .profesor-form__checkbox-helper{color:var(--color-text-secondary-dark)}@media(max-width:768px){.profesor-form__fields{gap:var(--spacing-lg)}.profesor-form__section-title{font-size:var(--font-size-base)}}.profesores-page{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl)}.profesores-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.profesores-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.profesores-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.profesores-page__filters{display:flex;gap:var(--spacing-md);align-items:flex-end;flex-wrap:wrap}.profesores-page__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.profesores__valor{font-weight:var(--font-weight-semibold);color:var(--color-success-600)}.profesores-page__pagination{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.theme-dark .profesores-page__title{color:var(--color-text-primary-dark)}.theme-dark .profesores-page__subtitle{color:var(--color-text-secondary-dark)}.theme-dark .profesores__valor{color:var(--color-success-400)}.theme-dark .profesores-page__pagination{border-top-color:var(--color-border-dark)}.profesores-page{padding:var(--spacing-md);gap:var(--spacing-lg);max-width:1400px;margin:0 auto}.profesores-page__header{flex-direction:column;align-items:stretch}.profesores-page__title{font-size:var(--font-size-xl)}.profesores-page__filters{flex-direction:column;align-items:stretch}.profesores-page__actions{flex-direction:column}@media(min-width:480px){.profesores-page__filters{flex-direction:row;flex-wrap:wrap}.profesores-page__filters>*{flex:1 1 200px}.profesores-page__actions{flex-direction:row}}@media(min-width:768px){.profesores-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.profesores-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.profesores-page__title{font-size:var(--font-size-2xl)}}@media(min-width:900px){.profesores-page__filters{flex-wrap:nowrap}.profesores-page__filters>*{flex:1}}@media(min-width:1024px){.profesores-page{padding:var(--spacing-xl)}.profesores-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1440px){.profesores-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}}.profesor-detalle-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.profesor-detalle-page__header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.profesor-detalle-page__actions{display:flex;gap:var(--spacing-sm)}.profesor-detalle__info-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.profesor-detalle__name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.profesor-detalle__documento{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.profesor-detalle__badges{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.profesor-detalle__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.profesor-detalle__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.profesor-detalle__info-grid--small{gap:var(--spacing-md)}.profesor-detalle__info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profesor-detalle__info-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.profesor-detalle__info-label svg{color:var(--color-text-tertiary)}.profesor-detalle__info-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.profesor-detalle__info-value--highlight{color:var(--color-primary)}.profesor-detalle__info-value--money{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success)}.profesor-detalle__empty{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-lg);font-style:italic;grid-column:1 / -1}.profesor-detalle__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.profesor-detalle__section-header .profesor-detalle__section-title{margin:0;padding:0;border:none}.profesor-detalle__section-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);background-color:var(--color-background-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-full)}.theme-dark .profesor-detalle__info-label svg{color:var(--color-text-secondary)}@media(max-width:640px){.profesor-detalle-page{padding:var(--spacing-md);gap:var(--spacing-md)}.profesor-detalle-page__header{flex-direction:column;align-items:stretch}.profesor-detalle-page__actions{width:100%}.profesor-detalle-page__actions>*{flex:1}.profesor-detalle__info-header{flex-direction:column;gap:var(--spacing-md)}.profesor-detalle__name{font-size:var(--font-size-xl)}.profesor-detalle__info-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.profesor-detalle__info-value--money{font-size:var(--font-size-lg)}}@media(min-width:768px){.profesor-detalle-page{padding:var(--spacing-xl)}.profesor-detalle__name{font-size:var(--font-size-3xl)}.profesor-detalle__info-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.profesor-detalle__info-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.profesor-detalle-page{padding:var(--spacing-2xl) var(--spacing-xl)}}.profesor-edit-page{padding:var(--spacing-lg);max-width:var(--container-wide);margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.profesor-edit-page__header{display:flex;align-items:center;gap:var(--spacing-lg)}.profesor-edit-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.profesor-edit-page__form-header{padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.profesor-edit-page__form-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.profesor-edit-page__form-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}@media(max-width:640px){.profesor-edit-page{padding:var(--spacing-md);gap:var(--spacing-md)}.profesor-edit-page__header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.profesor-edit-page__title{font-size:var(--font-size-xl)}.profesor-edit-page__form-title{font-size:var(--font-size-lg)}}@media(min-width:768px){.profesor-edit-page{padding:var(--spacing-xl)}.profesor-edit-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1280px){.profesor-edit-page{padding:var(--spacing-2xl) var(--spacing-xl)}}.egreso-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.egreso-form__fields{display:flex;flex-direction:column;gap:var(--spacing-xl)}.egreso-form__section{display:flex;flex-direction:column;gap:var(--spacing-md)}.egreso-form__section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.egreso-form__checkbox{padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.egreso-form__checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.egreso-form__checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary-500)}.egreso-form__checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.egreso-form__checkbox-helper{margin:var(--spacing-xs) 0 0 26px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.egreso-form__periodo-group{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-background-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}@media(max-width:480px){.egreso-form__periodo-group{grid-template-columns:1fr}}.theme-dark .egreso-form__section-title{color:var(--color-text-primary-dark);border-bottom-color:var(--color-border-dark)}.theme-dark .egreso-form__checkbox{background-color:#ffffff0d;border-color:var(--color-border-dark)}.theme-dark .egreso-form__checkbox-label{color:var(--color-text-primary-dark)}.theme-dark .egreso-form__checkbox-helper{color:var(--color-text-secondary-dark)}.theme-dark .egreso-form__periodo-group{background-color:#ffffff0d;border-color:var(--color-border-dark)}@media(max-width:768px){.egreso-form__fields{gap:var(--spacing-lg)}.egreso-form__section-title{font-size:var(--font-size-base)}}.egreso-detalle{padding:.5rem 0}.egreso-detalle__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.egreso-detalle__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color)}.egreso-detalle__tipo{display:flex;gap:.5rem;align-items:center}.egreso-detalle__monto{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.egreso-detalle__section{margin-bottom:1.25rem}.egreso-detalle__section-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.egreso-detalle__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(max-width:480px){.egreso-detalle__grid{grid-template-columns:1fr}}.egreso-detalle__field{display:flex;flex-direction:column;gap:.25rem}.egreso-detalle__label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase}.egreso-detalle__value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.egreso-detalle__notas{background-color:var(--bg-secondary);padding:.75rem;border-radius:.375rem;font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.egreso-detalle__section--meta{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.egreso-detalle__meta{display:flex;gap:1.5rem;font-size:.75rem;color:var(--text-tertiary)}.egreso-detalle__actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.egresos-alerta{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:.5rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #f59e0b26}.egresos-alerta:hover{transform:translateY(-1px);box-shadow:0 4px 8px #f59e0b40}.egresos-alerta__icon{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:#f59e0b;border-radius:50%;color:#fff;flex-shrink:0}.egresos-alerta__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;font-size:.6875rem;font-weight:700;color:#fff;background-color:#dc2626;border-radius:9px;display:flex;align-items:center;justify-content:center}.egresos-alerta__content{display:flex;flex-direction:column;gap:.125rem}.egresos-alerta__title{font-size:.8125rem;font-weight:600;color:#92400e}.egresos-alerta__monto{font-size:.75rem;color:#b45309;font-weight:500}@media(max-width:480px){.egresos-alerta{padding:.5rem .75rem}.egresos-alerta__icon{width:28px;height:28px}.egresos-alerta__title{font-size:.75rem}.egresos-alerta__monto{font-size:.6875rem}}.egresos-page{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl)}.egresos-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.egresos-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.egresos-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.egresos-page__filters{display:flex;gap:var(--spacing-md);align-items:flex-end;flex-wrap:wrap}.egresos-page__filters>*{min-width:180px}.egresos-page__filters--dates{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.egresos-page__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.egresos__monto{font-weight:var(--font-weight-semibold);color:var(--color-error-600)}.egresos-page__pagination{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.theme-dark .egresos-page__title{color:var(--color-text-primary-dark)}.theme-dark .egresos-page__subtitle{color:var(--color-text-secondary-dark)}.theme-dark .egresos__monto{color:var(--color-error-400)}.theme-dark .egresos-page__pagination{border-top-color:var(--color-border-dark)}.egresos-page{padding:var(--spacing-md);gap:var(--spacing-lg);max-width:1400px;margin:0 auto}.egresos-page__header{flex-direction:column;align-items:stretch}.egresos-page__title{font-size:var(--font-size-xl)}.egresos-page__filters{flex-direction:column;align-items:stretch}.egresos-page__filters>*{min-width:100%}.egresos-page__actions{flex-direction:column}@media(min-width:480px){.egresos-page__filters{flex-direction:row;flex-wrap:wrap}.egresos-page__filters>*{flex:1 1 180px;min-width:180px}.egresos-page__actions{flex-direction:row}}@media(min-width:768px){.egresos-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.egresos-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.egresos-page__title{font-size:var(--font-size-2xl)}}@media(min-width:900px){.egresos-page__filters{flex-wrap:nowrap}.egresos-page__filters>*{flex:1;min-width:auto}}@media(min-width:1024px){.egresos-page{padding:var(--spacing-xl)}.egresos-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1440px){.egresos-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}}.usuario-form{display:flex;flex-direction:column;gap:1.5rem}.usuario-form__content{display:grid;grid-template-columns:1fr;gap:1.25rem}.usuario-form__field{display:flex;flex-direction:column}@media(min-width:768px){.usuario-form__content{grid-template-columns:1fr 1fr}.usuario-form__field:first-child{grid-column:1 / -1}}.usuarios-page{padding:var(--spacing-md);max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.usuarios-page__header{display:flex;flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.usuarios-page__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.usuarios-page__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.usuarios-page__actions{display:flex;gap:var(--spacing-sm)}.icon-button{background:transparent;border:none;padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.icon-button:hover{background:var(--color-background-secondary);color:var(--color-primary)}.icon-button--danger:hover{background:var(--color-error-light);color:var(--color-error)}.usuario-detail{padding:var(--spacing-md) 0}.usuario-detail__section{display:flex;flex-direction:column;gap:var(--spacing-md)}.usuario-detail__section h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.usuario-detail__field{display:grid;grid-template-columns:1fr;gap:var(--spacing-xs);padding:var(--spacing-sm) 0;align-items:center}.usuario-detail__field label{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.usuario-detail__field span,.usuario-detail__field div{color:var(--color-text-primary);display:flex;align-items:center}@media(min-width:480px){.usuarios-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}}@media(min-width:768px){.usuarios-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.usuarios-page__title{font-size:var(--font-size-2xl)}.usuario-detail__field{grid-template-columns:200px 1fr;gap:var(--spacing-md)}}@media(min-width:900px){.usuario-detail__field{grid-template-columns:250px 1fr}}@media(min-width:1024px){.usuarios-page{padding:var(--spacing-xl)}.usuarios-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1440px){.usuarios-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}}.theme-dark .usuarios-page__title{color:var(--color-text-primary)}.theme-dark .usuarios-page__subtitle{color:var(--color-text-secondary)}.theme-dark .usuario-detail__section h3{border-bottom-color:var(--color-border)}.usuario-detalle-page{padding:1.5rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.usuario-detalle-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.usuario-detalle-page__title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary);margin:.5rem 0 0}.usuario-detalle__info{padding:2rem}.usuario-detalle__info-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.usuario-detalle__avatar{width:80px;height:80px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0}.usuario-detalle__info-title h2{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.usuario-detalle__badges{display:flex;gap:.5rem;flex-wrap:wrap}.usuario-detalle__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.usuario-detalle__info-item{display:flex;flex-direction:column;gap:.5rem}.usuario-detalle__info-label{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.usuario-detalle__info-value{font-size:1rem;color:var(--color-text-primary);font-weight:500}@media(max-width:768px){.usuario-detalle-page{padding:1rem}.usuario-detalle-page__title{font-size:1.5rem}.usuario-detalle__info{padding:1.5rem}.usuario-detalle__info-header{flex-direction:column;align-items:flex-start}.usuario-detalle__avatar{width:60px;height:60px;font-size:1.5rem}.usuario-detalle__info-grid{grid-template-columns:1fr}}.reportes-page{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-xl)}.reportes-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg);flex-wrap:wrap}.reportes-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:var(--spacing-sm) 0 0}.reportes-page__subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.reportes-page__export-buttons{display:flex;gap:var(--spacing-sm)}.reportes-page__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.reporte-card{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-xl);transition:transform .2s,box-shadow .2s}.reporte-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.reporte-card__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--border-radius-lg);background-color:var(--color-background-secondary)}.reporte-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.reporte-card__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.5;flex-grow:1}.reportes-page__filters{display:flex;flex-direction:column;gap:var(--spacing-md);align-items:stretch;width:100%}.reportes-page__filters>*{width:100%!important;min-width:100%!important;flex:none!important}.reportes-page__filter-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-top:var(--spacing-sm);width:100%}.reportes-page__filter-actions>button{width:100%}.reportes-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);gap:var(--spacing-md);color:var(--color-text-secondary)}.reportes-page__kpis{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);width:100%;overflow:hidden}.reportes-page__kpis--4{grid-template-columns:1fr}.kpi-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);text-align:center;min-width:0;overflow:hidden}.kpi-card__label{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px;word-break:break-word}.kpi-card__value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);word-break:break-word}.kpi-card__value--success{color:var(--color-success-600)}.kpi-card__value--danger{color:var(--color-error-600)}.reporte-section__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg)}.reporte-distribucion{display:flex;flex-direction:column;gap:var(--spacing-md)}.reporte-distribucion__item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.reporte-distribucion__header{display:flex;justify-content:space-between;align-items:center}.reporte-distribucion__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.reporte-distribucion__value{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.reporte-distribucion__bar{height:8px;background-color:var(--color-background-secondary);border-radius:var(--border-radius-full);overflow:hidden}.reporte-distribucion__bar-fill{height:100%;border-radius:var(--border-radius-full);transition:width .3s ease}.reporte-distribucion__bar-fill--success{background-color:var(--color-success-500)}.reporte-distribucion__bar-fill--danger{background-color:var(--color-error-500)}.reporte-distribucion__bar-fill--warning{background-color:var(--color-warning-500)}.reportes-page__comparativa{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-bg-secondary);border-radius:var(--border-radius-md)}.comparativa-badge{display:flex;align-items:center;justify-content:center;min-width:100px;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--border-radius-md);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.comparativa-badge--aumento{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.comparativa-badge--disminucion{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}.comparativa-badge--estable{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}.comparativa-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.comparativa-info p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.kpi-card__value--warning{color:var(--color-warning-600)}.theme-dark .kpi-card__value--warning{color:var(--color-warning-400)}.reporte-distribucion__percentage{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-align:right}.reporte__monto-positivo{color:var(--color-success-600);font-weight:var(--font-weight-semibold)}.reporte__monto-negativo{color:var(--color-error-600);font-weight:var(--font-weight-semibold)}.flujo-caja__chart{display:flex;justify-content:space-around;align-items:flex-end;height:200px;padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border)}.flujo-caja__chart-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);flex:1}.flujo-caja__chart-bars{display:flex;gap:4px;align-items:flex-end;height:150px}.flujo-caja__chart-bar{width:24px;min-height:4px;border-radius:var(--border-radius-sm) var(--border-radius-sm) 0 0;transition:height .3s ease}.flujo-caja__chart-bar--ingresos{background-color:var(--color-success-500)}.flujo-caja__chart-bar--egresos{background-color:var(--color-error-500)}.flujo-caja__chart-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}.flujo-caja__legend{display:flex;justify-content:center;gap:var(--spacing-lg);margin-top:var(--spacing-md)}.flujo-caja__legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.flujo-caja__legend-color{width:12px;height:12px;border-radius:var(--border-radius-sm)}.flujo-caja__legend-color--ingresos{background-color:var(--color-success-500)}.flujo-caja__legend-color--egresos{background-color:var(--color-error-500)}.theme-dark .reportes-page__title{color:var(--color-text-primary-dark)}.theme-dark .reportes-page__subtitle{color:var(--color-text-secondary-dark)}.theme-dark .reporte-card__icon{background-color:#ffffff0d}.theme-dark .reporte-card__title{color:var(--color-text-primary-dark)}.theme-dark .reporte-card__description,.theme-dark .kpi-card__label{color:var(--color-text-secondary-dark)}.theme-dark .kpi-card__value{color:var(--color-text-primary-dark)}.theme-dark .kpi-card__value--success{color:var(--color-success-400)}.theme-dark .kpi-card__value--danger{color:var(--color-error-400)}.theme-dark .reporte-section__title,.theme-dark .reporte-distribucion__label{color:var(--color-text-primary-dark)}.theme-dark .reporte-distribucion__bar{background-color:#ffffff1a}.theme-dark .reporte__monto-positivo{color:var(--color-success-400)}.theme-dark .reporte__monto-negativo{color:var(--color-error-400)}.theme-dark .flujo-caja__chart{border-bottom-color:var(--color-border-dark)}.reportes-page{padding:var(--spacing-sm);gap:var(--spacing-md);max-width:1400px;margin:0 auto}.reportes-page__header{flex-direction:column;align-items:stretch;gap:var(--spacing-md)}.reportes-page__title{font-size:var(--font-size-lg);margin:0}.reportes-page__subtitle{font-size:var(--font-size-sm)}.reportes-page__export-buttons{flex-direction:column;width:100%}.reportes-page__export-buttons>button{width:100%}.reportes-page__filters-card{padding:var(--spacing-md)!important}.reportes-page__filters{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:var(--spacing-md)!important}.reportes-page__filters>*{width:100%!important;min-width:100%!important;max-width:100%!important;flex:0 0 100%!important}.reportes-page__filter-actions{display:flex!important;flex-direction:column!important;gap:var(--spacing-sm)!important;margin-top:var(--spacing-sm);width:100%!important}.reportes-page__filter-actions>button{width:100%!important;justify-content:center}.reportes-page__kpis,.reportes-page__kpis--4{grid-template-columns:1fr;gap:var(--spacing-sm)}.kpi-card{padding:var(--spacing-md)}.kpi-card__value{font-size:var(--font-size-lg)}.flujo-caja__chart{height:150px;overflow-x:auto}.flujo-caja__chart-bars{height:100px}.flujo-caja__chart-bar{width:16px}.reportes-page__grid{grid-template-columns:1fr;gap:var(--spacing-md)}.reporte-card{padding:var(--spacing-md)}.reportes-page__comparativa{flex-direction:column;text-align:center}@media(min-width:480px){.reportes-page{padding:var(--spacing-md);gap:var(--spacing-lg)}.reportes-page__title{font-size:var(--font-size-xl)}.reportes-page__export-buttons{flex-direction:row;width:auto}.reportes-page__export-buttons>button{width:auto}.reportes-page__filters{flex-direction:column!important}.reportes-page__filters>*{width:100%!important;min-width:100%!important;flex:0 0 100%!important}.reportes-page__filter-actions{flex-direction:row!important;justify-content:stretch;gap:var(--spacing-sm)}.reportes-page__filter-actions>button{flex:1;width:auto!important}.reportes-page__kpis,.reportes-page__kpis--4,.reportes-page__grid{grid-template-columns:repeat(2,1fr)}.reportes-page__comparativa{flex-direction:row;text-align:left}}@media(min-width:768px){.reportes-page{padding:var(--spacing-lg);gap:var(--spacing-xl)}.reportes-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.reportes-page__title{font-size:var(--font-size-2xl)}.reportes-page__filters{flex-direction:row!important;flex-wrap:wrap!important}.reportes-page__filters>*{flex:1 1 180px!important;min-width:180px!important;max-width:none!important;width:auto!important}.reportes-page__filter-actions{flex:0 0 auto!important}.kpi-card{padding:var(--spacing-lg)}.flujo-caja__chart{height:180px}.flujo-caja__chart-bars{height:130px}.flujo-caja__chart-bar{width:20px}.reporte-card{padding:var(--spacing-lg)}}@media(min-width:900px){.reportes-page__kpis{grid-template-columns:repeat(3,1fr)}.reportes-page__kpis--4{grid-template-columns:repeat(4,1fr)}.reportes-page__filters{flex-wrap:nowrap}.reportes-page__filters>*{flex:1;min-width:auto}.reportes-page__grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.reportes-page{padding:var(--spacing-xl)}.reportes-page__title{font-size:var(--font-size-3xl)}.kpi-card{padding:var(--spacing-xl)}.flujo-caja__chart{height:200px}.flujo-caja__chart-bars{height:150px}.flujo-caja__chart-bar{width:24px}.reporte-card{padding:var(--spacing-xl)}}@media(min-width:1440px){.reportes-page{padding:var(--spacing-2xl);gap:var(--spacing-2xl)}.reportes-page__kpis{gap:var(--spacing-xl)}.flujo-caja__chart{height:250px}.flujo-caja__chart-bars{height:200px}.flujo-caja__chart-bar{width:32px}}.movimientos-page{padding:var(--spacing-lg);max-width:1400px;margin:0 auto}.movimientos-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);gap:var(--spacing-md);flex-wrap:wrap}.movimientos-page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.movimientos-page__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.movimientos-page__filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);align-items:flex-end}.movimientos-page__filter-actions{display:flex;gap:var(--spacing-sm);align-items:flex-end;padding-bottom:2px}.movimientos-page__filters-hint{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic}.movimientos-page__user-selector{margin-bottom:var(--spacing-lg)}.movimientos-page__user-info{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-md);margin-top:var(--spacing-md)}.movimientos-page__user-avatar{width:48px;height:48px;border-radius:50%;background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.movimientos-page__user-details h4{margin:0;font-size:var(--font-size-base);color:var(--color-text-primary)}.movimientos-page__user-details p{margin:var(--spacing-xs) 0 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.movimientos-page__kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media(max-width:768px){.movimientos-page__kpis{grid-template-columns:1fr}}.kpi-card{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-lg)}.kpi-card__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.kpi-card__value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.kpi-card__value--success{color:var(--color-success)}.kpi-card__value--danger{color:var(--color-error)}.kpi-card__value--warning{color:var(--color-warning)}.movimientos-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);color:var(--color-text-secondary)}.movimientos-page__empty{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.movimientos-page__empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.movimientos-page__periodos{display:flex;flex-direction:column;gap:var(--spacing-md)}.periodo-card{border:1px solid var(--color-border);border-radius:var(--border-radius-md);overflow:hidden;background-color:var(--color-bg-primary)}.periodo-card__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-bg-secondary);cursor:pointer;transition:background-color .2s ease}.periodo-card__header:hover{background-color:var(--color-bg-tertiary)}.periodo-card__header-left{display:flex;align-items:center;gap:var(--spacing-md)}.periodo-card__toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.periodo-card__toggle--expanded{transform:rotate(90deg)}.periodo-card__titulo{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.periodo-card__fechas{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0 0}.periodo-card__resumen{display:flex;gap:var(--spacing-lg);align-items:center}.periodo-card__resumen-item{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.periodo-card__resumen-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase}.periodo-card__resumen-valor{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.periodo-card__resumen-valor--positivo{color:var(--color-success)}.periodo-card__resumen-valor--negativo{color:var(--color-error)}.periodo-card__content{padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.periodo-card__section{margin-bottom:var(--spacing-lg)}.periodo-card__section:last-child{margin-bottom:0}.periodo-card__section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.periodo-card__section-count{background-color:var(--color-bg-tertiary);padding:2px 8px;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal)}.movimiento-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-sm)}.movimiento-item:last-child{margin-bottom:0}.movimiento-item__info{display:flex;flex-direction:column;gap:2px}.movimiento-item__concepto{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.movimiento-item__detalle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.movimiento-item__monto{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.movimiento-item__monto--ingreso{color:var(--color-success)}.movimiento-item__monto--egreso{color:var(--color-error)}.movimiento-item__estado{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-left:var(--spacing-sm)}.movimiento-item__estado--pagado{background-color:var(--color-success-light);color:var(--color-success)}.movimiento-item__estado--pendiente{background-color:var(--color-warning-light);color:var(--color-warning)}.movimiento-item__estado--vencido{background-color:var(--color-error-light);color:var(--color-error)}.periodo-card__empty{text-align:center;padding:var(--spacing-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-style:italic}.movimiento-detalle__header{margin-bottom:var(--spacing-lg)}.movimiento-detalle__fecha{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.movimiento-detalle__kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.movimiento-detalle__section{margin-bottom:var(--spacing-lg)}.movimiento-detalle__section:last-child{margin-bottom:0}.movimiento-detalle__section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.movimientos-page{padding:var(--spacing-sm)}.movimientos-page__header{flex-direction:column;align-items:stretch}.movimientos-page__title{font-size:var(--font-size-xl)}.movimientos-page__kpis{grid-template-columns:1fr}.periodo-card__header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.periodo-card__resumen{width:100%;justify-content:space-between}.movimiento-detalle__kpis{grid-template-columns:1fr}@media(min-width:480px){.movimientos-page{padding:var(--spacing-md)}.movimientos-page__kpis,.movimiento-detalle__kpis{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.movimientos-page{padding:var(--spacing-lg)}.movimientos-page__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.movimientos-page__title{font-size:var(--font-size-2xl)}.movimientos-page__kpis{grid-template-columns:repeat(3,1fr)}.periodo-card__header{flex-direction:row;align-items:center;justify-content:space-between}.periodo-card__resumen{width:auto}.movimiento-detalle__kpis{grid-template-columns:repeat(3,1fr)}}@media(min-width:900px){.movimientos-page__filters{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px){.movimientos-page{padding:var(--spacing-xl)}.movimientos-page__title{font-size:var(--font-size-3xl)}}@media(min-width:1440px){.movimientos-page{padding:var(--spacing-2xl)}.movimientos-page__header{margin-bottom:var(--spacing-xl)}.movimientos-page__kpis{gap:var(--spacing-lg)}}:root{--color-primary: #1e40af;--color-primary-dark: #1e3a8a;--color-primary-light: #3b82f6;--color-primary-lighter: #60a5fa;--color-primary-lightest: #93c5fd;--color-secondary: #7c3aed;--color-secondary-dark: #6d28d9;--color-secondary-light: #8b5cf6;--color-accent: #f59e0b;--color-accent-dark: #d97706;--color-accent-light: #fbbf24;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-text-primary: #1f2937;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-disabled: #d1d5db;--color-text-inverse: #ffffff;--color-background: #ffffff;--color-background-secondary: #f9fafb;--color-background-tertiary: #f3f4f6;--color-background-dark: #111827;--color-surface: #ffffff;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-border-dark: #d1d5db;--color-admin-general: #dc2626;--color-admin-financiero: #ea580c;--color-coordinador: #f59e0b;--color-asistente: #10b981;--color-pagado: #10b981;--color-al-dia: #3b82f6;--color-mora: #ef4444;--color-pendiente: #f59e0b;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: "Courier New", 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-light: 300;--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;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--breakpoint-xs: 480px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-md-lg: 900px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-xxl: 1440px;--breakpoint-2xl: 1536px;--container-mobile: 100%;--container-tablet: 768px;--container-desktop: 1024px;--container-wide: 1280px;--radius-none: 0;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--border-radius-none: 0;--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);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .06);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-overlay: 1035;--z-index-sidebar: 1036;--z-index-header: 1037;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070;--header-height: 60px;--header-height-mobile: 60px;--header-height-desktop: 70px;--sidebar-width: 280px;--sidebar-width-expanded: 280px;--sidebar-width-mobile: 0px;--sidebar-width-tablet: 70px;--sidebar-width-desktop: 250px;--button-height-sm: 32px;--button-height-md: 40px;--button-height-lg: 48px;--input-height-sm: 32px;--input-height-md: 40px;--input-height-lg: 48px;--max-width-form: 600px;--max-width-modal-sm: 400px;--max-width-modal-md: 600px;--max-width-modal-lg: 800px;--max-width-modal-xl: 1000px}.theme-dark{--color-background: #111827;--color-background-secondary: #1f2937;--color-background-tertiary: #374151;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-border: #374151;--color-border-light: #4b5563;--color-border-dark: #1f2937;--color-surface: #1f2937;--color-info-light: #1e3a5f;--color-info: #60a5fa;--color-success-light: #064e3b;--color-warning-light: #78350f;--color-error-light: #7f1d1d}.theme-light{--color-surface: #ffffff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}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)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{margin-bottom:var(--spacing-md)}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{max-width:100%;height:auto;display:block}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer;padding:0}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;font-size:inherit;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);width:100%;transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-lightest)}input:disabled,textarea:disabled,select:disabled{background-color:var(--color-background-tertiary);cursor:not-allowed}table{border-collapse:collapse;width:100%}th,td{text-align:left;padding:var(--spacing-sm) var(--spacing-md)}code{font-family:var(--font-family-mono);font-size:.9em;background-color:var(--color-background-tertiary);padding:.2em .4em;border-radius:var(--radius-sm)}pre{font-family:var(--font-family-mono);background-color:var(--color-background-tertiary);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(min-width:768px)and (max-width:1023px){.hidden-tablet{display:none}}@media(min-width:1024px){.hidden-desktop{display:none}.hidden-mobile{display:block}}.container{width:100%;margin-left:auto;margin-right:auto;padding-left:var(--spacing-md);padding-right:var(--spacing-md)}@media(min-width:768px){.container{max-width:var(--container-tablet);padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media(min-width:1024px){.container{max-width:var(--container-desktop);padding-left:var(--spacing-xl);padding-right:var(--spacing-xl)}}@media(min-width:1280px){.container{max-width:var(--container-wide)}}.m-0{margin:0}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.mt-0{margin-top:0}.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)}.mb-0{margin-bottom:0}.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)}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.pt-md{padding-top:var(--spacing-md)}.pb-md{padding-bottom:var(--spacing-md)}.px-md{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.py-md{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.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-light{font-weight:var(--font-weight-light)}.text-normal{font-weight:var(--font-weight-normal)}.text-medium{font-weight:var(--font-weight-medium)}.text-semibold{font-weight:var(--font-weight-semibold)}.text-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.flex-1{flex:1}.flex-auto{flex:auto}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media(min-width:768px){.md-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.lg-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.w-full{width:100%}.w-auto{width:auto}.w-screen{width:100vw}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.max-w-sm{max-width:640px}.max-w-md{max-width:768px}.max-w-lg{max-width:1024px}.max-w-xl{max-width:1280px}.max-w-full{max-width:100%}.border{border:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-l{border-left:1px solid var(--color-border)}.border-r{border-right:1px solid var(--color-border)}.rounded-none{border-radius:var(--radius-none)}.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)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-none{box-shadow:none}.bg-white{background-color:var(--color-background)}.bg-gray{background-color:var(--color-background-secondary)}.bg-gray-light{background-color:var(--color-background-tertiary)}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-error{background-color:var(--color-error)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-error{background-color:var(--color-error-light);color:var(--color-error)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.badge-primary{background-color:var(--color-primary-lightest);color:var(--color-primary)}.card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.transition{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.overlay{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-index-modal-backdrop)}@media(min-width:480px){.sm-flex{display:flex}.sm-hidden{display:none}.sm-block{display:block}.sm-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.md-flex{display:flex}.md-hidden{display:none}.md-block{display:block}.md-flex-row{flex-direction:row}.md-flex-col{flex-direction:column}.md-items-center{align-items:center}.md-justify-between{justify-content:space-between}.md-gap-md{gap:var(--spacing-md)}.md-gap-lg{gap:var(--spacing-lg)}.md-text-left{text-align:left}}@media(min-width:900px){.md-lg-flex{display:flex}.md-lg-hidden{display:none}.md-lg-block{display:block}.md-lg-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md-lg-flex-nowrap{flex-wrap:nowrap}}@media(min-width:1024px){.lg-flex{display:flex}.lg-hidden{display:none}.lg-block{display:block}.lg-flex-row{flex-direction:row}.lg-items-center{align-items:center}.lg-justify-between{justify-content:space-between}.lg-gap-lg{gap:var(--spacing-lg)}.lg-gap-xl{gap:var(--spacing-xl)}}@media(min-width:1280px){.xl-flex{display:flex}.xl-hidden{display:none}.xl-block{display:block}.xl-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl-gap-xl{gap:var(--spacing-xl)}}@media(min-width:1440px){.xxl-flex{display:flex}.xxl-hidden{display:none}.xxl-block{display:block}.xxl-gap-2xl{gap:var(--spacing-2xl)}.xxl-p-2xl{padding:var(--spacing-2xl)}}@media(min-width:1536px){.screen-2xl-flex{display:flex}.screen-2xl-hidden{display:none}.screen-2xl-block{display:block}}.hidden-mobile{display:none}@media(min-width:768px){.hidden-mobile{display:block}.hidden-tablet{display:none}}@media(min-width:1024px){.hidden-tablet{display:block}.hidden-desktop{display:none}}.show-mobile-only{display:block}@media(min-width:768px){.show-mobile-only{display:none}}.show-tablet-only{display:none}@media(min-width:768px)and (max-width:1023px){.show-tablet-only{display:block}}.show-desktop-only{display:none}@media(min-width:1024px){.show-desktop-only{display:block}}
