@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}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}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:var(--color-azul-confiable);color:var(--color-texto-claro);border:none;border-radius:var(--border-radius-lg);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;box-shadow:var(--shadow-lg);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:var(--color-azul-confiable-hover);transform:translateY(-2px);box-shadow:var(--shadow-xl)}.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}.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}.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:var(--spacing-lg) 0;margin:0;flex:1;overflow-y:auto;position:relative;z-index:1}.menu-item{margin:var(--spacing-xs) var(--spacing-md);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:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);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:var(--font-size-body)}.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(8px);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:4px;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:32px;height:32px;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:8px;height:8px;border-radius:50%;background:var(--color-verde-exito);opacity:0;transform:scale(0);transition:all var(--transition-normal);box-shadow:0 0 8px 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}.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)}.logo-icon{width:28px;height:28px}}@media (max-width: 480px){.menu-nav{width:100%;max-width:320px}.menu-logo-button{min-width:100px}.logo-text{display:none}}@media (min-width: 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}.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{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:hidden}.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{padding:1.25rem}.dashboard-header{flex-direction:column;gap:1rem;align-items:flex-start}}@media (max-width: 600px){.view-card{padding:1.25rem}.dashboard-header,.dashboard-main{padding:1rem}}#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}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.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}}.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{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)}.materia-accordion-header:hover{background:var(--color-fondo-hover)}.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}.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)}.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:100;max-height:200px;overflow-y:auto;animation:fadeInDown .2s ease-out}.student-grade-cell{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);white-space:nowrap}.student-materias-accordion{position:relative;display:inline-block}.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-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:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:10;min-width:150px;animation:slideDown .2s ease-out}.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)}.student-materia-item:last-child{border-bottom:none}.student-payment-cell{font-family:var(--font-secondary);font-size:var(--font-size-small);color:var(--color-texto-secundario);white-space:nowrap}.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}@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}.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-md) 1.25rem 1.25rem;background:var(--color-fondo-secundario);border-top:1px solid var(--color-borde)}.input-wrapper{display:flex;gap:var(--spacing-md);align-items:flex-end;background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-xl);padding:var(--spacing-md) 1.25rem;box-shadow:var(--shadow-md)}.chat-input{flex:1;padding:1.15rem 1.35rem;border:1.5px solid var(--color-borde);border-radius:var(--border-radius-lg);font-size:var(--font-size-body);font-family:var(--font-secondary);line-height:var(--line-height-relaxed);resize:none;max-height:220px;min-height:70px;outline:none;background:var(--color-fondo-secundario);color:var(--color-texto-principal);box-shadow:inset var(--shadow-sm);transition:all var(--transition-fast)}.chat-input:focus{border-color:var(--color-azul-claro-educativo);box-shadow:inset var(--shadow-sm),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}.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}.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}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.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}}.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)}.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)}.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)}.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)}.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}.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)}.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-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 textarea{resize:vertical;min-height:100px}.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}.edit-student-modal{max-width:700px;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 .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)}}.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}.new-student-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-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-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-lg);font-family:var(--font-secondary);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-texto-principal);background:linear-gradient(to bottom,#ffffff,var(--color-fondo-secundario));background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233498db' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;transition:all var(--transition-normal);outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;box-shadow:0 2px 4px #0000000d}.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:linear-gradient(to bottom,#fff,#f8f9fa);box-shadow:0 4px 8px #3498db26;transform:translateY(-1px)}.form-select:focus{border-color:var(--color-azul-confiable);background:linear-gradient(to bottom,#fff,#f0f8ff);box-shadow:0 0 0 4px #3498db26,0 4px 12px #3498db33;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='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23bdc3c7' d='M6 9L1 4h10z'/%3E%3C/svg%3E");color:var(--color-texto-disabled);cursor:not-allowed;border-color:var(--color-borde);box-shadow:none}.form-select option{padding:var(--spacing-md) var(--spacing-lg);margin:var(--spacing-xs) 0;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);border-radius:var(--border-radius-md);transition:all var(--transition-fast);cursor:pointer}.form-select option:first-child{margin-top:0;padding-top:var(--spacing-md)}.form-select option:last-child{margin-bottom:0;padding-bottom:var(--spacing-md)}.form-select option:hover,.form-select option:focus{background:linear-gradient(135deg,var(--color-azul-claro-educativo),var(--color-azul-confiable));color:var(--color-texto-claro);font-weight:var(--font-weight-semibold);padding-left:calc(var(--spacing-lg) + 4px)}.form-select option:checked{background:linear-gradient(135deg,var(--color-verde-exito),var(--color-verde-claro-estudio));color:var(--color-texto-claro);font-weight:var(--font-weight-semibold);padding-left:calc(var(--spacing-lg) + 4px)}.form-select option:disabled{background:var(--color-fondo-hover);color:var(--color-texto-disabled);cursor:not-allowed;opacity:.6}.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-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-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(3,1fr);gap:var(--spacing-md);flex:1;width:100%}.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-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-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: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-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-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)}.view-header-actions{display:flex;gap:var(--spacing-md);align-items:center}.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-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);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{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:focus{outline:none;box-shadow:none}.materia-accordion-header:focus-visible{outline:none;box-shadow:none}.materia-accordion-header:active{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;scroll-margin-top:0;scroll-padding-top:0;scroll-margin-bottom:0;scroll-padding-bottom:0}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:200px}}.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:not(:disabled){background:var(--color-fondo-hover);border-color:var(--color-azul-claro-educativo)}.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}.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}.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:0 2px 8px #3498db4d}.nivel-button:disabled{opacity:.6;cursor:not-allowed}.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)}@media (max-width: 768px){.materias-niveles-container{flex-direction:column}.materia-nivel-item{min-width:100%}}.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}.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-close-button:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.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-textarea:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.observation-textarea::placeholder{color:var(--color-texto-secundario)}.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}@media (max-width: 768px){.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:#fff;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)}.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)}.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}.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:1200px;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}.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(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{background:#ffffff96;border:1px solid var(--color-borde);border-radius:var(--border-radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);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:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-texto-secundario);font-weight:var(--font-weight-semibold)}.stat-value{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-azul-confiable)}.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-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:4px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.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)}.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:hidden}.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)}.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-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)}@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}}.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:hidden}.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}.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)}.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)}.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-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-cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.futuros-card{background:var(--color-fondo-secundario);border:1px solid var(--color-borde);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);cursor:pointer;display:flex;flex-direction:column;gap:var(--spacing-md)}.futuros-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--color-azul-claro-educativo)}.futuros-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-borde)}.futuros-card-student-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.futuros-card-avatar{width:60px;height:60px;border-radius:var(--border-radius-md);object-fit:cover;border:2px solid var(--color-borde);flex-shrink:0}.futuros-card-student-text{display:flex;flex-direction:column;gap:.25rem}.futuros-card-student-name{font-family:var(--font-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-azul-confiable);margin:0;line-height:1.2}.futuros-card-status-badge{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);padding:.125rem .5rem;background:#3498db1a;border-radius:var(--border-radius-full);display:inline-block;width:fit-content}.futuros-card-next-contact{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);min-width:100px}.futuros-card-next-contact-label{font-family:var(--font-secondary);font-size:var(--font-size-xs);color:var(--color-texto-secundario);text-transform:uppercase;letter-spacing:.05em}.futuros-card-next-contact-value{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-bold)}.futuros-card-next-contact.overdue{background:#ef44441a;border:1px solid var(--color-risk)}.futuros-card-next-contact.overdue .futuros-card-next-contact-value{color:var(--color-risk)}.futuros-card-next-contact.today{background:#f59e0b1a;border:1px solid var(--color-warning)}.futuros-card-next-contact.today .futuros-card-next-contact-value{color:var(--color-warning)}.futuros-card-next-contact.tomorrow{background:#3498db1a;border:1px solid var(--color-azul-claro-educativo)}.futuros-card-next-contact.tomorrow .futuros-card-next-contact-value{color:var(--color-azul-claro-educativo)}.futuros-card-next-contact.soon{background:#10b9811a;border:1px solid var(--color-verdeExito)}.futuros-card-next-contact.soon .futuros-card-next-contact-value{color:var(--color-verdeExito)}.futuros-card-next-contact.later,.futuros-card-next-contact.no-scheduled,.futuros-card-next-contact.invalid{background:var(--color-fondo-hover);border:1px solid var(--color-borde)}.futuros-card-next-contact.later .futuros-card-next-contact-value,.futuros-card-next-contact.no-scheduled .futuros-card-next-contact-value,.futuros-card-next-contact.invalid .futuros-card-next-contact-value{color:var(--color-texto-secundario)}.futuros-card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.futuros-card-field{display:flex;flex-direction:column;gap:.25rem}.futuros-card-field-full{grid-column:1 / -1}.futuros-card-field-label{font-family:var(--font-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-texto-secundario);text-transform:uppercase;letter-spacing:.05em}.futuros-card-field-value{font-family:var(--font-secondary);font-size:var(--font-size-body);color:var(--color-texto-principal);word-break:break-word}.futuros-card-phone-link{color:var(--color-azul-claro-educativo);text-decoration:none;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.futuros-card-phone-link:hover{text-decoration:underline;color:var(--color-azul-claro-hover)}.futuros-card-observation{font-style:italic;color:var(--color-texto-secundario);line-height:1.5;max-height:4.5em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.futuros-card-footer{display:flex;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-borde)}.futuros-card-button{flex:1;padding:var(--spacing-sm) var(--spacing-md);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)}.futuros-card-button-primary{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}.futuros-card-button-primary:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.futuros-card-button-secondary{background:transparent;color:var(--color-azul-claro-educativo);border:1px solid var(--color-azul-claro-educativo)}.futuros-card-button-secondary:hover{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro)}.futuros-card-button:active{transform:translateY(0)}@media (max-width: 1024px){.futuros-cards-container{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@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%}.futuros-cards-container{grid-template-columns:1fr}.futuros-card-header{flex-direction:column}.futuros-card-next-contact{align-items:flex-start;width:100%}.futuros-card-body{grid-template-columns:1fr}.futuros-card-footer{flex-direction:column}.futuros-card-button{width:100%}}@media (max-width: 480px){.futuros-card{padding:var(--spacing-md)}.futuros-card-avatar{width:50px;height:50px}.futuros-card-student-name{font-size:var(--font-size-body)}}.futuros-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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.futuros-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:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.futuros-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)}.futuros-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}.futuros-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}.futuros-modal-close:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal)}.futuros-modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1;background-color:transparent}.futuros-validation-message{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);color:var(--color-azul-confiable);font-family:var(--font-secondary);font-size:var(--font-size-small);margin-bottom:var(--spacing-lg);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.futuros-validation-icon{font-size:1.2rem;flex-shrink:0}.futuros-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.futuros-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.futuros-form-group-full{grid-column:1 / -1}.futuros-form-label{font-family:var(--font-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-azul-confiable)}.futuros-required{color:var(--color-risk);font-weight:var(--font-weight-bold)}.futuros-form-input,.futuros-form-textarea{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}.futuros-form-input:focus,.futuros-form-textarea:focus{border-color:var(--color-azul-claro-educativo);box-shadow:0 0 0 3px #3498db1a}.futuros-form-input::placeholder,.futuros-form-textarea::placeholder{color:var(--color-texto-secundario)}.futuros-form-textarea{resize:vertical;min-height:100px;font-family:var(--font-secondary)}.futuros-modal-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)}.futuros-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)}.futuros-modal-button-cancel{background:transparent;color:var(--color-texto-secundario);border:1px solid var(--color-borde)}.futuros-modal-button-cancel:hover{background:var(--color-fondo-hover);color:var(--color-texto-principal);border-color:var(--color-texto-secundario)}.futuros-modal-button-save{background:var(--color-azul-claro-educativo);color:var(--color-texto-claro);box-shadow:var(--shadow-sm)}.futuros-modal-button-save:hover{background:var(--color-azul-claro-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.futuros-modal-button-save:active{transform:translateY(0)}@media (max-width: 768px){.futuros-modal{max-height:95vh}.futuros-form-grid{grid-template-columns:1fr}.futuros-modal-footer{flex-direction:column-reverse}.futuros-modal-button{width:100%}}
