@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&family=Nunito:wght@400;600&display=swap";:root{--color-azul-confiable: #2C3E50;--color-azul-claro-educativo: #3498DB;--color-verde-exito: #27AE60;--color-verde-claro-estudio: #2ECC71;--color-fondo-crema-academico: #FAFAF5;--color-gris-tipografico: #3C3C3C;--color-azul-confiable-hover: #1a252f;--color-azul-claro-hover: #2980B9;--color-verde-exito-hover: #229954;--color-verde-claro-hover: #27AE60;--color-warning: #fbbf24;--color-risk: #ef4444;--color-warning-hover: #f59e0b;--color-risk-hover: #dc2626;--color-fondo-principal: var(--color-fondo-crema-academico);--color-fondo-secundario: #FFFFFF;--color-fondo-hover: rgba(44, 62, 80, .05);--color-texto-principal: var(--color-gris-tipografico);--color-texto-secundario: #6C757D;--color-texto-claro: #FFFFFF;--color-texto-disabled: #ADB5BD;--color-borde: rgba(44, 62, 80, .1);--color-borde-hover: rgba(44, 62, 80, .2);--font-primary: "Montserrat", sans-serif;--font-secondary: "Nunito", sans-serif;--font-size-h1: clamp(2.25rem, 4vw, 3rem);--font-size-h2: clamp(1.75rem, 3vw, 2rem);--font-size-h3: clamp(1.375rem, 2.5vw, 1.5rem);--font-size-body: clamp(1rem, 1.5vw, 1.125rem);--font-size-small: .875rem;--font-size-xs: .75rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.6;--line-height-relaxed: 1.8;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--border-radius-sm: .5rem;--border-radius-md: 1rem;--border-radius-lg: 1.5rem;--border-radius-xl: 2rem;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(44, 62, 80, .05);--shadow-md: 0 4px 6px rgba(44, 62, 80, .1);--shadow-lg: 0 10px 15px rgba(44, 62, 80, .1);--shadow-xl: 0 20px 25px rgba(44, 62, 80, .15);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden;width:100%;box-sizing:border-box}body{font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-texto-principal);background-color:var(--color-fondo-principal);margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;width:100%;box-sizing:border-box}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);color:var(--color-azul-confiable);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:0}h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable)}h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-medium);color:var(--color-azul-claro-educativo)}h4,h5,h6{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}p{font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-relaxed);color:var(--color-texto-principal);margin:0}.text-highlight{color:var(--color-verde-exito);font-weight:var(--font-weight-semibold)}.text-secondary{color:var(--color-texto-secundario);font-size:var(--font-size-small)}small,.text-small{font-size:var(--font-size-small);line-height:var(--line-height-normal)}a{color:var(--color-azul-claro-educativo);text-decoration:none;font-weight:var(--font-weight-semibold);transition:color var(--transition-fast)}a:hover{color:var(--color-azul-confiable)}a:focus{outline:2px solid var(--color-azul-claro-educativo);outline-offset:2px}button{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);border:none;cursor:pointer;transition:all var(--transition-normal);outline:none}.btn-primary{background-color:var(--color-verde-exito);color:var(--color-texto-claro);padding:.75rem 1.5rem;border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-md)}.btn-primary:hover{background-color:var(--color-verde-exito-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background-color:var(--color-texto-disabled);cursor:not-allowed;opacity:.6}.btn-secondary{background-color:transparent;color:var(--color-azul-claro-educativo);padding:.75rem 1.5rem;border:2px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold)}.btn-secondary:hover{background-color:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}.btn-ghost{background-color:transparent;color:var(--color-azul-claro-educativo);padding:.75rem 1.5rem;border:1px solid var(--color-borde);border-radius:var(--border-radius-full);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold)}.btn-ghost:hover{background-color:var(--color-fondo-hover);border-color:var(--color-borde-hover)}input,textarea,select{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background-color:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:.75rem 1rem;transition:all var(--transition-fast);outline:none}input:focus,textarea:focus,select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}input::placeholder,textarea::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.card{background-color:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.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-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)}.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)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-bold{font-weight:var(--font-weight-bold)}.text-semibold{font-weight:var(--font-weight-semibold)}.text-medium{font-weight:var(--font-weight-medium)}.text-regular{font-weight:var(--font-weight-regular)}.text-azul-confiable{color:var(--color-azul-confiable)}.text-azul-claro{color:var(--color-azul-claro-educativo)}.text-verde-exito{color:var(--color-verde-exito)}.text-verde-claro{color:var(--color-verde-claro-estudio)}.text-gris{color:var(--color-gris-tipografico)}.bg-crema{background-color:var(--color-fondo-crema-academico)}.bg-blanco{background-color:var(--color-fondo-secundario)}.bg-azul-confiable{background-color:var(--color-azul-confiable)}.bg-azul-claro{background-color:var(--color-azul-claro-educativo)}.bg-verde-exito{background-color:var(--color-verde-exito)}@media (max-width: 768px){:root{--font-size-h1: 2rem;--font-size-h2: 1.5rem;--font-size-h3: 1.25rem;--font-size-body: 1rem}.card{padding:var(--spacing-lg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-normal) ease-out}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-fondo-principal)}::-webkit-scrollbar-thumb{background:var(--color-borde);border-radius:var(--border-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-texto-secundario)}.menu-logo-button{position:fixed;top:var(--spacing-md);left:var(--spacing-md);z-index:1000;background:#3498dbbf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--color-texto-claro);border:1px solid rgba(255,255,255,.2);border-radius:var(--border-radius-lg);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;box-shadow:0 4px 16px #3498db4d;transition:all var(--transition-normal);font-family:var(--font-primary);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:var(--spacing-sm);min-width:140px;animation:slideInLeft .5s ease-out}.menu-logo-button:hover{background:#3498dbd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transform:translateY(-2px);box-shadow:0 6px 20px #3498db66;border-color:#ffffff4d}.menu-logo-button:active{transform:translateY(0)}.logo-container{display:flex;align-items:center;gap:var(--spacing-sm);width:100%}.logo-icon{width:32px;height:32px;object-fit:contain;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.logo-text{font-size:var(--font-size-body);letter-spacing:.05em;color:#fff;font-weight:var(--font-weight-bold)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#2c3e50b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;animation:fadeIn .3s ease-out}.menu-nav{position:fixed;top:0;left:0;height:100vh;width:280px;background:linear-gradient(180deg,var(--color-azul-confiable) 0%,var(--color-azul-confiable-hover) 100%);box-shadow:var(--shadow-xl);z-index:999;display:flex;flex-direction:column;transform:translate(-100%);transition:transform var(--transition-normal) cubic-bezier(.4,0,.2,1);overflow:hidden}.menu-nav.menu-open{transform:translate(0)}.menu-nav:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(52,152,219,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(39,174,96,.1) 0%,transparent 50%);pointer-events:none}.menu-header{padding:var(--spacing-xl) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);position:relative;z-index:1}.menu-brand{display:flex;align-items:center;gap:var(--spacing-md);animation:fadeInUp .6s ease-out .2s both;text-decoration:none;cursor:pointer;transition:all var(--transition-normal);border-radius:var(--border-radius-md);padding:var(--spacing-xs);margin:calc(var(--spacing-xs) * -1)}.menu-brand:hover{background:#ffffff1a;transform:translateY(-2px)}.menu-brand:active{transform:translateY(0)}.menu-brand-icon{width:48px;height:48px;object-fit:contain;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.menu-brand-text{display:flex;flex-direction:column}.menu-brand-name{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-bold);color:var(--color-texto-claro);letter-spacing:.05em;line-height:1.2}.menu-brand-subtitle{font-family:var(--font-secondary);font-size:var(--font-size-small);color:#fffc;margin-top:2px}.menu-close-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--color-texto-claro);width:36px;height:36px;border-radius:var(--border-radius-md);cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);font-family:var(--font-primary)}.menu-close-button:hover{background:#fff3;transform:rotate(90deg)}.menu-list{list-style:none;padding:calc(var(--spacing-lg) * .8) 0;margin:0;flex:1;overflow-y:auto;position:relative;z-index:1}.menu-item{margin:calc(var(--spacing-xs) * .8) calc(var(--spacing-md) * .8);animation:fadeInLeft .5s ease-out both}.menu-item:nth-child(1){animation-delay:.1s}.menu-item:nth-child(2){animation-delay:.2s}.menu-item:nth-child(3){animation-delay:.3s}.menu-item:nth-child(4){animation-delay:.4s}.menu-link{display:flex;align-items:center;gap:calc(var(--spacing-md) * .8);padding:calc(var(--spacing-md) * .8) calc(var(--spacing-lg) * .8);color:#ffffffe6;text-decoration:none;border-radius:var(--border-radius-md);transition:all var(--transition-normal);position:relative;overflow:hidden;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:calc(var(--font-size-body) * .8)}.menu-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.menu-link:hover:before{left:100%}.menu-link:hover{background:#ffffff1a;transform:translate(6.4px);color:var(--color-texto-claro)}.menu-link-active{background:#ffffff26;color:var(--color-texto-claro);box-shadow:inset 0 0 20px #ffffff1a,0 4px 12px #0003}.menu-link-active:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3.2px;height:60%;background:var(--color-verde-exito);border-radius:0 var(--border-radius-sm) var(--border-radius-sm) 0;animation:slideInLeft .3s ease-out}.menu-link-icon{width:25.6px;height:25.6px;object-fit:contain;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-normal);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.menu-link:hover .menu-link-icon{transform:scale(1.2) rotate(5deg)}.menu-link-active .menu-link-icon{animation:bounce .6s ease-out}.menu-link-text{flex:1;letter-spacing:.02em}.menu-link-indicator{width:6.4px;height:6.4px;border-radius:50%;background:var(--color-verde-exito);opacity:0;transform:scale(0);transition:all var(--transition-normal);box-shadow:0 0 6.4px var(--color-verde-exito)}.menu-link-active .menu-link-indicator{opacity:1;transform:scale(1);animation:pulse 2s ease-in-out infinite}.menu-footer{padding:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:1;animation:fadeInUp .6s ease-out .4s both;display:flex;flex-direction:column;gap:var(--spacing-md)}.menu-user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#ffffff0d;border-radius:var(--border-radius-md);color:var(--color-texto-claro)}.menu-user-icon{font-size:1.2rem}.menu-user-name{font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-medium)}.menu-logout-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:.75rem 1.5rem;background-color:transparent;border:2px solid var(--color-warning);border-radius:var(--border-radius-md);color:var(--color-warning);cursor:pointer;font-family:var(--font-primary);font-size:calc(var(--font-size-body) * .8);font-weight:var(--font-weight-semibold);transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.menu-logout-button:hover{background-color:var(--color-warning-hover);border-color:var(--color-warning-hover);color:var(--color-texto-claro);box-shadow:var(--shadow-md);transform:translateY(-1px)}.menu-logout-button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.menu-logout-icon{font-size:1rem}.menu-logout-text{flex:1;text-align:left}.menu-footer-decoration{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);text-align:center}.menu-footer-icon{font-size:1.5rem;animation:sparkle 2s ease-in-out infinite}.menu-footer-text{font-family:var(--font-secondary);font-size:var(--font-size-small);color:#ffffffb3;margin:0}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3) rotate(10deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}@keyframes sparkle{0%,to{opacity:.7;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.1) rotate(180deg)}}.menu-list::-webkit-scrollbar{width:6px}.menu-list::-webkit-scrollbar-track{background:#ffffff0d}.menu-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--border-radius-full)}.menu-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width: 768px){.menu-nav{width:280px}.menu-logo-button{top:var(--spacing-sm);left:var(--spacing-sm);min-width:120px;padding:var(--spacing-xs) var(--spacing-sm)}.logo-text{font-size:var(--font-size-small);color:#fff;display:inline}.logo-icon{width:28px;height:28px}}@media (max-width: 768px) and (orientation: portrait){.menu-nav{width:280px}.logo-text{font-size:var(--font-size-small);display:inline;color:#fff}}@media (max-width: 1024px) and (max-height: 768px) and (orientation: landscape){.menu-nav{width:280px;transform:translate(-100%)}.menu-nav.menu-open{transform:translate(0)}.menu-logo-button{top:var(--spacing-sm);left:var(--spacing-sm);min-width:120px;padding:var(--spacing-xs) var(--spacing-sm);display:flex}.logo-text{font-size:var(--font-size-small);color:#fff;display:inline}.logo-icon{width:28px;height:28px}.menu-close-button{display:flex}.menu-overlay{display:block}}@media (max-width: 480px){.menu-nav{width:100%;max-width:320px}.menu-logo-button{min-width:100px}.logo-text{font-size:var(--font-size-small);display:inline;color:#fff}}@media (min-width: 769px) and (min-height: 769px){.menu-nav{transform:translate(0)}.menu-logo-button,.menu-close-button{display:none}}.menu-link,.menu-link-active{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.menu-link{will-change:transform,background-color}.notificacion-button{position:fixed;right:var(--spacing-lg);bottom:var(--spacing-lg);z-index:999;background:var(--color-fondo-secundario);border:2px solid var(--color-borde);border-radius:var(--border-radius-full);width:64px;height:64px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-lg);transition:all var(--transition-normal);padding:0;overflow:visible}.notificacion-button:hover{animation:none;transform:scale(1.1) translateY(0);box-shadow:var(--shadow-xl);border-color:var(--color-azul-claro-educativo)}.notificacion-button-bounce{animation:bounceNotification 1.5s ease-in-out infinite}.notificacion-button-bounce:hover{animation:none;transform:scale(1.1) translateY(0)}@keyframes bounceNotification{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.notificacion-button-icon{width:40px;height:40px;object-fit:contain}.notificacion-badge{position:absolute;top:-4px;right:-4px;background:var(--color-risk);color:var(--color-texto-claro);border-radius:var(--border-radius-full);width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);font-family:var(--font-primary);border:2px solid var(--color-fondo-secundario)}.notificacion-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.notificacion-modal{background-color:#fff!important;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png)!important;background-size:cover,30%!important;background-position:center,center!important;background-repeat:no-repeat,no-repeat!important;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);width:800px;height:600px;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.notificacion-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-modal-title{font-family:var(--font-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:0}.notificacion-modal-close{background:transparent;border:none;font-size:1.5rem;color:var(--color-texto-secundario);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:all var(--transition-fast);line-height:1}.notificacion-modal-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.notificacion-modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;background-color:transparent}.notificacion-empty{text-align:center;padding:var(--spacing-2xl);color:var(--color-texto-secundario)}.notificacion-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.notificacion-item{background:#ffffffe6;border-radius:var(--border-radius-md);padding:var(--spacing-md);border-left:4px solid var(--color-azul-claro-educativo);cursor:pointer;transition:all var(--transition-fast);display:flex;justify-content:space-between;align-items:flex-start;box-shadow:var(--shadow-sm)}.notificacion-item:hover{transform:translate(4px);box-shadow:var(--shadow-md);background:#fffffff2}.notificacion-item.leida{opacity:.7;border-left-color:var(--color-borde)}.notificacion-item-content{flex:1}.notificacion-item-titulo{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0 0 var(--spacing-xs) 0}.notificacion-item-mensaje{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0 0 var(--spacing-xs) 0;line-height:var(--line-height-normal)}.notificacion-item-fecha{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario)}.notificacion-item-fecha-programada{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.notificacion-item-fecha-label{font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:uppercase;letter-spacing:.5px}.notificacion-item-fecha-value{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.notificacion-item-indicator{width:10px;height:10px;background:var(--color-azul-claro-educativo);border-radius:var(--border-radius-full);margin-left:var(--spacing-sm);flex-shrink:0;margin-top:4px}.notificacion-modal-footer{display:flex;gap:var(--spacing-md);justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-top:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-modal-footer-buttons{display:flex;gap:var(--spacing-sm)}.notificacion-modal-button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.notificacion-modal-button-view{background:transparent;color:var(--color-texto-secundario);border:1px solid var(--color-borde)}.notificacion-modal-button-view:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal);border-color:var(--color-texto-secundario)}.notificacion-modal-button-view.active{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-sm)}.notificacion-modal-button-view.active:hover{background:var(--color-azul-claro-hover);border-color:var(--color-azul-claro-hover)}.notificacion-modal-button-close{background:transparent;color:var(--color-texto-secundario);border:1px solid var(--color-borde)}.notificacion-modal-button-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal);border-color:var(--color-texto-secundario)}@media (max-width: 768px){.notificacion-button{right:var(--spacing-sm);bottom:var(--spacing-sm);width:56px;height:56px;max-width:calc(100vw - var(--spacing-sm) * 2);box-sizing:border-box}.notificacion-button-icon{width:32px;height:32px}.notificacion-button-bounce{animation:bounceNotification 1.5s ease-in-out infinite}@keyframes bounceNotification{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.notificacion-modal{width:95vw;height:90vh;max-width:95vw;max-height:90vh}.notificacion-modal-footer{flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.notificacion-modal-footer-buttons{width:100%;display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.notificacion-modal-button-view{flex:1 1 calc(33.333% - var(--spacing-xs));min-width:0;font-size:var(--font-size-small);padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notificacion-modal-button-close{width:100%;margin-top:var(--spacing-xs)}}@media (max-width: 480px){.notificacion-modal-footer-buttons{flex-direction:column}.notificacion-modal-button-view{flex:1;width:100%}}.notificacion-detalle-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--spacing-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.notificacion-detalle-modal{background-color:#fff!important;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png)!important;background-size:cover,40%!important;background-position:center,center!important;background-repeat:no-repeat,no-repeat!important;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:700px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.notificacion-detalle-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-detalle-title{font-family:var(--font-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:0}.notificacion-detalle-close{background:transparent;border:none;font-size:1.5rem;color:var(--color-texto-secundario);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:all var(--transition-fast);line-height:1}.notificacion-detalle-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.notificacion-detalle-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;background-color:transparent}.notificacion-detalle-info{display:flex;flex-direction:column;gap:var(--spacing-lg)}.notificacion-detalle-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.notificacion-detalle-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.notificacion-detalle-value{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal)}.notificacion-detalle-mensaje{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0;line-height:var(--line-height-normal);background:#ffffffe6;padding:var(--spacing-md);border-radius:var(--border-radius-md)}.notificacion-detalle-detalles{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0;line-height:var(--line-height-normal);background:#ffffffe6;padding:var(--spacing-md);border-radius:var(--border-radius-md);white-space:pre-wrap}.notificacion-detalle-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-detalle-button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.notificacion-detalle-button-posponer{background:transparent;color:var(--color-texto-secundario);border:1px solid var(--color-borde)}.notificacion-detalle-button-posponer:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal);border-color:var(--color-texto-secundario)}.notificacion-detalle-button-hecho{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);box-shadow:var(--shadow-sm)}.notificacion-detalle-button-hecho:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.notificacion-detalle-button-hecho:active{transform:translateY(0)}.notificacion-posponer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1002;padding:var(--spacing-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.notificacion-posponer-modal{background-color:#fff!important;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png)!important;background-size:cover,40%!important;background-position:center,center!important;background-repeat:no-repeat,no-repeat!important;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.notificacion-posponer-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-posponer-title{font-family:var(--font-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:0}.notificacion-posponer-close{background:transparent;border:none;font-size:1.5rem;color:var(--color-texto-secundario);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:all var(--transition-fast);line-height:1}.notificacion-posponer-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.notificacion-posponer-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;background-color:transparent}.notificacion-posponer-field{display:flex;flex-direction:column;gap:var(--spacing-md)}.notificacion-posponer-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.notificacion-posponer-input{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background-color:#fffffff2;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);outline:none}.notificacion-posponer-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.notificacion-posponer-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-borde);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notificacion-posponer-button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.notificacion-posponer-button:disabled{opacity:.5;cursor:not-allowed}.notificacion-posponer-button-cancelar{background:transparent;color:var(--color-texto-secundario);border:1px solid var(--color-borde)}.notificacion-posponer-button-cancelar:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal);border-color:var(--color-texto-secundario)}.notificacion-posponer-button-cambio{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);box-shadow:var(--shadow-sm)}.notificacion-posponer-button-cambio:hover:not(:disabled){background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.notificacion-posponer-button-cambio:active:not(:disabled){transform:translateY(0)}@media (max-width: 768px){.notificacion-detalle-modal,.notificacion-posponer-modal{max-height:95vh;max-width:100%}.notificacion-detalle-footer,.notificacion-posponer-footer{flex-direction:column-reverse}.notificacion-detalle-button,.notificacion-posponer-button{width:100%}}.dashboard-shell{min-height:100vh;background:var(--color-fondo-principal);color:var(--color-texto-principal);font-family:var(--font-secondary);position:relative}.dashboard-main{padding:var(--spacing-xl);max-width:1400px;margin:0 auto;transition:margin-left var(--transition-normal)}@media (min-width: 769px){.dashboard-main{margin-left:280px;padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-xl) var(--spacing-lg)}}@media (max-width: 768px){.dashboard-main{width:100%;max-width:100%;padding:var(--spacing-lg);margin-top:60px;margin-left:0;margin-right:0;box-sizing:border-box}}@media (max-width: 768px) and (orientation: portrait){.dashboard-main{width:100%;max-width:100%;padding:var(--spacing-lg);margin-left:0;margin-right:0;box-sizing:border-box}}@media (max-width: 1024px) and (max-height: 768px) and (orientation: landscape){.dashboard-main{margin-left:0;padding:var(--spacing-lg);margin-top:60px}}.view-card{background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);position:relative;overflow:visible}.view-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(/imagenesApp/BuhoLogo-vec.png);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.05;z-index:0;pointer-events:none}.view-card>*{position:relative;z-index:1}.view-header{display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.view-eyebrow{font-family:var(--font-primary);text-transform:uppercase;letter-spacing:.15em;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);margin:0 0 .25rem}.view-title{font-family:var(--font-primary);font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0}.ghost-button{border-radius:var(--border-radius-full);padding:.6rem 1.4rem;border:1px solid var(--color-borde);color:var(--color-azul-claro-educativo);background:transparent;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);transition:all var(--transition-fast);cursor:pointer}.ghost-button:hover{border-color:var(--color-azul-claro-educativo);background:var(--color-fondo-hover)}.primary-link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);color:var(--color-azul-claro-educativo);transition:color var(--transition-fast)}.primary-link:hover{color:var(--color-azul-confiable)}.primary-link:after{content:"↗";font-size:.9rem;transition:transform var(--transition-fast)}.primary-link:hover:after{transform:translate(4px)}@media (max-width: 900px){.dashboard-main{width:100%;max-width:100%;padding:1.25rem;box-sizing:border-box}.dashboard-header{flex-direction:column;gap:1rem;align-items:flex-start}}@media (max-width: 600px){.view-card{padding:1.25rem}.dashboard-header{padding:1rem}.dashboard-main{width:100%;max-width:100%;padding:1rem;margin-left:0;margin-right:0;box-sizing:border-box}}#root{width:100%;height:100%;margin:0;padding:0}.app-container{min-height:100vh;width:100%;display:flex;justify-content:center;align-items:center;background:var(--color-fondo-principal);font-family:var(--font-secondary)}.content{text-align:center;padding:var(--spacing-xl);max-width:800px}.logo{width:200px;height:auto;margin-bottom:var(--spacing-xl);animation:float 3s ease-in-out infinite}.title{font-family:var(--font-primary);font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:var(--spacing-md) 0}.subtitle{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin:var(--spacing-md) auto}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width: 768px){.content{padding:var(--spacing-md)}.logo{width:150px}.title{font-size:var(--font-size-h2)}.subtitle{font-size:var(--font-size-body)}}.primary-button{display:inline-block;padding:var(--spacing-md) var(--spacing-xl);background-color:var(--color-verde-exito);color:var(--color-texto-claro);text-decoration:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);transition:all var(--transition-normal);border:none;cursor:pointer}.primary-button:hover{background-color:var(--color-verde-exito-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out;cursor:pointer}.image-modal-content{position:relative;width:75vw;height:75vh;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out;cursor:default}.image-modal-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:var(--border-radius-md);box-shadow:0 8px 32px #00000080}.image-modal-close{position:absolute;top:-40px;right:0;background:#ffffffe6;border:none;width:40px;height:40px;border-radius:50%;font-size:2rem;color:var(--color-texto-principal);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:10001;line-height:1;padding:0;box-shadow:0 2px 8px #0000004d}.image-modal-close:hover{background:var(--color-texto-claro);transform:scale(1.1);box-shadow:0 4px 12px #0006}.image-modal-close:active{transform:scale(.95)}@media (max-width: 768px){.image-modal-content{width:90vw;height:90vh}.image-modal-close{top:-35px;right:-10px;width:35px;height:35px;font-size:1.5rem}}body:has(.analytics-modal-overlay){overflow-x:hidden!important;width:100%!important;max-width:100vw!important}.analytics-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out;cursor:pointer;padding:var(--spacing-lg, 20px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;width:100vw;max-width:100vw;box-sizing:border-box}.analytics-modal-content{position:relative;width:100%;max-width:1400px;max-height:90vh;background:var(--color-fondo-secundario, #ffffff);border-radius:var(--border-radius-lg, 12px);box-shadow:0 8px 32px #00000080;animation:scaleIn .3s ease-out;cursor:default;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-xl, 24px) var(--spacing-lg, 20px);margin:auto;display:flex;flex-direction:column}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.analytics-modal-close{position:sticky;top:var(--spacing-md, 16px);align-self:flex-end;background:#ffffffe6;border:none;width:40px;height:40px;min-width:40px;min-height:40px;border-radius:50%;font-size:2rem;color:var(--color-texto-principal, #333);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast, .2s);z-index:10001;line-height:1;padding:0;margin-bottom:var(--spacing-md, 16px);box-shadow:0 2px 8px #0000004d;flex-shrink:0}.analytics-modal-close:hover{background:var(--color-texto-claro, #ffffff);transform:scale(1.1);box-shadow:0 4px 12px #0006}.analytics-modal-close:active{transform:scale(.95)}.analytics-modal-header{margin-bottom:var(--spacing-xl, 24px);padding-bottom:var(--spacing-md, 16px);border-bottom:2px solid var(--color-borde, #e0e0e0)}.analytics-modal-header h2{margin:0;font-size:1.75rem;font-weight:var(--font-weight-bold, 700);color:var(--color-texto-principal, #333)}.analytics-loading,.analytics-error{text-align:center;padding:var(--spacing-xl, 24px);color:var(--color-texto-principal, #333)}.analytics-error{color:var(--color-risk, #d32f2f)}.retry-button{margin-top:var(--spacing-md, 16px);padding:var(--spacing-sm, 8px) var(--spacing-md, 16px);background:var(--color-primario, #1976d2);color:#fff;border:none;border-radius:var(--border-radius-md, 8px);cursor:pointer;font-size:var(--font-size-base, 16px);transition:all var(--transition-fast, .2s)}.retry-button:hover{background:var(--color-primario-hover, #1565c0);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.analytics-content{display:flex;flex-direction:column;gap:var(--spacing-lg, 20px);width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg, 20px);align-items:start;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.analytics-charts{display:flex;justify-content:center;width:100%}.chart-container{background:#fff;padding:var(--spacing-md, 16px);border-radius:var(--border-radius-lg, 12px);box-shadow:0 2px 8px #0000001a;min-height:300px;height:400px;width:100%;max-width:100%;overflow:hidden;overflow-x:hidden;box-sizing:border-box;position:relative}.chart-container canvas{max-width:100%!important;height:auto!important}.analytics-table-container{background:#fff;padding:var(--spacing-lg, 20px);border-radius:var(--border-radius-lg, 12px);box-shadow:0 2px 8px #0000001a;min-height:300px;max-height:400px;display:flex;flex-direction:column;overflow:hidden}.analytics-table-container h3{margin:0 0 var(--spacing-md, 16px) 0;font-size:1.25rem;font-weight:var(--font-weight-semibold, 600);color:var(--color-texto-principal, #333);flex-shrink:0}.analytics-table-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;width:100%;max-width:100%;box-sizing:border-box}.analytics-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.analytics-table-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.analytics-table-wrapper::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.analytics-table-wrapper::-webkit-scrollbar-thumb:hover{background:#555}.analytics-table{width:100%;max-width:100%;border-collapse:collapse;display:table;box-sizing:border-box;overflow-x:hidden}.analytics-table thead{background:var(--color-fondo-hover, #f5f5f5)}.analytics-table th{padding:var(--spacing-md, 16px);text-align:left;font-weight:var(--font-weight-semibold, 600);color:var(--color-texto-principal, #333);border-bottom:2px solid var(--color-borde, #e0e0e0)}.analytics-table td{padding:var(--spacing-md, 16px);border-bottom:1px solid var(--color-borde, #e0e0e0);color:var(--color-texto-secundario, #666)}.analytics-table tbody tr:hover{background:var(--color-fondo-hover, #f5f5f5)}.analytics-table tbody tr:last-child td{border-bottom:none}@media (max-width: 1024px) and (min-width: 769px){.analytics-modal-content{padding:var(--spacing-lg, 20px)}.analytics-grid{grid-template-columns:1fr;gap:var(--spacing-md, 16px)}.chart-container{height:350px;min-height:350px}.analytics-table-container{max-height:350px;min-height:250px}}@media (max-width: 768px){.analytics-modal-overlay{align-items:flex-start;padding:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;width:100vw;max-width:100vw}.analytics-modal-content{width:100vw;max-width:100vw;min-height:100vh;max-height:100vh;height:100vh;padding:var(--spacing-md, 16px) var(--spacing-sm, 12px);border-radius:0;margin:0;padding-top:max(var(--spacing-md, 16px),env(safe-area-inset-top));padding-bottom:max(var(--spacing-md, 16px),env(safe-area-inset-bottom));overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.analytics-modal-close{position:sticky;top:var(--spacing-sm, 8px);align-self:flex-end;width:36px;height:36px;min-width:36px;min-height:36px;font-size:1.75rem;margin-bottom:var(--spacing-sm, 8px)}.analytics-modal-header{margin-bottom:var(--spacing-md, 16px);padding-bottom:var(--spacing-sm, 12px)}.analytics-modal-header h2{font-size:1.5rem}.analytics-content{gap:var(--spacing-md, 16px);width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box;flex:1;display:flex;flex-direction:column;min-height:0}.analytics-grid{grid-template-columns:1fr;gap:var(--spacing-md, 16px);width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box;flex:1;display:flex;flex-direction:column;min-height:0}.analytics-charts{width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box;flex-shrink:0}.chart-container{height:280px;min-height:280px;max-height:280px;padding:var(--spacing-sm, 12px);width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.analytics-table-container{height:auto;min-height:0;max-height:none;flex:1;padding:var(--spacing-md, 16px) var(--spacing-sm, 12px);width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box;display:flex;flex-direction:column}.analytics-table-container h3{font-size:1.1rem;margin-bottom:var(--spacing-sm, 12px)}.analytics-table{font-size:.8rem;display:block;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.analytics-table thead{display:none}.analytics-table tbody{display:block;width:100%;max-width:100%;box-sizing:border-box}.analytics-table tbody tr{display:block;margin-bottom:var(--spacing-sm, 12px);border:1px solid var(--color-borde, #e0e0e0);border-radius:var(--border-radius-md, 8px);padding:var(--spacing-sm, 12px);background:var(--color-fondo-secundario, #ffffff);width:100%;max-width:100%;box-sizing:border-box}.analytics-table tbody td{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs, 8px) 0;border-bottom:none;text-align:right;width:100%;max-width:100%;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word}.analytics-table tbody td:before{content:attr(data-label);font-weight:var(--font-weight-semibold, 600);color:var(--color-texto-principal, #333);text-align:left;margin-right:var(--spacing-sm, 12px)}.analytics-table tbody td:first-child{font-weight:var(--font-weight-semibold, 600);color:var(--color-texto-principal, #333);font-size:.9rem;margin-bottom:var(--spacing-xs, 8px)}.analytics-table tbody td:first-child:before{content:"";margin:0}}@media (max-width: 480px){.analytics-modal-content{padding:var(--spacing-sm, 12px) var(--spacing-xs, 8px);width:100vw;max-width:100vw;box-sizing:border-box}.analytics-modal-close{width:32px;height:32px;min-width:32px;min-height:32px;font-size:1.5rem}.analytics-modal-header h2{font-size:1.25rem}.chart-container{height:250px;min-height:250px;padding:var(--spacing-xs, 8px)}.analytics-table-container{padding:var(--spacing-sm, 12px) var(--spacing-xs, 8px)}.analytics-table{font-size:.75rem}.analytics-table tbody td{padding:var(--spacing-xs, 8px) 0}}@media (max-width: 768px) and (orientation: landscape){.analytics-modal-content{min-height:100vh;max-height:100vh;height:100vh;width:100vw;max-width:100vw;box-sizing:border-box}.chart-container{height:200px;min-height:200px;max-height:200px}.analytics-table-container{flex:1;min-height:0;max-height:none}}.search-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.search-input-container{position:relative;display:flex;flex-direction:column;gap:var(--spacing-xs)}.materia-input-wrapper{position:relative;width:100%}.materia-accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);border:none;cursor:pointer;font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);text-align:left;transition:all var(--transition-fast)}.materia-accordion-header:hover{background:var(--color-fondo-hover)}.materia-option-button{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;justify-content:space-between;align-items:center}.materia-option-button:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.materia-chips-container:focus-within{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.materia-input{flex:1;min-width:150px;border:none;background:transparent;padding:var(--spacing-xs) 0;outline:none;font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal)}.materia-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.student-table tbody tr{border-bottom:1px solid var(--color-borde);transition:all var(--transition-fast);cursor:pointer;position:relative;z-index:1}.student-table tbody tr:has(.student-materias-accordion-content){z-index:1000}.student-grade-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);white-space:nowrap;overflow:visible;position:relative;z-index:1000}.student-materias-accordion-header{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:transparent;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-claro-educativo);cursor:pointer;transition:all var(--transition-fast)}.student-payment-cell{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);white-space:nowrap}.student-avance-cell{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);white-space:nowrap;text-align:center}.student-avance-placeholder{color:var(--color-texto-secundario);font-style:italic}.indicator-status{display:flex;align-items:center;gap:.5rem;font-family:var(--font-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:var(--color-texto-principal)}.indicator-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.student-mobile-actions{display:none;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap}.student-mobile-link{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small);text-decoration:none;display:inline-block;color:var(--color-azul-claro-educativo);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);border:1px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.student-mobile-link:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}@media (max-width: 768px){.search-filters-grid{grid-template-columns:1fr}.search-filters-container{padding:var(--spacing-md)}}@media (max-width: 768px){.mobile-hide{display:none!important}.student-table-container{overflow-x:visible;-webkit-overflow-scrolling:touch}.student-table{width:100%;min-width:auto}.student-table tbody tr{display:block;border-bottom:1px solid var(--color-borde);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);box-shadow:var(--shadow-sm)}.student-table tbody tr:active{background:var(--color-fondo-hover);transform:scale(.98)}.student-table td{display:block;padding:0;border:none}.student-info-cell{width:100%;min-width:auto}.student-info{width:100%}.student-info-text{flex:1}.student-grade-mobile{display:block}.student-avatar{width:48px;height:48px}.student-mobile-actions{display:flex}.action-button{margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast)}.delete-button{background-color:#ef4444;color:#fff;border:none}.delete-button:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.delete-button:active{transform:translateY(0)}.search-input-container{margin-bottom:var(--spacing-sm)}}.chat-container{display:flex;flex-direction:column;height:clamp(400px,70vh,600px);width:100%;max-width:500px;margin:0 auto;background:var(--color-fondo-secundario);box-shadow:var(--shadow-xl);border-radius:var(--border-radius-xl);overflow:hidden}.chat-header{background:linear-gradient(135deg,var(--color-azul-claro-educativo) 0%,var(--color-azul-confiable) 100%);color:var(--color-texto-claro);padding:var(--spacing-md) 1.25rem;text-align:center;box-shadow:var(--shadow-md)}.chat-header h1{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-bold);color:var(--color-texto-claro);margin:0}.chat-messages{flex:1;overflow-y:auto;padding:1.25rem var(--spacing-lg);background:var(--color-fondo-principal);display:flex;flex-direction:column;gap:var(--spacing-md)}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;font-family:var(--font-secondary);color:var(--color-texto-secundario);font-style:italic}.message{display:flex;justify-content:flex-end}.message.message-system{justify-content:flex-start}.message-content{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);padding:var(--spacing-md) 1.25rem;border-radius:var(--border-radius-lg);max-width:90%;word-wrap:break-word;box-shadow:var(--shadow-md);font-family:var(--font-secondary)}.message-content.message-content-system{background:var(--color-fondo-secundario);color:var(--color-texto-principal);border:1px solid var(--color-borde);box-shadow:var(--shadow-sm)}.message-content p{margin:0;line-height:var(--line-height-relaxed);white-space:pre-wrap;word-wrap:break-word;font-family:var(--font-secondary)}.audio-message{display:flex;align-items:center}.audio-message audio{max-width:100%;outline:none}.audio-message audio::-webkit-media-controls-panel{background-color:#ffffff1a}.message-time{display:block;font-family:var(--font-secondary);font-size:var(--font-size-xs);opacity:.8;margin-top:var(--spacing-sm);text-align:right}.message-content-system .message-time{text-align:left;color:var(--color-texto-secundario)}.chat-input-container{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);background:var(--color-fondo-secundario);border-top:1px solid var(--color-borde)}.input-wrapper{display:flex;gap:var(--spacing-sm);align-items:center;background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-sm)}.chat-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-family:var(--font-secondary);line-height:1.4;resize:none;max-height:150px;min-height:40px;height:40px;overflow-y:auto;outline:none;background:#fff;color:var(--color-texto-principal);transition:border-color var(--transition-fast)}.chat-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.chat-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.input-actions{display:flex;gap:var(--spacing-sm);align-items:center}.record-button{width:45px;height:45px;border-radius:50%;border:none;background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal);user-select:none;-webkit-user-select:none;font-family:var(--font-primary)}.record-button:hover{background:var(--color-azul-claro-hover);transform:scale(1.05)}.record-button.recording{background:#e74c3c;animation:pulse 1.5s infinite}.send-button{width:45px;height:45px;padding:0;background:var(--color-verde-exito);color:var(--color-texto-claro);border:none;border-radius:50%;font-size:1.2rem;font-weight:var(--font-weight-semibold);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal);user-select:none;-webkit-user-select:none;font-family:var(--font-primary)}.send-button:hover:not(:disabled){background:var(--color-verde-exito-hover);transform:scale(1.05);box-shadow:var(--shadow-md)}.send-button:disabled{background:var(--color-texto-disabled);cursor:not-allowed;opacity:.6}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--color-fondo-principal)}.chat-messages::-webkit-scrollbar-thumb{background:var(--color-borde);border-radius:var(--border-radius-sm)}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--color-texto-secundario)}.audio-json-container{background:var(--color-fondo-hover);border-top:2px solid var(--color-azul-claro-educativo);padding:var(--spacing-md);max-height:300px;overflow-y:auto;box-shadow:var(--shadow-sm)}.audio-json-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.json-header-actions{display:flex;gap:var(--spacing-sm);align-items:center}.audio-json-header h3{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0}.close-json-button{background:#e74c3c;color:var(--color-texto-claro);border:none;border-radius:50%;width:24px;height:24px;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-normal)}.close-json-button:hover{background:#c0392b}.send-api-button{background:var(--color-verde-exito);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-small);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background var(--transition-normal);display:flex;align-items:center;gap:.25rem}.send-api-button:hover:not(:disabled){background:var(--color-verde-exito-hover)}.send-api-button:disabled{background:var(--color-texto-disabled);cursor:not-allowed;opacity:.7}.api-response{padding:.75rem;border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-sm);font-size:var(--font-size-small);font-family:var(--font-secondary);font-weight:var(--font-weight-medium)}.api-response.success{background:#27ae601a;color:var(--color-verde-exito);border:1px solid rgba(39,174,96,.2)}.api-response.error{background:#e74c3c1a;color:#e74c3c;border:1px solid rgba(231,76,60,.2)}.audio-json-content{background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-sm);padding:var(--spacing-md);margin:0;font-size:var(--font-size-small);font-family:Courier New,monospace;color:var(--color-texto-principal);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto}.audio-json-content::-webkit-scrollbar{width:8px;height:8px}.audio-json-content::-webkit-scrollbar-track{background:var(--color-fondo-principal)}.audio-json-content::-webkit-scrollbar-thumb{background:var(--color-borde);border-radius:var(--border-radius-sm)}.audio-json-content::-webkit-scrollbar-thumb:hover{background:var(--color-texto-secundario)}@media (max-width: 768px){.chat-container{height:100vh;max-width:100%}.message-content{max-width:85%}.chat-header h1{font-size:var(--font-size-h3)}.chat-input{font-size:var(--font-size-body)}.audio-json-container{max-height:200px}.audio-json-content{font-size:var(--font-size-xs);padding:.75rem}}.assistance-stats{background:var(--color-fondo-secundario, #ffffff);border-radius:var(--border-radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm);margin:0}.assistance-stats-title{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-borde)}.assistance-stats-loading,.assistance-stats-error,.assistance-stats-empty{text-align:center;padding:var(--spacing-lg) var(--spacing-md);color:var(--color-texto-secundario);font-size:var(--font-size-xs)}.assistance-stats-error{color:var(--color-risk)}.assistance-stats-summary{margin-bottom:var(--spacing-md)}.stat-item.stat-total{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--color-azul-confiable) 0%,var(--color-azul-claro-educativo) 100%);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);color:var(--color-texto-claro)}.stat-item.stat-total .stat-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-texto-claro)}.stat-item.stat-total .stat-value{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-texto-claro)}.assistance-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-sm);width:100%}.stat-card{background:var(--color-fondo-crema-academico, #f8f9fa);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);display:flex;flex-direction:column;align-items:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.stat-card.stat-presente{border-left:3px solid var(--color-verde-exito)}.stat-card.stat-tarde{border-left:3px solid var(--color-warning)}.stat-card.stat-ausente{border-left:3px solid var(--color-risk)}.stat-icon{font-size:1.25rem;margin-bottom:var(--spacing-xs)}.stat-presente .stat-icon{color:var(--color-verde-exito)}.stat-tarde .stat-icon{color:var(--color-warning)}.stat-ausente .stat-icon{color:var(--color-risk)}.stat-content{width:100%;text-align:center}.stat-count{display:block;font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.stat-label{display:block;font-size:var(--font-size-xs);color:var(--color-texto-secundario);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs)}.stat-bar{width:100%;height:6px;background:var(--color-borde);border-radius:var(--border-radius-full);overflow:hidden;margin:var(--spacing-xs) 0}.stat-bar-fill{height:100%;border-radius:var(--border-radius-full);transition:width .6s ease}.stat-bar-fill.present{background:var(--color-verde-exito)}.stat-bar-fill.late{background:var(--color-warning)}.stat-bar-fill.absent{background:var(--color-risk)}.stat-percentage{display:block;font-size:var(--font-size-xs);color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-xs)}@media (max-width: 768px){.assistance-stats{padding:var(--spacing-sm)}.assistance-stats-title{font-size:var(--font-size-xs);margin-bottom:var(--spacing-xs)}.stat-item.stat-total{padding:var(--spacing-xs) var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-xs)}.stat-item.stat-total .stat-value{font-size:1.25rem}.stat-icon{font-size:1rem}.stat-count{font-size:1.25rem}.stat-label{font-size:var(--font-size-xs)}.stat-percentage{font-size:10px}}@media (max-width: 480px){.assistance-stats{padding:var(--spacing-xs)}.assistance-stats-grid{gap:var(--spacing-xs)}.stat-card{padding:var(--spacing-xs)}.stat-icon{font-size:.875rem;margin-bottom:4px}.stat-count{font-size:1rem;margin-bottom:2px}.stat-label{font-size:10px;margin-bottom:4px}.stat-bar{height:4px;margin:4px 0}.stat-item.stat-total .stat-value{font-size:1rem}}.detail-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:var(--spacing-xl)}.panel{border-radius:var(--border-radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-borde);background:#ffffff96;margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.panel h3{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-top:0;margin-bottom:var(--spacing-md)}.chat-buho-button{width:140px!important;height:140px!important;min-width:140px!important;min-height:140px!important;border-radius:50%!important;border:2px solid var(--color-azul-claro-educativo)!important;background:linear-gradient(135deg,#3498db1a,#3498db33)!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:all var(--transition-normal)!important;box-shadow:0 2px 8px #3498db33!important;padding:0!important;overflow:hidden!important;margin:0 auto!important;flex-shrink:0!important}.chat-buho-button:hover{background:linear-gradient(135deg,#3498db33,#3498db4d);border-color:var(--color-azul-confiable);transform:scale(1.1);box-shadow:0 4px 12px #3498db4d}.chat-buho-button:active{transform:scale(.95)}.chat-buho-button-icon{width:110px!important;height:110px!important;object-fit:contain!important;transition:transform var(--transition-normal)!important;display:block!important;border-radius:50%!important}.chat-buho-panel{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;text-align:center!important;padding:var(--spacing-xl)!important}.chat-buho-header{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;width:100%!important;gap:var(--spacing-md)!important}.chat-buho-panel h3{text-align:center!important;margin:0!important;width:100%!important}.chat-buho-button:hover .chat-buho-button-icon{transform:rotate(15deg) scale(1.1)}.profile-card{border-radius:var(--border-radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-borde);background:#ffffff96;box-shadow:var(--shadow-md)}.profile-card header{display:flex;gap:var(--spacing-md);align-items:center;margin-bottom:var(--spacing-md)}.profile-card .student-avatar{width:88px;height:88px;border-radius:var(--border-radius-lg);border:3px solid var(--color-borde)}.student-name{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:0}.student-grade{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin:.15rem 0 0}.profile-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md);width:100%;box-sizing:border-box}.profile-meta>div{min-width:0;max-width:100%;overflow:visible;word-wrap:break-word;overflow-wrap:break-word}.meta-label{font-family:var(--font-primary);text-transform:uppercase;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);letter-spacing:.1em}.meta-value{font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);margin-top:.25rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%;min-width:0}.payment-status-container{margin-top:.25rem;display:block;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.payment-status-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--border-radius-full);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);white-space:normal!important;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;min-width:0;width:100%;max-width:100%;box-sizing:border-box;line-height:1.4}.payment-status-alDia{background:var(--color-verde-exito);color:var(--color-texto-claro)}.payment-status-atrasado{background:var(--color-risk);color:var(--color-texto-claro)}.payment-status-sinPagos{background:var(--color-texto-secundario);color:var(--color-texto-claro)}.payment-days-late{font-weight:var(--font-weight-bold);margin-left:var(--spacing-xs)}.resume-block{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md)}.resume-item{padding:var(--spacing-md);border-radius:var(--border-radius-md);background:var(--color-fondo-hover);border:1px solid var(--color-borde)}.hoja-de-vida-container{width:100%;margin-top:var(--spacing-xl);box-sizing:border-box;overflow-x:hidden}.hoja-de-vida-content{border-radius:var(--border-radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-borde);background:#ffffff96;box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box;overflow-x:hidden}.hoja-de-vida-content h3{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-top:0;margin-bottom:var(--spacing-md)}.observations-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-borde);width:100%;box-sizing:border-box;overflow-x:hidden}.observations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;width:100%;box-sizing:border-box;flex-wrap:wrap;gap:var(--spacing-sm)}.observations-header h3{margin:0}.observations-buttons-container{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}@media (max-width: 768px){.observations-header{flex-direction:column;align-items:flex-start}.observations-buttons-container{flex-direction:column;width:100%;gap:var(--spacing-xs)}.observations-buttons-container .ghost-button{width:100%;box-sizing:border-box;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.fortune-area{display:flex;flex-direction:column;gap:var(--spacing-sm)}.fortune-button{align-self:flex-start;background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);padding:.7rem 1.4rem;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-normal)}.fortune-button:hover{background:var(--color-azul-claro-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.fortune-message{font-family:var(--font-secondary);padding:var(--spacing-md) 1.25rem;border-radius:var(--border-radius-md);background:#3498db1a;color:var(--color-texto-principal);border:1px solid rgba(52,152,219,.2)}.observations-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.observations-list li{font-family:var(--font-secondary);padding:.9rem var(--spacing-md);border-radius:var(--border-radius-md);background:var(--color-fondo-hover);border:1px solid var(--color-borde);color:var(--color-texto-principal)}.observations-list-detailed{display:flex;flex-direction:column;gap:var(--spacing-md)}.observation-item-detailed{background:var(--color-fondo-hover);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-md);transition:all var(--transition-fast)}.observation-item-detailed:hover{box-shadow:var(--shadow-sm)}.observation-item-header-detailed{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-sm)}.observation-header-left{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-width:200px}.observation-header-right{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.observation-date-detailed{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold)}.observation-reporter-detailed{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);font-style:italic}.observation-importance-detailed,.observation-type-detailed{padding:.25rem .6rem;border-radius:var(--border-radius-full);font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize;white-space:nowrap}.observation-type-detailed.type-regular{background:#3498db33;color:var(--color-azul-claro-educativo)}.observation-type-detailed.type-resumen{background:#9b59b633;color:#9b59b6}.observation-type-detailed.type-retiro{background:#e74c3c33;color:#e74c3c}.observation-type-detailed.type-inconformidad_padre{background:#f39c1233;color:#f39c12}.observation-importance-detailed.importance-baja{background:#3498db33;color:var(--color-azul-claro-educativo)}.observation-importance-detailed.importance-media{background:#fbbf2433;color:#f59e0b}.observation-importance-detailed.importance-alta{background:#ef444433;color:var(--color-risk)}.observation-text-detailed{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0;line-height:1.6}.observation-subject-detailed{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-confiable);margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#3498db1a;border-radius:var(--border-radius-sm);border-left:3px solid var(--color-azul-claro-educativo)}.observation-summary-detailed{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);margin-top:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-fondo-hover);border-radius:var(--border-radius-sm);font-style:italic}.observation-summary-detailed strong{font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);font-style:normal}.loading-text,.no-observations-text-detailed{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);text-align:center;padding:var(--spacing-lg);font-style:italic}@media (max-width: 900px){.detail-layout{grid-template-columns:1fr}}.student-detail-shell{position:relative;width:100%;box-sizing:border-box;overflow-x:hidden}.chat-bubble-overlay{position:fixed;bottom:24px;right:24px;width:min(85vw,480px);z-index:50}.chat-bubble{background:#2c3e50f2;border-radius:var(--border-radius-xl);padding:var(--spacing-md);box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.1)}.chat-bubble-header{display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-md) var(--spacing-sm);color:var(--color-texto-claro);font-family:var(--font-primary)}.chat-bubble .ghost-button{background:#ffffff1a;color:var(--color-texto-claro);border-color:#fff3}.chat-bubble .ghost-button:hover{background:#fff3}.chat-bubble .chat-container{height:520px;max-width:none;border-radius:var(--border-radius-lg)}.chat-bubble .chat-header{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.chat-bubble .chat-input-container{border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg)}@media (max-width: 640px){.chat-bubble-overlay{bottom:12px;right:12px;width:calc(100vw - 24px)}.chat-bubble .chat-container{height:60vh}}.modal-content{background:#fff;border-radius:var(--border-radius-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-borde)}.modal-header h3{margin:0;font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-texto-secundario);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:background-color var(--transition-fast)}.modal-close:hover{background-color:var(--color-fondo-hover)}.modal-body{padding:var(--spacing-md);flex:1;overflow-y:auto;min-height:0}.modal-student-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background-color:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-md);font-size:var(--font-size-small);font-family:var(--font-secondary)}.modal-student-info strong{color:var(--color-azul-confiable)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);font-family:var(--font-primary);color:var(--color-texto-principal)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-family:var(--font-secondary);transition:border-color var(--transition-fast);box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.monto-option-chip{border-radius:var(--border-radius-full);padding:.6rem 1.4rem;border:1px solid var(--color-borde);color:var(--color-azul-claro-educativo);background:transparent;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);transition:all var(--transition-fast);cursor:pointer}.monto-option-chip:hover{border-color:var(--color-azul-claro-educativo);background:var(--color-fondo-hover)}.monto-option-chip-selected{border-radius:var(--border-radius-full);padding:.6rem 1.4rem;border:1px solid var(--color-azul-claro-educativo);color:var(--color-texto-claro);background:var(--color-azul-claro-educativo);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);transition:all var(--transition-fast);cursor:pointer}.monto-option-chip-selected:hover{border-color:var(--color-azul-confiable);background:var(--color-azul-confiable);color:var(--color-texto-claro)}.edit-student-modal{max-width:90vw;width:100%;background-color:#fff!important;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png)!important;background-size:cover,40%!important;background-position:center,center!important;background-repeat:no-repeat,no-repeat!important}.edit-student-modal .form-grid{display:block;width:100%}.edit-student-modal .form-grid .form-group{width:100%;margin-bottom:var(--spacing-md)}.edit-student-modal .form-section-basic-info .form-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md)}@media (max-width: 1200px){.edit-student-modal .form-section-basic-info .form-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.edit-student-modal .form-section-basic-info .form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.edit-student-modal .form-section-basic-info .form-grid{grid-template-columns:1fr}}.edit-student-modal .modal-header{background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.edit-student-modal .modal-body{background-color:transparent}.edit-student-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.edit-student-form .form-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.edit-student-form .form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:#ffffff96;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all var(--transition-fast);outline:none;box-sizing:border-box}.edit-student-form .form-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.edit-student-form .form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:#ffffff96;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);cursor:pointer;outline:none;box-sizing:border-box}.edit-student-form .form-select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.horarios-list-edit{display:flex;flex-direction:column;gap:var(--spacing-sm)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-borde)}.edit-student-modal .modal-actions{background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--spacing-md);margin:0;margin-top:var(--spacing-lg);border-radius:var(--border-radius-md)}.primary-button{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.primary-button:hover:not(:disabled){background-color:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.modal-content{max-width:100%;margin:var(--spacing-sm);max-height:95vh;display:flex;flex-direction:column}.modal-overlay{padding:var(--spacing-sm);align-items:flex-start;overflow-y:auto;padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.modal-body{flex:1;overflow-y:auto;min-height:0}.modal-footer{flex-shrink:0;padding:var(--spacing-md);border-top:1px solid var(--color-borde);display:flex;gap:var(--spacing-sm);justify-content:flex-end;background:#fff;position:sticky;bottom:0}}.observation-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.observation-form-title{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0 0 var(--spacing-md) 0}.importance-selector{display:flex;flex-direction:column;gap:var(--spacing-sm)}.importance-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal)}.importance-option{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:#fff;color:var(--color-texto-principal);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.importance-option:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.importance-option.selected{background:var(--color-azul-claro-educativo);color:#fff;border-color:var(--color-azul-claro-educativo)}.importance-option.importance-baja.selected{background:#3498dbcc}.importance-option.importance-media.selected{background:#fbbf24cc}.importance-option.importance-alta.selected{background:#ef4444cc}.observation-cancel-edit-button{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:transparent;color:var(--color-texto-secundario);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start}.observation-cancel-edit-button:hover{background:var(--color-fondo-hover);border-color:var(--color-texto-secundario)}.modal-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-texto-secundario);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:background-color var(--transition-fast)}.modal-close-button:hover{background-color:var(--color-fondo-hover)}.modal-footer{padding:var(--spacing-md);border-top:1px solid var(--color-borde);display:flex;gap:var(--spacing-sm);justify-content:flex-end;background:#fff}.modal-cancel-button{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:transparent;color:var(--color-texto-principal);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.modal-cancel-button:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.modal-save-button{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--border-radius-md);background:var(--color-verde-exito);color:#fff;font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.modal-save-button:hover:not(:disabled){background:var(--color-verde-exito-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.modal-save-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.modal-content{max-height:98vh;margin:var(--spacing-xs)}.modal-overlay{padding:var(--spacing-xs);padding-top:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.importance-options{flex-direction:column}.importance-option{width:100%}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.guardians-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:.25rem}.guardian-name-button{background:transparent;border:1px solid var(--color-azul-claro-educativo);color:var(--color-azul-claro-educativo);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:fit-content;min-width:120px}.guardian-name-button:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.guardian-name-button:active{transform:translateY(0)}.guardian-modal-content{max-width:600px}.guardian-details{display:flex;flex-direction:column;gap:var(--spacing-lg)}.guardian-photo{display:flex;justify-content:center;align-items:center;margin-bottom:var(--spacing-md)}.guardian-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--color-borde);box-shadow:var(--shadow-md)}.guardian-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.guardian-info-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde)}.guardian-info-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);text-transform:uppercase;letter-spacing:.05em}.guardian-info-value{font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);margin:0}.guardian-phone-link{color:var(--color-azul-claro-educativo);text-decoration:none;transition:color var(--transition-fast)}.guardian-phone-link:hover{color:var(--color-azul-confiable);text-decoration:underline}@media (max-width: 768px){.guardian-info-grid{grid-template-columns:1fr}.guardian-avatar{width:100px;height:100px}}.asignaturas-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:.25rem}.asignatura-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border-radius:var(--border-radius-full);font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);white-space:nowrap}.form-section-basic-info{width:100%;margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-lg);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm)}.form-section-basic-info .form-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-md);width:100%}.form-section-basic-info .form-group{width:100%;margin-bottom:var(--spacing-md)}@media (max-width: 1200px){.form-section-basic-info .form-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.form-section-basic-info .form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.form-section-basic-info .form-grid{grid-template-columns:1fr}}.niveles-materia-group{width:100%;margin-top:var(--spacing-md);margin-bottom:var(--spacing-md)}.materias-niveles-container{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.materia-nivel-item{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);margin-bottom:var(--spacing-md);width:100%;box-sizing:border-box}.materia-nivel-header{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.materia-nivel-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);align-items:start}.materia-nivel-col{display:flex;flex-direction:column;gap:var(--spacing-xs)}.nivel-buttons-container{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.nivel-button{min-width:40px;height:36px;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-borde);border-radius:var(--border-radius-sm);background:#fff;color:var(--color-texto-principal);font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.nivel-button:hover:not(:disabled){background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo);transform:translateY(-1px)}.nivel-button.selected{background:var(--color-azul-claro-educativo);color:#fff;border-color:var(--color-azul-claro-educativo)}.nivel-selected-indicator{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);margin-top:var(--spacing-xs)}.materia-objetivo-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}@media (max-width: 768px){.materia-nivel-header,.materia-nivel-content{grid-template-columns:1fr}}.horarios-header-accordion{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.horarios-header-accordion h3{margin:0}.horarios-toggle-button{background:transparent;border:1px solid var(--color-borde);border-radius:var(--border-radius-sm);padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--color-azul-confiable);font-size:var(--font-size-body);min-width:32px;height:32px}.horarios-toggle-button:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.horarios-toggle-button:focus{outline:2px solid var(--color-azul-claro-educativo);outline-offset:2px}.horarios-toggle-icon{display:inline-block;transition:transform var(--transition-fast);font-size:var(--font-size-small);line-height:1}.horarios-section-info{margin-top:var(--spacing-md);animation:fadeIn var(--transition-normal) ease-out}.horario-semanal{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.horario-dia-item-display{display:flex;flex-direction:row;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-fondo-hover);border-radius:var(--border-radius-sm);border:1px solid var(--color-borde)}.horario-dia-header-display{min-width:70px;flex-shrink:0}.horario-dia-header-display h5{font-family:var(--font-primary);font-size:.75rem;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0}.horario-items-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-xs);flex:1}.horario-item-display{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-xs);padding:.25rem var(--spacing-xs);background:var(--color-fondo-secundario);border-radius:var(--border-radius-sm);border:1px solid var(--color-borde);min-width:fit-content}.horario-time{font-family:var(--font-primary);font-size:.7rem;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);white-space:nowrap}.horario-materias-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.horario-materia{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-xs);font-family:var(--font-secondary);font-size:.7rem;color:var(--color-texto-principal)}.horario-nivel{font-family:var(--font-secondary);font-size:.65rem;color:var(--color-texto-secundario);background:var(--color-fondo-hover);padding:.1rem .25rem;border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium)}@media (max-width: 768px){.horario-dia-item-display{flex-direction:column}.horario-dia-header-display{min-width:auto;width:100%}.horario-items-list{width:100%}}.pagos-panel{margin-top:var(--spacing-lg)}.pagos-panel h3{margin-bottom:var(--spacing-md)}.primary-button-small{background-color:var(--color-verde-exito);color:var(--color-texto-claro);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);border:none;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-primary);width:100%;margin-bottom:var(--spacing-md)}.primary-button-small:hover{background-color:var(--color-verde-exito-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.primary-button-small:active{transform:translateY(0)}.edit-student-modal .acudiente-fields{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);flex:1;width:100%}@media (max-width: 1024px){.edit-student-modal .acudiente-fields{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.edit-student-modal .acudiente-fields{grid-template-columns:1fr}}.asistencia-panel{grid-column:1 / -1;padding:0;background:transparent;border:none;box-shadow:none}.asistencia-panel .assistance-stats{margin:0}.new-student-form{margin-top:var(--spacing-xl)}.form-select{width:100%;padding:var(--spacing-md) var(--spacing-lg);padding-right:2.5rem;border:2px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-texto-principal);background:var(--color-fondo-secundario);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%233498db' d='M7 10L2 5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-size:14px;transition:all var(--transition-fast);outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;box-shadow:var(--shadow-sm);line-height:1.5}.form-select:active,.form-select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db26,var(--shadow-md)}.form-select:not([value=""]):not(:disabled),.form-select.has-value:not(:disabled){color:var(--color-verde-exito)!important;font-weight:var(--font-weight-semibold)}.form-select:not([value=""]):not(:disabled):focus,.form-select.has-value:not(:disabled):focus{color:var(--color-verde-exito)!important}.form-select:not([value=""]):not(:disabled):hover,.form-select.has-value:not(:disabled):hover{color:var(--color-verde-exito)!important}.form-select:hover:not(:disabled){border-color:var(--color-azul-claro-educativo);background:var(--color-fondo-secundario);box-shadow:var(--shadow-md);transform:translateY(-1px)}.form-select:focus{border-color:var(--color-azul-claro-educativo);background:var(--color-fondo-secundario);box-shadow:0 0 0 3px #3498db26,var(--shadow-md);transform:translateY(-1px)}.form-select:disabled{background:var(--color-fondo-hover);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%23bdc3c7' d='M7 10L2 5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-size:14px;color:var(--color-texto-disabled);cursor:not-allowed;border-color:var(--color-borde);box-shadow:none;opacity:.6}.form-select option{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);color:var(--color-texto-principal);font-weight:var(--font-weight-regular);font-family:var(--font-secondary);font-size:var(--font-size-body);line-height:1.6;min-height:2.5rem;display:flex;align-items:center;cursor:pointer;transition:all var(--transition-fast)}.form-select option[value=""]{color:var(--color-texto-secundario);font-style:italic;background:var(--color-fondo-hover)}.form-select option:not([value=""]):not(:disabled){background:var(--color-fondo-secundario);color:var(--color-texto-principal);padding-left:var(--spacing-md)}.form-select option:hover:not(:disabled):not([value=""]){background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);font-weight:var(--font-weight-semibold);padding-left:calc(var(--spacing-md) + 4px)}.form-select option:checked:not([value=""]){background:var(--color-verde-exito);color:var(--color-texto-claro);font-weight:var(--font-weight-semibold);padding-left:calc(var(--spacing-md) + 4px)}.form-select option:disabled{background:var(--color-fondo-hover);color:var(--color-texto-disabled);cursor:not-allowed;opacity:.5;font-style:italic}.form-select::-ms-expand{display:none}.form-select::-webkit-scrollbar{width:8px}.form-select::-webkit-scrollbar-track{background:var(--color-fondo-hover);border-radius:var(--border-radius-sm)}.form-select::-webkit-scrollbar-thumb{background:var(--color-azul-claro-educativo);border-radius:var(--border-radius-sm)}.form-select::-webkit-scrollbar-thumb:hover{background:var(--color-azul-confiable)}.document-id-container{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-sm);width:100%}.document-type-select,.document-number-input{min-width:0}.form-group-autocomplete,.autocomplete-container{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--spacing-xs);background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:1000;max-height:200px;overflow-y:auto;animation:fadeInDown .2s ease-out}.autocomplete-option{width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;border:none;background:transparent;color:var(--color-texto-principal);font-family:var(--font-secondary);font-size:var(--font-size-body);cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--color-borde)}.autocomplete-option:last-child{border-bottom:none}.autocomplete-option:hover{background:var(--color-fondo-hover);color:var(--color-azul-claro-educativo);padding-left:calc(var(--spacing-md) + 4px)}.autocomplete-option:active{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}.autocomplete-dropdown::-webkit-scrollbar{width:6px}.autocomplete-dropdown::-webkit-scrollbar-track{background:var(--color-fondo-hover)}.autocomplete-dropdown::-webkit-scrollbar-thumb{background:var(--color-borde);border-radius:var(--border-radius-full)}.autocomplete-dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-texto-secundario)}.form-section{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde)}.form-section-acudientes{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);border-radius:var(--border-radius-lg);width:100%;max-width:100%;display:block}.form-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.add-horario-button{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.add-horario-button:hover:not(:disabled){background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.add-horario-button:disabled{opacity:.6;cursor:not-allowed}.horarios-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.horarios-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-md);margin-top:var(--spacing-md)}.horario-dia-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.horario-dia-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.horario-dia-label{font-family:var(--font-primary);font-size:.875rem;font-weight:600;color:var(--color-azul-confiable);margin:0}.copy-horario-button{width:24px;height:24px;padding:0;background:var(--color-azul-claro);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-sm);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0;opacity:.8}.copy-horario-button:hover:not(:disabled){background:var(--color-azul-confiable);opacity:1;transform:scale(1.1)}.copy-horario-button:disabled{opacity:.4;cursor:not-allowed;background:var(--color-verde-exito)}.horario-dia-item .autocomplete-container{width:100%;position:relative}.horario-dia-item .form-input{font-size:.8125rem;padding:var(--spacing-xs) var(--spacing-sm)}.horario-dia-item .form-label{font-size:.75rem;margin-bottom:var(--spacing-xs)}.acudientes-list{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-top:var(--spacing-md);width:100%}.acudiente-item{padding:var(--spacing-md);background:#ffffff96;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);transition:all var(--transition-fast);width:100%;max-width:100%}.acudiente-item:hover{border-color:var(--color-azul-claro-educativo);box-shadow:0 2px 8px #3498db1a}.acudiente-item-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-borde)}.acudiente-number{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.acudiente-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.acudiente-photo-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);flex-shrink:0;min-width:120px}.acudiente-photo-preview{position:relative;width:100px;height:120px;border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.acudiente-photo-preview:hover{border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-md)}.acudiente-photo-wrapper{position:relative;width:100%;height:100%}.acudiente-photo{width:100%;height:100%;object-fit:cover;display:block}.acudiente-photo-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;background:var(--color-risk);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-bold);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);z-index:10}.acudiente-photo-remove:hover{background:#dc2626;transform:scale(1.1);box-shadow:var(--shadow-md)}.acudiente-photo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--color-texto-secundario)}.acudiente-photo-placeholder svg{opacity:.5}.acudiente-photo-input{display:none}.acudiente-photo-label{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-sm);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center;display:inline-block;min-width:90px}.acudiente-photo-label:hover:not(:disabled){background:var(--color-azul-confiable);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.acudiente-photo-label:active{transform:translateY(0)}.acudiente-fields{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);flex:1;width:100%}@media (max-width: 1024px){.acudiente-fields{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.acudiente-fields{grid-template-columns:1fr}}.acudiente-item .form-group{width:100%;min-width:0}.add-acudiente-button{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-verde-exito);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;gap:var(--spacing-xs)}.add-acudiente-button:hover:not(:disabled){background:var(--color-verde-claro-estudio);transform:translateY(-1px);box-shadow:var(--shadow-md)}.add-acudiente-button:disabled{opacity:.6;cursor:not-allowed}.remove-acudiente-button{width:28px;height:28px;padding:0;background:var(--color-risk);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-sm);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.remove-acudiente-button:hover:not(:disabled){background:var(--color-risk-hover);transform:scale(1.1)}.remove-acudiente-button:disabled{opacity:.6;cursor:not-allowed}.form-actions .btn-primary{min-width:160px}.header-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.student-photo-upload{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin:0 var(--spacing-lg)}.photo-preview-container{position:relative;width:150px;height:180px;border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.photo-preview-container:hover{border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-md)}.photo-preview-wrapper{position:relative;width:100%;height:100%}.photo-preview{width:100%;height:100%;object-fit:cover;display:block}.photo-remove-button{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);width:28px;height:28px;background:var(--color-risk);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:var(--font-weight-bold);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);z-index:10}.photo-remove-button:hover{background:#dc2626;transform:scale(1.1);box-shadow:var(--shadow-md)}.photo-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;height:100%;color:var(--color-texto-secundario)}.photo-placeholder svg{opacity:.5}.photo-placeholder-text{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-texto-secundario)}.photo-upload-label{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);text-align:center;display:inline-block;min-width:120px}.photo-upload-label:hover:not(:disabled){background:var(--color-azul-confiable);transform:translateY(-1px);box-shadow:var(--shadow-md)}.photo-upload-label:active{transform:translateY(0)}.voice-input-button{width:48px;height:48px;padding:0;background:var(--color-verde-exito);border:none;border-radius:var(--border-radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-md);overflow:hidden}.voice-input-button:hover{background:var(--color-verde-claro-estudio);transform:scale(1.1);box-shadow:var(--shadow-lg)}.voice-button-logo{width:32px;height:32px;object-fit:contain}.voice-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.voice-modal{background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;overflow:hidden}.voice-modal-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-borde);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--color-azul-claro-educativo) 0%,var(--color-azul-confiable) 100%);color:var(--color-texto-claro);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.voice-modal-header h3{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);margin:0;color:var(--color-texto-claro)}.voice-modal-close{width:32px;height:32px;padding:0;background:transparent;border:none;color:var(--color-texto-claro);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.voice-modal-close:hover{background:#fff3}.voice-modal-content{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);overflow-y:auto;flex:1;min-height:0}.voice-status{text-align:center;padding:var(--spacing-md)}.voice-buho-instructions{padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);margin-bottom:var(--spacing-md)}.buho-says{display:flex;align-items:flex-start;gap:var(--spacing-md)}.buho-icon-small{width:48px;height:48px;object-fit:contain;flex-shrink:0;animation:float 3s ease-in-out infinite}.buho-message{flex:1;font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal)}.buho-waiting{display:flex;flex-direction:column;gap:var(--spacing-sm)}.buho-instruction-text{font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0 0 var(--spacing-sm) 0}.buho-examples{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.buho-example-item{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-fondo-secundario);border-left:3px solid var(--color-verde-exito);border-radius:var(--border-radius-sm);font-size:var(--font-size-small);color:var(--color-texto-principal)}.buho-example-item strong{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.buho-active-field{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-verde-exito);color:var(--color-texto-claro);border-radius:var(--border-radius-md);animation:fieldDetected .5s ease-out}.buho-field-name{font-weight:var(--font-weight-bold);font-size:var(--font-size-h3)}.buho-field-value{font-size:var(--font-size-small);opacity:.9}.buho-next-hint{font-size:var(--font-size-xs);color:var(--color-azul-claro-educativo);margin-top:var(--spacing-xs);font-style:italic}.voice-preview-data{padding:var(--spacing-md);background:var(--color-fondo-principal);border:1px solid var(--color-verde-exito);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md)}.voice-preview-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-verde-exito);margin-bottom:var(--spacing-sm)}.voice-preview-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.voice-preview-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-fondo-secundario);border-radius:var(--border-radius-sm);font-size:var(--font-size-small)}.preview-field-name{font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);min-width:120px}.preview-field-value{color:var(--color-texto-principal);flex:1}.voice-buho-response{padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-azul-claro-educativo) 0%,var(--color-azul-confiable) 100%);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--color-azul-confiable);animation:slideUp .3s ease-out}.buho-response-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.buho-response-title{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-claro)}.buho-response-text{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-claro);line-height:1.6;padding:var(--spacing-sm);background:#ffffff1a;border-radius:var(--border-radius-sm)}.voice-processing{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);margin-bottom:var(--spacing-md);font-family:var(--font-primary);font-size:var(--font-size-body);color:var(--color-azul-confiable);font-weight:var(--font-weight-medium)}@keyframes fieldDetected{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.voice-fields-detected{padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde)}.voice-fields-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-sm)}.voice-fields-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.field-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-verde-exito);color:var(--color-texto-claro);border-radius:var(--border-radius-sm);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);animation:fadeIn .3s ease-out}.field-highlighted{border-color:var(--color-verde-exito)!important;box-shadow:0 0 0 3px #27ae6033!important;animation:fieldPulse 2s ease-in-out infinite}@keyframes fieldPulse{0%,to{box-shadow:0 0 0 3px #27ae6033}50%{box-shadow:0 0 0 3px #27ae6066}}.voice-listening{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);color:var(--color-verde-exito);font-family:var(--font-primary);font-weight:var(--font-weight-semibold)}.voice-pulse{width:12px;height:12px;background:var(--color-verde-exito);border-radius:var(--border-radius-full);animation:pulse 1.5s ease-in-out infinite}.voice-stopped{color:var(--color-texto-secundario);font-family:var(--font-secondary)}.voice-transcript{min-height:120px;max-height:200px;flex-shrink:0}.voice-transcript-textarea{width:100%;min-height:150px;max-height:300px;padding:var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-principal);resize:vertical;line-height:var(--line-height-normal)}.voice-transcript-textarea:focus{outline:none;border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.voice-modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-borde);background:var(--color-fondo-secundario);flex-wrap:wrap;flex-shrink:0}.btn-start,.btn-stop,.btn-apply{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.btn-start{background:var(--color-verde-exito);color:var(--color-texto-claro)}.btn-start:hover{background:var(--color-verde-claro-estudio)}.btn-stop{background:var(--color-risk);color:var(--color-texto-claro)}.btn-stop:hover{background:var(--color-risk-hover)}.btn-fill-form{background:var(--color-verde-exito);color:var(--color-texto-claro);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.btn-fill-form:hover:not(:disabled){background:var(--color-verde-claro-estudio);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-fill-form:disabled{opacity:.5;cursor:not-allowed}.btn-apply{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}.btn-apply:hover:not(:disabled){background:var(--color-azul-confiable)}.btn-apply:disabled{opacity:.5;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@media (max-width: 768px){.student-photo-upload{margin:var(--spacing-md) 0;order:-1}.photo-preview-container{width:120px;height:150px}.form-grid{grid-template-columns:1fr}.form-section-header{flex-direction:column;align-items:flex-start}.horarios-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.horario-dia-label{font-size:var(--font-size-body)}.horario-dia-item .form-input{font-size:var(--font-size-body);padding:var(--spacing-sm) var(--spacing-md)}.horario-dia-item .form-label{font-size:var(--font-size-body)}.copy-horario-button{width:32px;height:32px;font-size:1rem}.acudientes-list{grid-template-columns:1fr;gap:var(--spacing-md)}.acudiente-content{flex-direction:column}.acudiente-fields{grid-template-columns:1fr;width:100%}.document-id-container{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn-primary,.form-actions .ghost-button{width:100%}}@media (min-width: 769px) and (max-width: 1024px){.horarios-grid{grid-template-columns:repeat(3,1fr)}.acudientes-list{flex-direction:column}.acudiente-item{width:100%;max-width:100%}.acudiente-fields{grid-template-columns:repeat(2,1fr)}.header-actions{flex-direction:column;width:100%}.header-actions .ghost-button,.header-actions .btn-primary{width:100%}}.materia-accordion{width:100%;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);overflow:hidden;transition:all var(--transition-fast);scroll-margin:0;scroll-padding:0}.materia-accordion.field-highlighted{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.materia-accordion-header:focus{outline:none;box-shadow:none}.materia-accordion-header:focus-visible{outline:none;box-shadow:none}.materia-accordion-header:active{outline:none}.materia-accordion-content{padding:var(--spacing-xs);display:flex;flex-direction:column;gap:var(--spacing-xs);background:var(--color-fondo-secundario);border-top:1px solid var(--color-borde);animation:slideDown .2s ease-out;scroll-margin-top:0;scroll-padding-top:0;scroll-margin-bottom:0;scroll-padding-bottom:0}.materia-nivel-item .form-group-autocomplete,.materia-nivel-item .autocomplete-container{position:relative;z-index:10}.materia-nivel-item .autocomplete-dropdown{z-index:1001;box-shadow:0 4px 12px #00000026;border:2px solid var(--color-azul-claro-educativo)}.materia-nivel-item .autocomplete-container{position:relative;z-index:10;isolation:isolate}.nivel-button.selected{background:var(--color-azul-claro-educativo);border-color:var(--color-azul-claro-educativo);color:var(--color-texto-claro);font-weight:var(--font-weight-bold);box-shadow:0 2px 8px #3498db4d}.nivel-selected-indicator{margin-top:var(--spacing-xs);font-size:var(--font-size-small);color:var(--color-texto-secundario);font-family:var(--font-secondary)}.nivel-selected-indicator strong{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.new-student-observations-wrapper{position:relative}.new-student-observations-wrapper .form-textarea{padding-bottom:50px}.new-student-observations-wrapper .observation-audio-controls{position:absolute;bottom:12px;right:12px;margin:0;width:auto}.error-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-lg)}.error-modal-content{background:var(--color-fondo-principal);border-radius:var(--border-radius-lg);box-shadow:0 4px 20px #00000026;max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.error-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde);background:var(--color-fondo-secundario)}.error-modal-title{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-risk);margin:0}.error-modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-texto-secundario);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.error-modal-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.error-modal-body{padding:var(--spacing-lg);flex:1;overflow-y:auto}.error-modal-body p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0 0 var(--spacing-md) 0;line-height:1.6}.error-modal-main-message{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-risk);margin:0 0 var(--spacing-md) 0;line-height:1.6;padding:var(--spacing-md);background:#e74c3c1a;border-left:4px solid var(--color-risk);border-radius:var(--border-radius-sm)}.error-modal-hint{font-size:var(--font-size-small);color:var(--color-texto-secundario);font-style:italic;margin-top:var(--spacing-md)}.error-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-borde);background:var(--color-fondo-secundario)}.error-modal-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-azul-confiable);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.error-modal-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:0 2px 8px #3498db4d}.error-modal-button:active{transform:translateY(0)}.materia-horario-group{margin-top:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,#ffffff 0%,var(--color-fondo-crema-academico) 100%);border-radius:var(--border-radius-lg);border:2px solid var(--color-borde);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.materia-horario-group:hover{border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-md)}.materia-horario-group .form-label{font-size:var(--font-size-body);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);display:flex;align-items:center;gap:var(--spacing-xs)}.materia-horario-group .form-label:before{content:"🕐";font-size:1.125rem}.horario-selector-container{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.horario-dia-selector{position:relative;margin-bottom:var(--spacing-md)}.horario-dia-selector .form-label{font-size:var(--font-size-small);margin-bottom:var(--spacing-xs);display:block;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);font-family:var(--font-primary)}.horario-dia-selector .form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-right:2.5rem;font-size:var(--font-size-body);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%233498db' d='M7 10L2 5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);line-height:1.5}.horario-dia-selector .form-select:hover:not(:disabled){border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-md);transform:translateY(-1px)}.horario-dia-selector .form-select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db26,var(--shadow-md);outline:none}.horario-dia-selector .form-select:not([value=""]):not(:disabled){color:var(--color-verde-exito);font-weight:var(--font-weight-semibold);border-color:var(--color-verde-exito)}.horario-hora-selector{position:relative;animation:slideDown .3s ease-out}.horario-hora-selector .form-label{font-size:var(--font-size-small);margin-bottom:var(--spacing-xs);display:block;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);font-family:var(--font-primary)}.horario-hora-selector .form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-right:2.5rem;font-size:var(--font-size-body);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%233498db' d='M7 10L2 5h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);line-height:1.5}.horario-hora-selector .form-select:hover:not(:disabled){border-color:var(--color-azul-claro-educativo);box-shadow:var(--shadow-md);transform:translateY(-1px)}.horario-hora-selector .form-select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db26,var(--shadow-md);outline:none}.horario-hora-selector .form-select:not([value=""]):not(:disabled){color:var(--color-verde-exito);font-weight:var(--font-weight-semibold);border-color:var(--color-verde-exito)}.horario-info-message{font-size:var(--font-size-small);color:var(--color-texto-secundario);font-style:italic;padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);display:flex;align-items:center;gap:var(--spacing-xs);animation:fadeIn .3s ease-out}.horario-info-message:before{content:"ℹ️";font-size:1rem;flex-shrink:0}.horario-error-message{font-size:var(--font-size-small);color:var(--color-risk);padding:var(--spacing-md);background:#ef44441a;border-radius:var(--border-radius-md);border:1px solid rgba(239,68,68,.3);display:flex;align-items:center;gap:var(--spacing-xs);animation:fadeIn .3s ease-out}.horario-error-message:before{content:"⚠️";font-size:1rem;flex-shrink:0}.horario-selected-indicator{margin-top:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,#27ae601a,#2ecc711a);border-radius:var(--border-radius-md);border:2px solid var(--color-verde-exito);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-verde-exito);display:flex;align-items:center;gap:var(--spacing-xs);animation:fadeIn .3s ease-out;box-shadow:var(--shadow-sm)}.horario-selected-indicator:before{content:"✓";font-size:1.25rem;font-weight:var(--font-weight-bold);color:var(--color-verde-exito);flex-shrink:0}.horario-selected-indicator strong{color:var(--color-azul-confiable);font-weight:var(--font-weight-bold)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px);max-height:0}to{opacity:1;transform:translateY(0);max-height:500px}}@media (max-width: 768px){.materia-horario-group{padding:var(--spacing-md)}.horario-selector-container{gap:var(--spacing-sm)}.horario-dia-selector .form-select,.horario-hora-selector .form-select{font-size:var(--font-size-small);padding:var(--spacing-xs) var(--spacing-sm)}}.search-input-container{position:relative;margin-bottom:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs);z-index:1000}.current-time-info{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);margin-top:var(--spacing-sm);font-style:italic}.no-students-message{text-align:center;padding:var(--spacing-xl);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px dashed var(--color-borde);margin-top:var(--spacing-lg)}.no-students-message p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin-bottom:var(--spacing-md)}.clear-search-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.clear-search-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.clear-search-button:active{transform:translateY(0)}.attendance-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.attendance-card{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:center;justify-content:space-between;padding:var(--spacing-md) 1.25rem;border-radius:var(--border-radius-lg);border:1px solid var(--color-borde);background:#ffffff96;transition:all var(--transition-fast)}.attendance-card:hover{box-shadow:var(--shadow-md)}.attendance-info{display:flex;gap:var(--spacing-sm);align-items:center}.attendance-info .student-avatar{width:48px;height:48px;border-radius:var(--border-radius-md);border:2px solid var(--color-borde)}.attendance-info strong{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.attendance-info .student-grade{font-family:var(--font-secondary);margin:0;color:var(--color-texto-secundario);font-size:var(--font-size-small)}.attendance-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.status-chip{border-radius:var(--border-radius-full);padding:.4rem 1rem;border:1px solid var(--color-borde);background:var(--color-fondo-hover);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:var(--color-texto-principal);min-width:90px;text-align:center;cursor:pointer;transition:all var(--transition-fast)}.status-chip:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.status-chip.active{color:var(--color-texto-claro);box-shadow:var(--shadow-md)}.summary-row{margin-top:var(--spacing-xl);display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;align-items:center}.summary-pill{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.summary-pill span{font-family:var(--font-secondary);border-radius:var(--border-radius-full);padding:.4rem 1rem;background:var(--color-fondo-hover);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:var(--color-texto-principal)}.schedule-accordion{border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);background:#ffffff96;overflow:hidden;margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.schedule-accordion-header{width:100%;padding:var(--spacing-lg);background:var(--color-fondo-secundario);border:none;text-align:left;cursor:default}.schedule-accordion-title{display:flex;align-items:center;gap:var(--spacing-md)}.schedule-icon{font-size:1rem;color:var(--color-azul-claro-educativo);transition:transform var(--transition-fast);display:inline-block;width:20px;text-align:center}.schedule-accordion-header:hover .schedule-icon{color:var(--color-azul-confiable)}.schedule-title{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0}.schedule-accordion-content{padding:var(--spacing-lg);border-top:1px solid var(--color-borde)}.time-blocks-buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md)}.time-block-button{padding:var(--spacing-md);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);cursor:pointer;transition:all var(--transition-fast);text-align:left;display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:80px}.time-block-button:hover{border-color:var(--color-azul-claro-educativo);background:var(--color-fondo-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.time-block-button.selected{border-color:var(--color-azul-claro-educativo);background:#3498db1a;box-shadow:0 0 0 3px #3498db1a}.time-block-button.current-block{border-color:var(--color-azul-claro-educativo);background:#3498db26;box-shadow:0 0 0 3px #3498db33}.time-block-button.current-block.selected{border-color:var(--color-azul-claro-educativo);background:#3498db33;box-shadow:0 0 0 4px #3498db40}.time-block-button-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.time-block-button-time{font-family:var(--font-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-body);color:var(--color-azul-confiable)}.time-block-button.current-block .time-block-button-time{color:var(--color-azul-claro-educativo)}.time-block-button-count{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario)}.current-block-badge-small{font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-texto-claro);background:var(--color-azul-claro-educativo);padding:.2rem .5rem;border-radius:var(--border-radius-full);text-transform:uppercase;letter-spacing:.05em;align-self:flex-start;box-shadow:0 2px 4px #3498db4d}.time-block-button-summary{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;margin-top:var(--spacing-xs)}.time-block-mini-badge{font-family:var(--font-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:.15rem .4rem;border-radius:var(--border-radius-full);min-width:20px;text-align:center}.time-block-mini-badge.present-mini{background:#27ae6033;color:var(--color-verde-exito)}.time-block-mini-badge.late-mini{background:#fbbf2433;color:var(--color-warning)}.time-block-mini-badge.absent-mini{background:#ef444433;color:var(--color-risk)}.current-time-block-outside{margin-bottom:var(--spacing-lg);border:2px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-lg);background:#3498db0d;padding:var(--spacing-lg);box-shadow:0 0 0 3px #3498db1a}.current-time-block-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid rgba(52,152,219,.2)}.current-time-block-header h3{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-claro-educativo);margin:0}.selected-block-students{margin-top:var(--spacing-lg)}.selected-block-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde)}.selected-block-header h3{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0}.current-block-badge{font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-texto-claro);background:var(--color-azul-claro-educativo);padding:.25rem .6rem;border-radius:var(--border-radius-full);text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #3498db4d}.save-button{background:var(--color-verde-exito);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);padding:.7rem 1.4rem;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-normal)}.save-button:hover{background:var(--color-verde-exito-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.save-button:active{transform:translateY(0)}.saved-hint{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-verde-exito);margin-top:var(--spacing-xs)}.observation-button{background:var(--color-fondo-hover)!important;border-color:var(--color-azul-claro-educativo)!important}.observation-button.has-observation{background:#3498db1a!important;border-color:var(--color-azul-claro-educativo)!important;position:relative}.observation-button.has-observation:after{content:"";position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--color-azul-claro-educativo);border-radius:50%}.observation-button:hover{background:#3498db26!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.observation-modal-content{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde)}.modal-header h3{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);color:var(--color-azul-confiable);margin:0}.modal-close-button{background:none;border:none;font-size:2rem;color:var(--color-texto-secundario);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.modal-body{padding:var(--spacing-lg);flex:1;overflow-y:auto}.observation-textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);resize:vertical;min-height:120px;outline:none;transition:all var(--transition-fast)}.observation-audio-controls{margin-top:var(--spacing-sm);display:flex;gap:var(--spacing-sm);align-items:center}.observation-record-button:hover{background:var(--color-azul-claro-hover);transform:scale(1.05)}.observation-textarea:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.observation-textarea::placeholder{color:var(--color-texto-secundario)}.observation-input-wrapper{position:relative}.observation-input-wrapper .observation-textarea{padding-bottom:50px}.observation-input-wrapper .observation-audio-controls{position:absolute;bottom:12px;right:12px;margin:0;width:auto}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-borde)}.modal-cancel-button,.modal-save-button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);cursor:pointer;transition:all var(--transition-normal)}.modal-cancel-button{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.modal-cancel-button:hover{background:var(--color-borde)}.modal-save-button{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);box-shadow:var(--shadow-md)}.modal-save-button:hover{background:var(--color-azul-claro-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.modal-save-button:active{transform:translateY(0)}.modal-save-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.observations-list{margin-bottom:var(--spacing-lg)}.observations-list-title{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);color:var(--color-azul-confiable);margin-bottom:var(--spacing-md)}.observation-item{background:var(--color-fondo-hover);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.observation-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-sm)}.observation-date{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario)}.observation-importance{padding:.2rem .6rem;border-radius:var(--border-radius-full);font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize}.importance-baja{background:#3498db33;color:var(--color-azul-claro-educativo)}.importance-media{background:#fbbf2433;color:#f59e0b}.importance-alta{background:#ef444433;color:var(--color-risk)}.observation-item-actions{display:flex;gap:var(--spacing-xs)}.observation-edit-button,.observation-delete-button{padding:.3rem .6rem;border:none;border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.observation-edit-button{background:#3498db1a;color:var(--color-azul-claro-educativo)}.observation-edit-button:hover:not(:disabled){background:#3498db33}.observation-edit-button:disabled{opacity:.5;cursor:not-allowed}.observation-delete-button{background:#ef44441a;color:var(--color-risk)}.observation-delete-button:hover{background:#ef444433}.observation-text{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0;line-height:1.6}.observation-summary{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);margin-top:var(--spacing-sm);margin-bottom:0;font-style:italic}.no-observations-text,.loading-text{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);text-align:center;padding:var(--spacing-lg);font-style:italic}.observation-form{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:2px solid var(--color-borde)}.observation-form-title{font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body);color:var(--color-azul-confiable);margin-bottom:var(--spacing-md)}.observation-cancel-edit-button{margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-fondo-hover);color:var(--color-texto-principal);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-small);cursor:pointer;transition:all var(--transition-fast)}.observation-cancel-edit-button:hover{background:var(--color-borde)}.importance-selector{margin-bottom:var(--spacing-md)}.importance-label{display:block;font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:var(--color-azul-confiable);margin-bottom:var(--spacing-sm)}.importance-options{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.importance-option{flex:1;min-width:80px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);cursor:pointer;transition:all var(--transition-fast);text-transform:capitalize;background:var(--color-fondo-secundario);color:var(--color-texto-principal)}.importance-option.importance-baja{border-color:#3498db4d}.importance-option.importance-baja:hover{border-color:var(--color-azul-claro-educativo);background:#3498db1a}.importance-option.importance-baja.selected{background:#3498db33;border-color:var(--color-azul-claro-educativo);color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.importance-option.importance-media{border-color:#fbbf244d}.importance-option.importance-media:hover{border-color:#f59e0b;background:#fbbf241a}.importance-option.importance-media.selected{background:#fbbf2433;border-color:#f59e0b;color:#f59e0b;box-shadow:0 0 0 3px #fbbf241a}.importance-option.importance-alta{border-color:#ef44444d}.importance-option.importance-alta:hover{border-color:var(--color-risk);background:#ef44441a}.importance-option.importance-alta.selected{background:#ef444433;border-color:var(--color-risk);color:var(--color-risk);box-shadow:0 0 0 3px #ef44441a}.schedule-selector{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#ffffff96;border-radius:var(--border-radius-lg);border:1px solid var(--color-borde)}.schedule-day-selector{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-borde)}.day-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.day-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-principal);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal)}.day-button:hover{border-color:var(--color-azul-claro-educativo);background:#3498db0d;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.day-button.selected{border-color:var(--color-azul-claro-educativo);background:#3498db26;color:var(--color-azul-confiable);box-shadow:0 0 0 3px #3498db33}.no-schedules-message{padding:var(--spacing-md);text-align:center;background:var(--color-fondo-hover);border-radius:var(--border-radius-md);color:var(--color-texto-secundario);margin-top:var(--spacing-md);font-family:var(--font-secondary);font-size:var(--font-size-body)}.schedule-label{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal)}.schedule-buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md)}.schedule-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-fondo-principal);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-normal);text-align:center;min-height:100px}.schedule-button:hover{border-color:var(--color-azul-claro-educativo);background:#3498db0d;transform:translateY(-2px);box-shadow:0 4px 12px #3498db26}.schedule-button.selected{border-color:var(--color-azul-claro-educativo);background:#3498db1a;box-shadow:0 0 0 3px #3498db33}.schedule-button-time{font-size:var(--font-size-body);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable)}.schedule-button-count{font-size:var(--font-size-small);color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.loading-message{padding:var(--spacing-lg);text-align:center;background:#3498db0d;border-radius:var(--border-radius-md);border-left:4px solid var(--color-azul-claro-educativo);margin-bottom:var(--spacing-lg)}.loading-message p{color:var(--color-azul-claro-educativo);margin:0;font-weight:var(--font-weight-medium)}@media (max-width: 768px){.schedule-buttons{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.schedule-button{min-height:80px;padding:var(--spacing-sm)}.schedule-button-time{font-size:var(--font-size-small)}.schedule-button-count{font-size:var(--font-size-xs)}.time-blocks-buttons{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.time-block-button{min-height:70px;padding:var(--spacing-sm)}.time-block-button-time{font-size:var(--font-size-small)}.time-block-button-count{font-size:var(--font-size-xs)}.schedule-accordion-content{padding:var(--spacing-md)}}.search-filters-container{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde)}.search-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.search-input-container{position:relative;display:flex;flex-direction:column;gap:var(--spacing-xs);z-index:1000}.search-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);transition:all var(--transition-fast);outline:none}.search-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.search-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--spacing-xs);background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:9999;max-height:200px;overflow-y:auto;animation:fadeInDown .2s ease-out}.suggestion-item{width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;border:none;background:transparent;color:var(--color-texto-principal);font-family:var(--font-secondary);font-size:var(--font-size-body);cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--color-borde)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--color-fondo-hover);color:var(--color-azul-claro-educativo);padding-left:calc(var(--spacing-md) + 4px)}.suggestion-item:active{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.clear-filters-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);align-self:flex-start}.clear-filters-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.clear-filters-button:active{transform:translateY(0)}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-track{background:var(--color-fondo-hover)}.suggestions-dropdown::-webkit-scrollbar-thumb{background:var(--color-borde);border-radius:var(--border-radius-full)}.suggestions-dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-texto-secundario)}.results-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0}.results-count{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0}.results-filtered{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.no-results{text-align:center;padding:var(--spacing-xl);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px dashed var(--color-borde);margin:var(--spacing-lg) 0}.no-results p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin-bottom:var(--spacing-md)}.student-table-container{overflow-x:auto;border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);background:#ffffff96}.student-table{width:100%;border-collapse:collapse;font-family:var(--font-secondary)}.student-table thead{background:var(--color-fondo-hover);border-bottom:2px solid var(--color-borde)}.student-table th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:uppercase;letter-spacing:.05em}.student-table tbody tr{border-bottom:1px solid var(--color-borde);transition:all var(--transition-fast);cursor:pointer}.student-table tbody tr:hover{background:var(--color-fondo-hover)}.student-table tbody tr:last-child{border-bottom:none}.student-table td{padding:var(--spacing-md) var(--spacing-lg);vertical-align:middle}.student-info-cell{min-width:200px}.student-info{display:flex;align-items:center;gap:var(--spacing-md)}.student-info-text{display:flex;flex-direction:column;gap:.25rem}.student-grade-mobile{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);display:none}.payment-status-mobile{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-xs);display:none;background:transparent}.payment-status-mobile-alDia{color:#27ae60;background:transparent}.payment-status-mobile-atrasado{color:#ef4444;background:transparent}.payment-status-mobile-sinPagos{color:#6c757d;background:transparent}.student-avatar{width:40px;height:40px;border-radius:var(--border-radius-md);object-fit:cover;border:2px solid var(--color-borde);flex-shrink:0}.student-table .student-name{font-family:var(--font-primary)!important;font-size:.7rem!important;font-weight:var(--font-weight-semibold)!important;color:var(--color-azul-confiable)!important;margin:0!important}.payment-date-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);white-space:nowrap}.payment-amount-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-verde-exito);font-weight:var(--font-weight-semibold);white-space:nowrap}.payment-last-cell{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);white-space:nowrap}.indicator-cell{white-space:nowrap}.status-indicator-button{display:inline-block;padding:.5rem 1rem;border:none;border-radius:6px;font-family:var(--font-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:#fff;cursor:default;transition:opacity .2s ease;white-space:nowrap}.status-indicator-button:hover{opacity:.9}.indicator-status{display:flex;align-items:center;gap:.5rem;font-family:var(--font-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);background:transparent}.payment-status-alDia{color:#27ae60;background:transparent}.payment-status-atrasado{color:#ef4444;background:transparent}.payment-status-sinPagos{color:#6c757d;background:transparent}.payment-days-late{color:var(--color-risk);font-weight:var(--font-weight-bold)}.action-cell{white-space:nowrap}.action-cell .primary-link{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small);text-decoration:none;display:inline-block}@media (max-width: 768px){.search-filters-grid{grid-template-columns:1fr}.search-filters-container{padding:var(--spacing-md)}.mobile-hide{display:none!important}.student-table-container{overflow-x:visible;-webkit-overflow-scrolling:touch}.student-table{width:100%;min-width:auto}.student-table tbody tr{display:block;border-bottom:1px solid var(--color-borde);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);box-shadow:var(--shadow-sm)}.student-table tbody tr:active{background:var(--color-fondo-hover);transform:scale(.98)}.student-table td{display:block;padding:0;border:none}.student-info-cell{width:100%;min-width:auto}.student-info{width:100%}.student-info-text{flex:1}.student-grade-mobile,.payment-status-mobile{display:block}.student-avatar{width:48px;height:48px}.search-input-container{margin-bottom:var(--spacing-sm)}}.action-buttons{display:flex;gap:var(--spacing-xs);align-items:center}.primary-button-small{padding:var(--spacing-xs) var(--spacing-sm);background-color:transparent;color:var(--color-primary-dark, #0056b3);border:1px solid var(--color-primary-dark, #0056b3);border-radius:24px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.primary-button-small:hover{background-color:var(--color-primary-dark, #0056b3);color:#fff}.primary-button-small:active{transform:scale(.98)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background-color:#fff!important;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png)!important;background-size:cover,30%!important;background-position:center,center!important;background-repeat:no-repeat,no-repeat!important;border-radius:var(--radius-md);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border, #e0e0e0);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.monthly-summary-modal .modal-header{background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary, #666);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .2s}.modal-close:hover{background-color:var(--color-bg-secondary, #f5f5f5)}.modal-body{padding:var(--spacing-md);background-color:transparent}.modal-student-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background-color:var(--color-bg-secondary, #f5f5f5);border-radius:var(--radius-sm);font-size:.875rem}.modal-student-info strong{color:var(--color-primary)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;font-size:.875rem;color:var(--color-text-primary, #333)}.form-group input,.form-group select{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border, #ddd);border-radius:var(--radius-sm);font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007bff1a}.monto-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.monto-option-chip{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-primary-dark, #0056b3);border-radius:24px;background-color:transparent;font-size:1rem;font-weight:500;color:var(--color-primary-dark, #0056b3);cursor:pointer;transition:all .2s}.monto-option-chip:hover{background-color:#fff;color:var(--color-primary-dark, #0056b3);border-color:var(--color-primary-dark, #0056b3)}.monto-option-chip:active{transform:scale(.98)}.monto-option-chip-selected{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-primary-dark, #0056b3);border-radius:24px;background-color:var(--color-primary-dark, #0056b3);font-size:1rem;font-weight:500;color:#fff;cursor:pointer;transition:all .2s}.monto-option-chip-selected:hover{background-color:var(--color-primary-dark, #0056b3);color:#fff;border-color:var(--color-primary-dark, #0056b3)}.monto-option-chip-selected:active{transform:scale(.98)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border, #e0e0e0)}.modal-actions button:disabled{opacity:.6;cursor:not-allowed}.primary-button{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-dark, #0056b3);color:#fff;border:2px solid var(--color-primary-dark, #0056b3);border-radius:24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.primary-button:hover:not(:disabled){background-color:#fff;color:var(--color-primary-dark, #0056b3);border-color:var(--color-primary-dark, #0056b3)}.primary-button:active:not(:disabled){transform:scale(.98)}.modal-actions .ghost-button{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-dark, #0056b3);color:#fff;border:2px solid var(--color-primary-dark, #0056b3);border-radius:24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.modal-actions .ghost-button:hover:not(:disabled){background-color:#fff;color:var(--color-primary-dark, #0056b3);border-color:var(--color-primary-dark, #0056b3)}.modal-actions .ghost-button:active:not(:disabled){transform:scale(.98)}.header-buttons{display:flex;gap:var(--spacing-sm);align-items:center}.secondary-button{padding:var(--spacing-sm) var(--spacing-md);background-color:#fff;color:var(--color-primary-dark, #0056b3);border:2px solid var(--color-primary-dark, #0056b3);border-radius:24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.secondary-button:hover{background-color:var(--color-primary-dark, #0056b3);color:#fff}.secondary-button:active{transform:scale(.98)}.monthly-summary-modal{max-width:95vw!important;width:95vw!important;max-height:90vh;background-color:#fff;background-image:linear-gradient(#ffffff4d,#ffffff4d),url(/imagenesApp/BuhoLogo-vec.png);background-size:cover,40%;background-position:center,center;background-repeat:no-repeat,no-repeat}.modal-content.monthly-summary-modal{max-width:95vw!important;width:95vw!important}.monthly-summary-modal .modal-body{max-height:calc(90vh - 100px);overflow-y:auto;background-color:transparent}.loading-state,.error-state{text-align:center;padding:var(--spacing-xl)}.error-state{color:var(--color-risk, #ef4444)}.summary-header{text-align:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-borde);background:#ffffff96;border-radius:var(--border-radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-header h4{margin:0 0 var(--spacing-xs) 0;font-size:1.5rem;color:var(--color-azul-confiable)}.summary-period{margin:0;font-size:.875rem;color:var(--color-texto-secundario)}.summary-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.stat-card{background:#ffffff96;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-xs);display:flex;flex-direction:column;gap:2px;text-align:center;transition:transform .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-label{font-size:.55rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold);line-height:1.2}.stat-value{font-size:.9rem;font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);line-height:1.2}.stat-value-success{color:var(--color-verde-exito, #27AE60)}.stat-value-warning{color:var(--color-warning, #f59e0b)}.stat-value-danger{color:var(--color-risk, #ef4444)}.payment-stats-chart-container{margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:#ffffff96;border-radius:var(--border-radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center}.payment-chart-wrapper{width:100%;max-width:300px;height:250px;margin:0 auto}.payment-methods-breakdown{margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:#ffffff96;border-radius:var(--border-radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.payment-methods-breakdown h5{margin:0 0 var(--spacing-md) 0;font-size:1rem;color:var(--color-azul-confiable)}.payment-methods-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-sm)}.payment-method-card{background:#ffffff96;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-sm);display:flex;flex-direction:column;gap:.5rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.payment-method-header{display:flex;flex-direction:column;gap:4px}.payment-method-name{font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);font-size:.875rem}.payment-method-count{font-size:.75rem;color:var(--color-texto-secundario)}.payment-method-total{font-size:1rem;font-weight:var(--font-weight-bold);color:var(--color-verde-exito, #27AE60)}.bank-accordion{margin-top:.5rem;border-top:1px solid #e5e7eb;padding-top:.5rem}.bank-accordion-toggle{width:100%;padding:.5rem .75rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;text-align:left;font-size:.875rem;color:#374151;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-family:var(--font-primary)}.bank-accordion-toggle:hover{background:#e5e7eb}.bank-accordion-toggle.expanded{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.bank-breakdown-list{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.bank-breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#f9fafb;border-radius:4px;font-size:.875rem;gap:.5rem}.bank-breakdown-all{background:#dbeafe;border:1px solid #3b82f6;font-weight:600;color:#1e40af}.bank-name{flex:1;font-weight:500;color:var(--color-texto-principal)}.bank-amount{font-weight:600;color:#059669;min-width:100px;text-align:right}.bank-count{color:#6b7280;font-size:.8125rem;min-width:80px;text-align:right}.students-list{margin-top:var(--spacing-lg)}.students-list h5{margin:0 0 var(--spacing-md) 0;font-size:1rem;color:var(--color-azul-confiable)}.students-filters{margin-bottom:var(--spacing-md)}.filter-tabs{display:flex;gap:var(--spacing-xs);border-bottom:2px solid var(--color-borde)}.filter-tab{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:.875rem;color:var(--color-texto-secundario);transition:all .2s}.filter-tab:hover{color:var(--color-azul-claro-educativo)}.filter-tab.active{color:var(--color-azul-confiable);border-bottom-color:var(--color-azul-confiable);font-weight:var(--font-weight-semibold)}.students-table-wrapper{overflow-x:auto;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:#ffffff96;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-table{width:100%;border-collapse:collapse;font-size:.875rem}.summary-table thead{background:#ffffff96;border-bottom:2px solid var(--color-borde);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.summary-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.summary-table tbody tr{border-bottom:1px solid var(--color-borde);transition:background-color .2s}.summary-table tbody tr:hover{background:#ffffff96;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.summary-table tbody tr:last-child{border-bottom:none}.summary-table td{padding:var(--spacing-sm) var(--spacing-md);vertical-align:middle}.row-pagado{background:#27ae600d}.row-atrasado{background:#ef44440d}.row-pendiente{background:#f59e0b0d}.student-name-cell{font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.amount-cell{font-weight:var(--font-weight-semibold);color:var(--color-verde-exito, #27AE60)}.badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:var(--font-weight-semibold);white-space:nowrap}.badge-success{background:#27ae601a;color:var(--color-verde-exito, #27AE60)}.badge-warning{background:#f59e0b1a;color:var(--color-warning, #f59e0b)}.badge-danger{background:#ef44441a;color:var(--color-risk, #ef4444)}@media (max-width: 768px){.modal-content{max-width:100%;margin:var(--spacing-sm)}.action-buttons{flex-direction:column;width:100%}.primary-button-small{width:100%}.header-buttons{flex-direction:column;width:100%;gap:var(--spacing-xs)}.header-buttons button{width:100%}.monthly-summary-modal{max-width:100%;margin:var(--spacing-xs)}.summary-stats{grid-template-columns:repeat(2,1fr)}.payment-methods-grid{grid-template-columns:1fr}.students-table-wrapper{overflow-x:auto}.summary-table{font-size:.75rem}.summary-table th,.summary-table td{padding:var(--spacing-xs) var(--spacing-sm)}.stat-value{font-size:1.25rem}}.antiguos-view-card{background:var(--color-fondo-secundario);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);margin:var(--spacing-lg) 0;position:relative;overflow:visible}.antiguos-view-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(/imagenesApp/BuhoLogo-vec.png);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.05;z-index:0;pointer-events:none}.antiguos-view-card>*{position:relative;z-index:1}.antiguos-view-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-borde)}.antiguos-view-eyebrow{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-xs)}.antiguos-view-title{font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-sm)}.antiguos-search-container{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde);display:flex;gap:var(--spacing-md);align-items:flex-end;flex-wrap:wrap}.antiguos-search-input-wrapper{flex:1;min-width:250px;display:flex;flex-direction:column;gap:var(--spacing-xs);position:relative}.antiguos-search-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.antiguos-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);transition:all var(--transition-fast);outline:none}.antiguos-search-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.antiguos-search-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.antiguos-suggestions-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background-color:#fff;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);margin-top:.25rem;box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto}.antiguos-suggestion-item{width:100%;padding:.75rem 1rem;text-align:left;border:none;background-color:transparent;cursor:pointer;font-size:var(--font-size-body);font-family:var(--font-secondary);color:var(--color-texto-principal);transition:background-color var(--transition-fast);border-bottom:1px solid var(--color-borde)}.antiguos-suggestion-item:last-child{border-bottom:none}.antiguos-suggestion-item:hover{background-color:var(--color-fondo-hover)}.antiguos-clear-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.antiguos-clear-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.antiguos-clear-button:active{transform:translateY(0)}.antiguos-results-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) 0}.antiguos-results-count{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0}.antiguos-results-filtered{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.antiguos-no-results{text-align:center;padding:var(--spacing-xl);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px dashed var(--color-borde);margin:var(--spacing-lg) 0}.antiguos-no-results p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin-bottom:var(--spacing-md)}.antiguos-table-container{overflow-x:auto;border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);background:#ffffff96}.antiguos-table{width:100%;border-collapse:collapse;font-family:var(--font-secondary)}.antiguos-table thead{background:var(--color-fondo-hover);border-bottom:2px solid var(--color-borde)}.antiguos-table th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:uppercase;letter-spacing:.05em}.antiguos-table tbody tr{border-bottom:1px solid var(--color-borde);transition:all var(--transition-fast);cursor:pointer}.antiguos-table tbody tr:hover{background:var(--color-fondo-hover)}.antiguos-table tbody tr:last-child{border-bottom:none}.antiguos-table td{padding:var(--spacing-md) var(--spacing-lg);vertical-align:middle}.antiguos-student-info-cell{min-width:250px}.antiguos-student-info{display:flex;align-items:center;gap:var(--spacing-md)}.antiguos-student-info-text{display:flex;flex-direction:column;gap:.25rem}.antiguos-student-avatar{width:40px;height:40px;border-radius:var(--border-radius-md);object-fit:cover;border:2px solid var(--color-borde);flex-shrink:0}.antiguos-student-name{font-family:var(--font-primary);font-size:.8rem;font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.antiguos-student-grade-mobile,.antiguos-student-status{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);display:none}.antiguos-grade-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);white-space:nowrap}.antiguos-payment-cell,.antiguos-attendance-cell{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);white-space:nowrap}.antiguos-loading-text{font-style:italic;color:var(--color-texto-secundario)}.antiguos-indicator-cell{white-space:nowrap}.antiguos-status-indicator-button{display:inline-block;padding:.5rem 1rem;border:none;border-radius:6px;font-family:var(--font-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);color:#fff;cursor:default;transition:opacity .2s ease;white-space:nowrap}.antiguos-status-indicator-button:hover{opacity:.9}.antiguos-action-cell{white-space:nowrap}.antiguos-primary-link{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small);text-decoration:none;display:inline-block;color:var(--color-azul-claro-educativo);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);border:1px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.antiguos-primary-link:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.antiguos-primary-link:active{transform:translateY(0)}.antiguos-action-button,.antiguos-reactivate-button{display:inline-block!important;visibility:visible!important;opacity:1!important}.antiguos-reactivate-button:hover{background-color:#059669!important;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.antiguos-reactivate-button:active{transform:translateY(0)}.antiguos-mobile-actions{display:none;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap}.antiguos-mobile-link{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small);text-decoration:none;display:inline-block;color:var(--color-azul-claro-educativo);font-family:var(--font-primary);font-weight:var(--font-weight-semibold);border:1px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.antiguos-mobile-link:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.antiguos-load-payments-button{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px dashed var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:#2c3e50;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.antiguos-load-payments-button:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo);border-style:solid;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.antiguos-load-payments-button:active{transform:translateY(0)}@media (max-width: 768px){.antiguos-view-card{padding:var(--spacing-md);margin:var(--spacing-md) 0}.antiguos-search-container{padding:var(--spacing-md);flex-direction:column;align-items:stretch}.antiguos-search-input-wrapper{min-width:100%}.mobile-hide{display:none!important}.antiguos-table-container{overflow-x:visible;-webkit-overflow-scrolling:touch}.antiguos-table{width:100%;min-width:auto}.antiguos-table tbody tr{display:block;border-bottom:1px solid var(--color-borde);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);box-shadow:var(--shadow-sm)}.antiguos-table tbody tr:active{background:var(--color-fondo-hover);transform:scale(.98)}.antiguos-table td{display:block;padding:0;border:none}.antiguos-student-info-cell{width:100%;min-width:auto}.antiguos-student-info{width:100%}.antiguos-student-info-text{flex:1}.antiguos-student-grade-mobile,.antiguos-student-status{display:block}.antiguos-student-avatar{width:48px;height:48px}.antiguos-mobile-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap}.antiguos-action-button{margin-left:0;margin-top:var(--spacing-xs)}.antiguos-reactivate-button{margin-top:var(--spacing-xs)}}.futuros-view-card{background:var(--color-fondo-secundario);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);margin:var(--spacing-lg) 0;position:relative;overflow:visible}.futuros-view-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(/imagenesApp/BuhoLogo-vec.png);background-size:contain;background-position:center;background-repeat:no-repeat;opacity:.05;z-index:0;pointer-events:none}.futuros-view-card>*{position:relative;z-index:1}.total-students-display{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-hover);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);width:fit-content}.total-students-number{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-azul-confiable)}.total-students-label{font-size:var(--font-size-body);color:var(--color-texto-secundario)}.futuros-view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-borde);flex-wrap:wrap;gap:var(--spacing-md)}.futuros-view-eyebrow{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-xs)}.futuros-view-title{font-family:var(--font-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.futuros-add-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;box-shadow:var(--shadow-sm)}.futuros-add-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.futuros-add-button:active{transform:translateY(0)}.alphabet-filter-container{position:sticky;top:0;z-index:10;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde);box-shadow:0 2px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.alphabet-filter-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center;align-items:center}.alphabet-filter-button{min-width:40px;height:40px;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);background:var(--color-fondo-hover);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.alphabet-filter-button:hover{background:var(--color-fondo-hover);border-color:var(--color-primario);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.alphabet-filter-button.active{background:var(--color-verde-exito);color:var(--color-texto-claro);border-color:var(--color-verde-exito);box-shadow:var(--shadow-md)}.alphabet-filter-button.active:hover{background:var(--color-verde-exito-hover);border-color:var(--color-verde-exito-hover);transform:translateY(-2px)}.futuros-search-container{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde);display:flex;gap:var(--spacing-md);align-items:flex-end;flex-wrap:wrap}.futuros-search-input-wrapper{flex:1;min-width:250px;display:flex;flex-direction:column;gap:var(--spacing-xs);position:relative}.futuros-search-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.futuros-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);transition:all var(--transition-fast);outline:none}.futuros-search-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.futuros-search-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.futuros-suggestions-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background-color:#fff;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);margin-top:.25rem;box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto}.futuros-suggestion-item{width:100%;padding:.75rem 1rem;text-align:left;border:none;background-color:transparent;cursor:pointer;font-size:var(--font-size-body);font-family:var(--font-secondary);color:var(--color-texto-principal);transition:background-color var(--transition-fast);border-bottom:1px solid var(--color-borde)}.futuros-suggestion-item:last-child{border-bottom:none}.futuros-suggestion-item:hover{background-color:var(--color-fondo-hover)}.futuros-clear-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.futuros-clear-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.futuros-clear-button:active{transform:translateY(0)}.futuros-results-info{margin-bottom:var(--spacing-lg);padding:var(--spacing-sm) 0}.futuros-results-count{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);margin:0}.futuros-results-filtered{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.futuros-no-results{text-align:center;padding:var(--spacing-xl);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px dashed var(--color-borde);margin:var(--spacing-lg) 0}.futuros-no-results p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-secundario);margin-bottom:var(--spacing-md)}.futuros-no-results-hint{font-size:var(--font-size-small);color:var(--color-texto-secundario);font-style:italic}.futuros-table-container{overflow-x:auto;border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);background:#ffffff96}.futuros-table{width:100%;border-collapse:collapse;font-family:var(--font-secondary)}.futuros-table thead{background:var(--color-fondo-hover);border-bottom:2px solid var(--color-borde)}.futuros-table th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:uppercase;letter-spacing:.05em}.futuros-table th:nth-child(1){width:20%}.futuros-table th:nth-child(2){width:15%}.futuros-table th:nth-child(3){width:15%}.futuros-table th:nth-child(4){width:15%}.futuros-table th:nth-child(5){width:15%}.futuros-table th:nth-child(6){width:10%}.futuros-table tbody tr{border-bottom:1px solid var(--color-borde);transition:all var(--transition-fast);cursor:pointer;position:relative;z-index:1}.futuros-table tbody tr:has(.student-materias-accordion-content){z-index:1000}.futuros-table tbody tr:hover{background:var(--color-fondo-hover)}.futuros-table tbody tr:last-child{border-bottom:none}.futuros-table td{padding:var(--spacing-md) var(--spacing-lg);vertical-align:middle}.futuros-table td:nth-child(2){overflow:visible;position:relative;z-index:1000}.futuros-student-info-cell{min-width:200px;overflow:visible}.futuros-student-info-cell .futuros-student-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.futuros-student-info{display:flex;align-items:center;gap:var(--spacing-md)}.futuros-student-info-text{display:flex;flex-direction:column;gap:.25rem}.futuros-student-avatar{width:40px;height:40px;border-radius:var(--border-radius-md);object-fit:cover;border:2px solid var(--color-borde);flex-shrink:0}.futuros-table .futuros-student-name{font-family:var(--font-primary)!important;font-size:.7rem!important;font-weight:var(--font-weight-semibold)!important;color:var(--color-azul-confiable)!important;margin:0!important}.futuros-student-badge{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);display:none}.futuros-grade-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);white-space:nowrap}.futuros-data-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal)}.futuros-data-cell:hover:after{content:attr(data-full-text);position:absolute;left:0;top:100%;z-index:1000;background:var(--color-azul-confiable);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-small);white-space:normal;max-width:300px;box-shadow:var(--shadow-lg);margin-top:4px;pointer-events:none;opacity:0;animation:fadeInTooltip .2s ease-out forwards}@keyframes fadeInTooltip{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.futuros-contact-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;position:relative}.futuros-contact-cell:hover:after{content:attr(data-full-text);position:absolute;left:0;top:100%;z-index:1000;background:var(--color-azul-confiable);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-small);white-space:normal;max-width:300px;box-shadow:var(--shadow-lg);margin-top:4px;pointer-events:none;opacity:0;animation:fadeInTooltip .2s ease-out forwards}.futuros-next-contact-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);white-space:nowrap}.futuros-next-contact-badge.overdue{background:#ef44441a;border:1px solid var(--color-risk);color:var(--color-risk)}.futuros-next-contact-badge.today{background:#f59e0b1a;border:1px solid var(--color-warning);color:var(--color-warning)}.futuros-next-contact-badge.tomorrow{background:#3498db1a;border:1px solid var(--color-azul-claro-educativo);color:var(--color-azul-claro-educativo)}.futuros-next-contact-badge.soon{background:#10b9811a;border:1px solid var(--color-verdeExito);color:var(--color-verdeExito)}.futuros-next-contact-badge.later,.futuros-next-contact-badge.no-scheduled,.futuros-next-contact-badge.invalid{background:var(--color-fondo-hover);border:1px solid var(--color-borde);color:var(--color-texto-secundario)}.futuros-phone-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;position:relative}.futuros-phone-cell:hover:after{content:attr(data-full-text);position:absolute;left:0;top:100%;z-index:1000;background:var(--color-azul-confiable);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-small);white-space:normal;max-width:300px;box-shadow:var(--shadow-lg);margin-top:4px;pointer-events:none;opacity:0;animation:fadeInTooltip .2s ease-out forwards}.futuros-phone-link{color:var(--color-azul-claro-educativo);text-decoration:none;font-weight:var(--font-weight-medium);font-family:var(--font-secondary);font-size:var(--font-size-body);transition:all var(--transition-fast)}.futuros-phone-link:hover{text-decoration:underline;color:var(--color-azul-claro-hover)}.futuros-action-cell{white-space:nowrap}.futuros-action-button{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);text-decoration:none;display:inline-block}.futuros-action-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.futuros-action-button:active{transform:translateY(0)}.futuros-mobile-label{display:none;font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);margin-right:var(--spacing-xs)}@media (max-width: 768px){.futuros-view-card{padding:var(--spacing-md);margin:var(--spacing-md) 0}.futuros-view-header{flex-direction:column;align-items:stretch}.futuros-add-button{width:100%}.futuros-search-container{padding:var(--spacing-md);flex-direction:column;align-items:stretch}.futuros-search-input-wrapper{min-width:100%}.mobile-hide{display:none!important}.futuros-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.futuros-table{width:100%;min-width:auto}.futuros-table tbody tr{display:block;border-bottom:1px solid var(--color-borde);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);box-shadow:var(--shadow-sm)}.futuros-table tbody tr:active{background:var(--color-fondo-hover);transform:scale(.98)}.futuros-table td{display:block;padding:var(--spacing-xs) 0;border:none}.futuros-student-info-cell{width:100%;min-width:auto;padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-borde)}.futuros-student-info{width:100%}.futuros-student-info-text{flex:1}.futuros-student-badge{display:inline-block;padding:.125rem .5rem;background:#3498db1a;border-radius:var(--border-radius-full)}.futuros-student-avatar{width:48px;height:48px}.futuros-mobile-label{display:inline}.futuros-data-cell,.futuros-contact-cell,.futuros-phone-cell,.futuros-action-cell{display:block;white-space:normal;padding:var(--spacing-xs) 0}.futuros-action-button{width:100%;margin-top:var(--spacing-sm)}}@media (max-width: 480px){.futuros-student-avatar{width:40px;height:40px}.futuros-student-name{font-size:var(--font-size-small)}}.student-materias-accordion{position:relative;display:inline-block;z-index:1000}.student-materias-accordion-header{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:transparent;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-claro-educativo);cursor:pointer;transition:all var(--transition-fast);border:none}.student-materias-accordion-header:hover{background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.student-materias-accordion-icon{font-size:.75rem;color:var(--color-texto-secundario);transition:transform var(--transition-fast)}.student-materias-accordion-content{position:absolute;top:100%;left:0;margin-top:.25rem;padding:var(--spacing-xs);background:#fff;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);box-shadow:0 4px 12px #00000026;z-index:1001;min-width:200px;max-width:300px;max-height:300px;overflow-y:auto;white-space:normal;animation:slideDown .2s ease-out;isolation:isolate;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:300px;transform:translateY(0)}}.student-materia-item{padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-principal);border-bottom:1px solid var(--color-borde);background:#fff;position:relative;z-index:1002}.student-materia-item:last-child{border-bottom:none}.student-materia-item:hover{background:var(--color-fondo-hover)}.student-photo-upload{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.photo-preview-container{width:120px;height:120px;border-radius:var(--border-radius-lg);overflow:hidden;border:2px solid var(--color-borde);background:var(--color-fondo-hover);position:relative}.photo-preview-wrapper{width:100%;height:100%;position:relative}.photo-preview{width:100%;height:100%;object-fit:cover}.photo-remove-button{position:absolute;top:4px;right:4px;width:28px;height:28px;border-radius:50%;background:#e74c3ce6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transition:all var(--transition-fast);z-index:2}.photo-remove-button:hover{background:var(--color-risk);transform:scale(1.1)}.photo-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);color:var(--color-texto-secundario)}.photo-placeholder-text{font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-medium)}.photo-input{display:none}.photo-upload-label{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal);text-align:center}.photo-upload-label:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.prospecto-form{margin-top:var(--spacing-xl)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group-full{grid-column:1 / -1}.form-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.required{color:var(--color-risk);font-weight:var(--font-weight-bold)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.form-input:disabled{background:var(--color-fondo-hover);color:var(--color-texto-disabled);cursor:not-allowed}.form-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);transition:all var(--transition-fast);outline:none;resize:vertical;min-height:100px;line-height:var(--line-height-normal)}.form-textarea:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.form-textarea:disabled{background:var(--color-fondo-hover);color:var(--color-texto-disabled);cursor:not-allowed}.form-textarea::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.character-count{font-size:var(--font-size-small);color:var(--color-texto-secundario);text-align:right;margin-top:var(--spacing-xs);font-family:var(--font-secondary)}.form-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);animation:fadeIn .3s ease-out}.error-icon{font-size:1.5rem;flex-shrink:0}.form-error p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-risk);margin:0;font-weight:var(--font-weight-semibold)}.form-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#3498db1a;border:1px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);animation:fadeIn .3s ease-out}.info-icon{font-size:1.5rem;flex-shrink:0}.form-info p{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-azul-confiable);margin:0;font-weight:var(--font-weight-medium)}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-lg);border-top:1px solid var(--color-borde);flex-wrap:wrap}.form-actions .btn-primary{min-width:180px}.view-header-actions{display:flex;gap:var(--spacing-md);align-items:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn-primary,.form-actions .ghost-button{width:100%}}@media (min-width: 769px) and (max-width: 1024px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.materias-niveles-container{flex-direction:column}.materia-nivel-item{min-width:100%}}.materia-chips-container{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center;padding:var(--spacing-xs) var(--spacing-sm);margin-bottom:var(--spacing-xs);min-height:39px;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);transition:all var(--transition-fast)}.materia-chip{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);white-space:nowrap}.materia-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;margin-left:2px;background:#fff3;color:var(--color-texto-claro);border:none;border-radius:50%;font-size:16px;font-weight:var(--font-weight-bold);line-height:1;cursor:pointer;transition:all var(--transition-fast)}.materia-chip-remove:hover{background:#ffffff4d;transform:scale(1.1)}.materia-chip-remove:active{transform:scale(.95)}.materia-chip-remove:disabled{opacity:.5;cursor:not-allowed}.materia-accordion{width:100%;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);overflow:hidden;transition:all var(--transition-fast)}.materia-accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);border:none;cursor:pointer;font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);text-align:left;transition:all var(--transition-fast);outline:none}.materia-accordion-header:hover:not(:disabled){background:var(--color-fondo-hover)}.materia-accordion-header:disabled{opacity:.6;cursor:not-allowed}.materia-accordion-icon{font-size:var(--font-size-small);color:var(--color-texto-secundario);transition:transform var(--transition-fast)}.materia-accordion-content{padding:var(--spacing-xs);display:flex;flex-direction:column;gap:var(--spacing-xs);background:var(--color-fondo-secundario);border-top:1px solid var(--color-borde);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:200px}}.materia-option-wrapper{display:flex;flex-direction:column;gap:0}.materia-option-wrapper .materia-nivel-item{background:var(--color-fondo-tarjeta);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-sm);margin-top:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.materia-option-button{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#3498db;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:#fff;text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;justify-content:space-between;align-items:center}.materia-option-button:hover:not(:disabled){background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo);color:var(--color-texto-principal)}.materia-option-button.selected{background:#3498db1a;border-color:var(--color-azul-claro-educativo);color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-semibold)}.materia-option-button:disabled{opacity:.6;cursor:not-allowed}.materia-check{color:var(--color-azul-claro-educativo);font-weight:var(--font-weight-bold);font-size:var(--font-size-body)}.materias-niveles-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);position:relative;z-index:1}.materia-nivel-item{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-width:200px;position:relative;z-index:1}.niveles-materia-group{position:relative;z-index:0;clear:both;width:100%;margin-top:var(--spacing-md);isolation:isolate}.niveles-materia-group .materia-nivel-item{isolation:isolate}.nivel-buttons-container{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);min-height:50px;align-items:center}.nivel-button{width:36px;height:36px;border:2px solid var(--color-borde);border-radius:var(--border-radius-md);background:var(--color-fondo-secundario);color:var(--color-texto-principal);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.nivel-button:hover:not(:disabled){background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo);transform:scale(1.05)}.nivel-button.selected{background:var(--color-azul-claro-educativo);border-color:var(--color-azul-claro-educativo);color:var(--color-texto-claro);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-sm)}.nivel-button:disabled{opacity:.6;cursor:not-allowed}.nivel-selected-indicator{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-claro-educativo);margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#3498db1a;border-radius:var(--border-radius-sm)}.nivel-selected-indicator strong{color:var(--color-azul-confiable);font-weight:var(--font-weight-bold)}.prospect-observation-wrapper{position:relative}.prospect-observation-wrapper .form-textarea{padding-bottom:50px}.observation-audio-controls{position:absolute;bottom:12px;right:12px;margin:0;display:flex;gap:var(--spacing-sm);align-items:center;width:auto}.agenda-container{max-width:1200px;margin:0 auto}.agenda-header-row{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);align-items:start}.agenda-date-selector{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde);box-shadow:var(--shadow-sm)}.date-nav-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-fondo-hover);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-size:1.25rem;color:var(--color-azul-confiable);cursor:pointer;transition:all var(--transition-fast)}.date-nav-button:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-2px);box-shadow:var(--shadow-md)}.date-display{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-primary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:var(--color-fondo-secundario);cursor:pointer;transition:all var(--transition-fast)}.date-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a;outline:none}.date-info{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.date-label{font-family:var(--font-primary);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);text-transform:capitalize}.today-button{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-sm);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.today-button:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.agenda-stats{display:flex;flex-direction:row;gap:var(--spacing-md);flex-wrap:wrap}.agenda-stats .stat-card{flex:1;min-width:120px}.stat-card{padding:var(--spacing-lg);background:var(--color-fondo-secundario);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);display:flex;flex-direction:column;gap:var(--spacing-xs);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.stat-pending{border-left:4px solid var(--color-warning)}.stat-card.stat-completed{border-left:4px solid var(--color-verde-exito)}.stat-card.stat-priority{border-left:4px solid var(--color-risk)}.stat-label{font-size:var(--font-size-small);text-transform:uppercase;letter-spacing:.05em;color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold)}.stat-value{font-size:2rem;font-weight:var(--font-weight-bold);color:var(--color-azul-confiable)}.stat-card.stat-pending .stat-value{color:var(--color-warning)}.stat-card.stat-completed .stat-value{color:var(--color-verde-exito)}.stat-card.stat-priority .stat-value{color:var(--color-risk)}.agenda-filters{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-fondo-hover);border-radius:var(--border-radius-lg);border:1px solid var(--color-borde)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}@media (min-width: 769px){.filter-group:first-child{flex-direction:row;align-items:center;gap:var(--spacing-md);flex-wrap:nowrap}.filter-group:first-child .filter-label{margin-bottom:0;white-space:nowrap;flex-shrink:0}.category-filters-main{display:flex;flex-wrap:nowrap;gap:var(--spacing-sm);align-items:center;flex-shrink:0}.category-filters{display:flex;flex-wrap:nowrap;gap:var(--spacing-sm);align-items:center;margin-left:0;margin-top:0!important;flex:1}}.filter-label{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);text-transform:uppercase;letter-spacing:.05em}.category-filters-main{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.category-toggle-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);border:2px solid var(--color-azul-claro-educativo);border-radius:var(--border-radius-md);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-claro-educativo);cursor:pointer;transition:all var(--transition-fast);display:none;align-items:center;gap:var(--spacing-xs)}@media (max-width: 768px){.category-toggle-button{display:flex}}.category-toggle-button:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.category-toggle-icon{font-size:.75rem;transition:transform var(--transition-fast)}.category-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}@media (min-width: 769px){.category-filters{max-height:none!important;opacity:1!important;margin-top:0!important;margin-bottom:0!important}}@media (max-width: 768px){.category-filters{max-height:0;overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-normal),margin-top var(--transition-normal);opacity:0;margin-top:0;margin-bottom:0;gap:0}.category-filters.open{max-height:500px;opacity:1;margin-top:var(--spacing-sm);gap:var(--spacing-sm)}}.category-filter{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-fondo-secundario);border:2px solid var(--color-borde);border-radius:var(--border-radius-md);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-xs)}.category-filter:hover{background:var(--color-fondo-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.category-filter.active{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);border-color:var(--color-azul-claro-educativo)}.filter-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-body);color:var(--color-texto-principal)}.filter-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.tasks-container{margin-bottom:var(--spacing-xl)}.tasks-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.task-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-fondo-secundario);border-radius:var(--border-radius-md);border:1px solid var(--color-borde);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);position:relative}.task-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.task-card.completed{opacity:.7;background:var(--color-fondo-hover)}.task-card.priority-alta{border-left:4px solid var(--color-risk)}.task-card.priority-media{border-left:4px solid var(--color-warning)}.task-card.priority-baja{border-left:4px solid var(--color-verde-exito)}.task-header{display:flex;align-items:flex-start;gap:var(--spacing-md);flex:1}.task-checkbox-container{margin-top:2px}.task-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--color-verde-exito)}.task-main{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.task-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.task-title{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin:0;flex:1;min-width:200px}.task-title.strikethrough{text-decoration:line-through;color:var(--color-texto-secundario)}.task-badges{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.task-category-badge,.task-priority-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-texto-claro);display:flex;align-items:center;gap:4px;white-space:nowrap}.task-description{font-size:var(--font-size-body);color:var(--color-texto-secundario);line-height:var(--line-height-relaxed);margin:0}.task-description.strikethrough{text-decoration:line-through;opacity:.6}.task-time{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-small);color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold)}.time-icon{font-size:1rem}.task-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.task-action-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-fondo-hover);border:1px solid var(--color-borde);border-radius:var(--border-radius-sm);font-size:1rem;cursor:pointer;transition:all var(--transition-fast)}.task-action-button:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.task-delete-button:hover{background:var(--color-risk);border-color:var(--color-risk)}.no-tasks{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);border:2px dashed var(--color-borde)}.no-tasks-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.no-tasks-text{font-size:var(--font-size-body);color:var(--color-texto-secundario);margin-bottom:var(--spacing-lg)}.task-modal{max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#2c3e50b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);animation:fadeIn var(--transition-normal)}.modal-content{background:var(--color-fondo-secundario);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:600px;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-borde)}.modal-header h3{margin:0;font-size:var(--font-size-h3);color:var(--color-azul-confiable)}.modal-close-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--border-radius-sm);font-size:1.5rem;color:var(--color-texto-secundario);cursor:pointer;transition:all var(--transition-fast)}.modal-close-button:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.modal-body{padding:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-group label{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-texto-principal);text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group textarea,.form-group select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:#ffffff96;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a;outline:none}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-borde)}.ghost-button{background-color:transparent;color:var(--color-azul-claro-educativo);padding:.75rem 1.5rem;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.ghost-button:hover{background-color:var(--color-fondo-hover);border-color:var(--color-borde-hover)}@media (max-width: 768px){.agenda-header-row{grid-template-columns:1fr;gap:var(--spacing-md)}.agenda-date-selector{flex-direction:row;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.date-nav-button{width:36px;height:36px;flex-shrink:0;font-size:1rem}.date-display{flex:1;min-width:0;gap:var(--spacing-xs)}.date-input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-small)}.date-info{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-xs)}.date-label{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.today-button{padding:4px var(--spacing-xs);font-size:var(--font-size-xs);white-space:nowrap}.agenda-stats{flex-direction:row;flex-wrap:wrap}.agenda-stats .stat-card{flex:1 1 calc(50% - var(--spacing-md));min-width:120px}.task-card{flex-direction:column}.task-title-row{flex-direction:column;align-items:flex-start}.task-actions{width:100%;justify-content:flex-end}.form-row{grid-template-columns:1fr}.category-filters-main{flex-direction:column;width:100%}.category-filter-all,.category-toggle-button{width:100%;justify-content:center}.category-filters{flex-direction:column;width:100%;margin-top:var(--spacing-sm)}.category-filters.open{margin-top:var(--spacing-sm)}.category-filter{width:100%;justify-content:center}}@media (max-width: 480px){.agenda-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.agenda-stats .stat-card{flex:none;min-width:auto}.agenda-stats .stat-card.stat-completed{grid-column:1 / -1}.date-info{flex-direction:column;align-items:flex-start}.modal-content{width:100%;max-height:95vh}}.task-description-input-wrapper{position:relative}.task-description-input-wrapper textarea{padding-bottom:50px}.observation-audio-controls{margin-top:0;display:flex;gap:var(--spacing-sm);align-items:center}.task-description-input-wrapper .observation-audio-controls{position:absolute;bottom:10px;right:10px}.transcribing-indicator{font-family:var(--font-primary);color:var(--color-azul-confiable);font-size:var(--font-size-small)}.recording-time{font-family:var(--font-primary);color:#e74c3c;font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);min-width:45px;text-align:center}.observation-record-button{width:44px;height:44px;border-radius:50%;border:none;background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.observation-record-button:hover:not(:disabled){background:var(--color-azul-claro-hover);transform:scale(1.05)}.observation-record-button:disabled{background:var(--color-texto-disabled);cursor:not-allowed;opacity:.6}.observation-record-button.recording{background:#e74c3c;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.login-container{position:relative;height:100vh;max-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);overflow:hidden;background:var(--color-fondo-principal)}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;overflow:hidden}.login-background-gradient{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 30%,rgba(52,152,219,.4) 0%,rgba(52,152,219,.2) 30%,transparent 60%),radial-gradient(circle at 80% 70%,rgba(39,174,96,.4) 0%,rgba(39,174,96,.2) 30%,transparent 60%),radial-gradient(circle at 50% 50%,rgba(155,89,182,.25) 0%,rgba(155,89,182,.1) 40%,transparent 70%),radial-gradient(ellipse at 10% 20%,rgba(52,152,219,.3) 0%,transparent 50%),radial-gradient(ellipse at 90% 80%,rgba(39,174,96,.3) 0%,transparent 50%),radial-gradient(circle at 30% 60%,rgba(255,255,255,.1) 0%,transparent 40%),radial-gradient(circle at 70% 40%,rgba(255,255,255,.08) 0%,transparent 35%),linear-gradient(135deg,#2c3e5026,#3498db1a,#27ae6026);animation:gradientRotate 25s ease-in-out infinite,gradientPulse 8s ease-in-out infinite;filter:blur(.5px)}.login-background-gradient:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 800px 400px at 0% 50%,rgba(52,152,219,.2) 0%,transparent 50%),radial-gradient(ellipse 600px 300px at 100% 50%,rgba(39,174,96,.2) 0%,transparent 50%),conic-gradient(from 0deg at 50% 50%,#3498db1a,#27ae601a,#9b59b61a,#3498db1a,#3498db1a 360deg);animation:waveMove 15s ease-in-out infinite,conicRotate 20s linear infinite;opacity:.6}.login-background-gradient:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 15% 25%,rgba(255,255,255,.15) 0%,transparent 20%),radial-gradient(circle at 85% 75%,rgba(255,255,255,.12) 0%,transparent 18%),radial-gradient(circle at 45% 55%,rgba(255,255,255,.1) 0%,transparent 15%),radial-gradient(circle at 75% 30%,rgba(255,255,255,.08) 0%,transparent 12%),radial-gradient(circle at 25% 80%,rgba(255,255,255,.1) 0%,transparent 15%);animation:particlesFloat 12s ease-in-out infinite;opacity:.7}.login-background-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(52,152,219,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(52,152,219,.03) 1px,transparent 1px);background-size:50px 50px;animation:patternMove 30s linear infinite}.login-card{position:relative;z-index:1;width:100%;max-width:420px;max-height:calc(100vh - var(--spacing-md) * 2);background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius-xl);box-shadow:0 20px 60px #2c3e5033,0 0 0 1px #ffffff80,inset 0 1px #fffc;padding:var(--spacing-xl) var(--spacing-lg);animation:cardFadeIn .6s ease-out;overflow:hidden;display:flex;flex-direction:column}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-azul-claro-educativo),var(--color-verde-exito),var(--color-azul-claro-educativo));background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}.login-logo-section{display:flex;justify-content:center;align-items:center;margin-bottom:var(--spacing-lg);animation:logoFloat .8s ease-out .2s both;flex-shrink:0}.login-logo-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.login-logo{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 8px 16px rgba(44,62,80,.2));animation:logoPulse 3s ease-in-out infinite;z-index:2;position:relative}.login-logo-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:110px;height:110px;background:radial-gradient(circle,rgba(52,152,219,.3) 0%,rgba(39,174,96,.2) 50%,transparent 70%);border-radius:50%;animation:glowPulse 2s ease-in-out infinite;z-index:1}.login-content{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;min-height:0}.login-title{font-family:var(--font-primary);font-size:var(--font-size-h2);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);text-align:center;margin-bottom:var(--spacing-lg);background:linear-gradient(135deg,var(--color-azul-confiable) 0%,var(--color-azul-claro-educativo) 50%,var(--color-verde-exito) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:titleFadeIn .6s ease-out .3s both;flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md);flex:1;min-height:0}.login-form-group{display:flex;flex-direction:column;gap:var(--spacing-sm);animation:formGroupFadeIn .6s ease-out both}.login-form-group:nth-child(1){animation-delay:.4s}.login-form-group:nth-child(2){animation-delay:.5s}.login-label{font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable);margin-bottom:var(--spacing-xs)}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);background:#fffc;border:2px solid var(--color-borde);border-radius:var(--border-radius-md);transition:all var(--transition-normal);outline:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-input:focus{border-color:var(--color-azul-claro-educativo);background:#fffffff2;box-shadow:0 0 0 4px #3498db1a,0 4px 12px #3498db26;transform:translateY(-2px)}.login-input::placeholder{color:var(--color-texto-secundario);font-weight:var(--font-weight-regular)}.login-input-border{position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--color-azul-claro-educativo),var(--color-verde-exito));transition:width var(--transition-normal);border-radius:var(--border-radius-sm)}.login-input:focus+.login-input-border{width:100%}.login-show-password{position:absolute;right:var(--spacing-md);background:transparent;border:none;color:var(--color-azul-claro-educativo);font-family:var(--font-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);transition:all var(--transition-fast);z-index:2}.login-show-password:hover{color:var(--color-verde-exito);background:#3498db1a}.login-show-password:active{transform:scale(.95)}.login-forgot-password{text-align:right;margin-top:calc(var(--spacing-xs) * -1);margin-bottom:var(--spacing-xs);animation:formGroupFadeIn .6s ease-out .6s both}.login-forgot-link{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-azul-claro-educativo);text-decoration:none;font-weight:var(--font-weight-semibold);transition:all var(--transition-fast);position:relative}.login-forgot-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-verde-exito);transition:width var(--transition-normal)}.login-forgot-link:hover{color:var(--color-verde-exito)}.login-forgot-link:hover:after{width:100%}.login-submit-btn{position:relative;width:100%;padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-bold);color:var(--color-texto-claro);background:linear-gradient(135deg,var(--color-azul-claro-educativo) 0%,var(--color-verde-exito) 100%);border:none;border-radius:var(--border-radius-md);cursor:pointer;overflow:hidden;box-shadow:0 4px 15px #3498db4d,0 2px 8px #27ae6033;transition:all var(--transition-normal);animation:formGroupFadeIn .6s ease-out .7s both;z-index:1;flex-shrink:0;margin-top:var(--spacing-xs)}.login-submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.login-submit-btn:hover:before{left:100%}.login-submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3498db66,0 4px 12px #27ae604d}.login-submit-btn:active{transform:translateY(0)}.login-submit-text{position:relative;z-index:2;letter-spacing:.05em}.login-submit-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;background:radial-gradient(circle,rgba(255,255,255,.4) 0%,transparent 70%);border-radius:50%;transition:width .3s ease,height .3s ease}.login-submit-btn:hover .login-submit-glow{width:300px;height:300px}.login-error{padding:var(--spacing-sm) var(--spacing-md);background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:var(--border-radius-md);color:#e74c3c;font-size:var(--font-size-small);margin-bottom:var(--spacing-md);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes logoFloat{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes logoPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes glowPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.1)}}@keyframes titleFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes formGroupFadeIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes gradientRotate{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.1)}}@keyframes gradientPulse{0%,to{opacity:1;filter:blur(.5px) brightness(1)}50%{opacity:.9;filter:blur(1px) brightness(1.2)}}@keyframes waveMove{0%,to{transform:translate(0) translateY(0) scale(1)}33%{transform:translate(5%) translateY(-3%) scale(1.05)}66%{transform:translate(-5%) translateY(3%) scale(.95)}}@keyframes conicRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes particlesFloat{0%,to{transform:translate(0) scale(1);opacity:.7}25%{transform:translate(2%,-2%) scale(1.1);opacity:.8}50%{transform:translate(-2%,2%) scale(.9);opacity:.6}75%{transform:translate(1%,1%) scale(1.05);opacity:.75}}@keyframes patternMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 768px){.login-container{padding:var(--spacing-sm)}.login-card{padding:var(--spacing-lg) var(--spacing-md);max-width:100%}.login-logo{width:70px;height:70px}.login-logo-glow{width:100px;height:100px}.login-title{font-size:var(--font-size-h3);margin-bottom:var(--spacing-md)}.login-form{gap:var(--spacing-sm)}}@media (max-width: 480px){.login-container{padding:var(--spacing-xs)}.login-card{padding:var(--spacing-md) var(--spacing-sm);border-radius:var(--border-radius-lg)}.login-logo{width:60px;height:60px}.login-logo-glow{width:90px;height:90px}.login-logo-section{margin-bottom:var(--spacing-md)}.login-title{font-size:var(--font-size-h3);margin-bottom:var(--spacing-sm)}}
