:root{--color-fondo: #f4f6fb;--color-superficie: #ffffff;--color-superficie-elevada: #ffffff;--color-superficie-suave: #eef1f8;--color-tarjeta: var(--color-superficie);--color-borde: #e2e6ef;--color-borde-fuerte: #cdd4e3;--color-texto: #161a25;--color-texto-sec: #555f73;--color-texto-suave: #7b8499;--color-inactivo: #9aa3b2;--color-sobre-primario: #ffffff;--color-primario: #2d5bd7;--color-primario-hover: #2750c2;--color-primario-activo: #1e3f99;--color-primario-oscuro: #1e3f99;--color-primario-suave: #e8eefc;--color-primario-borde: #c2d2f6;--color-violin: #2d5bd7;--color-violin-suave: #e8eefc;--color-lenguaje: #7a4fcb;--color-lenguaje-suave: #efe8fb;--color-solfeo: #1f9d8b;--color-solfeo-suave: #e2f4f1;--color-exito: #1f9d8b;--color-exito-suave: #e2f4f1;--color-aviso: #c97a00;--color-aviso-suave: #fcf1de;--color-error: #d23f3f;--color-error-suave: #fbe6e6;--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-rec-pendiente: #c97a00;--color-rec-recuperada: #1f9d8b;--color-rec-no-recuperable: #8a93a6;--fuente-base: Inter, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--fs-xs: .75rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.375rem;--fs-2xl: 1.75rem;--fs-3xl: 2.25rem;--peso-normal: 400;--peso-medio: 500;--peso-semi: 600;--peso-fuerte: 700;--interlineado: 1.5;--esp-1: .25rem;--esp-2: .5rem;--esp-3: .75rem;--esp-4: 1rem;--esp-5: 1.25rem;--esp-6: 1.5rem;--esp-8: 2rem;--esp-10: 2.5rem;--radio-sm: 8px;--radio: 12px;--radio-lg: 16px;--radio-completo: 999px;--sombra-sm: 0 1px 2px rgba(16, 24, 40, .06);--sombra: 0 2px 8px rgba(16, 24, 40, .08);--sombra-md: 0 6px 18px rgba(16, 24, 40, .1);--sombra-lg: 0 16px 40px rgba(16, 24, 40, .16);--anillo-foco: 0 0 0 3px rgba(45, 91, 215, .4);--color-foco: var(--color-primario);--toque-min: 44px;--transicion: .16s ease;--ancho-max: 960px}:root[data-tema=oscuro]{--color-fondo: #0f1220;--color-superficie: #171a2b;--color-superficie-elevada: #1f2335;--color-superficie-suave: #1c2032;--color-tarjeta: var(--color-superficie);--color-borde: #2b3047;--color-borde-fuerte: #3a4060;--color-texto: #eef1fa;--color-texto-sec: #aab2c7;--color-texto-suave: #828aa2;--color-inactivo: #6c748c;--color-sobre-primario: #ffffff;--color-primario: #6b93ff;--color-primario-hover: #8aaaff;--color-primario-activo: #a9c0ff;--color-primario-oscuro: #a9c0ff;--color-primario-suave: #1d2745;--color-primario-borde: #34467a;--color-violin: #6b93ff;--color-violin-suave: #1d2745;--color-lenguaje: #b594f0;--color-lenguaje-suave: #2a2240;--color-solfeo: #3fd0ba;--color-solfeo-suave: #16302d;--color-exito: #3fd0ba;--color-exito-suave: #16302d;--color-aviso: #f0b43f;--color-aviso-suave: #352a14;--color-error: #f06868;--color-error-suave: #3a1f22;--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-rec-pendiente: #f0b43f;--color-rec-recuperada: #3fd0ba;--color-rec-no-recuperable: #828aa2;--sombra-sm: 0 1px 2px rgba(0, 0, 0, .4);--sombra: 0 2px 10px rgba(0, 0, 0, .45);--sombra-md: 0 8px 22px rgba(0, 0, 0, .5);--sombra-lg: 0 18px 44px rgba(0, 0, 0, .6);--anillo-foco: 0 0 0 3px rgba(107, 147, 255, .5);color-scheme:dark}@media(prefers-color-scheme:dark){:root[data-tema=sistema]{--color-fondo: #0f1220;--color-superficie: #171a2b;--color-superficie-elevada: #1f2335;--color-superficie-suave: #1c2032;--color-tarjeta: var(--color-superficie);--color-borde: #2b3047;--color-borde-fuerte: #3a4060;--color-texto: #eef1fa;--color-texto-sec: #aab2c7;--color-texto-suave: #828aa2;--color-inactivo: #6c748c;--color-sobre-primario: #ffffff;--color-primario: #6b93ff;--color-primario-hover: #8aaaff;--color-primario-activo: #a9c0ff;--color-primario-oscuro: #a9c0ff;--color-primario-suave: #1d2745;--color-primario-borde: #34467a;--color-violin: #6b93ff;--color-violin-suave: #1d2745;--color-lenguaje: #b594f0;--color-lenguaje-suave: #2a2240;--color-solfeo: #3fd0ba;--color-solfeo-suave: #16302d;--color-exito: #3fd0ba;--color-exito-suave: #16302d;--color-aviso: #f0b43f;--color-aviso-suave: #352a14;--color-error: #f06868;--color-error-suave: #3a1f22;--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-rec-pendiente: #f0b43f;--color-rec-recuperada: #3fd0ba;--color-rec-no-recuperable: #828aa2;--sombra-sm: 0 1px 2px rgba(0, 0, 0, .4);--sombra: 0 2px 10px rgba(0, 0, 0, .45);--sombra-md: 0 8px 22px rgba(0, 0, 0, .5);--sombra-lg: 0 18px 44px rgba(0, 0, 0, .6);--anillo-foco: 0 0 0 3px rgba(107, 147, 255, .5);color-scheme:dark}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--fuente-base);font-size:var(--fs-md);line-height:var(--interlineado);color:var(--color-texto);background:var(--color-fondo);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color var(--transicion),color var(--transicion)}h1,h2,h3,h4{color:var(--color-texto);line-height:1.25;margin:0 0 var(--esp-3)}h1{font-size:var(--fs-2xl);font-weight:var(--peso-fuerte)}h2{font-size:var(--fs-xl);font-weight:var(--peso-fuerte)}h3{font-size:var(--fs-lg);font-weight:var(--peso-semi)}h4{font-size:var(--fs-md);font-weight:var(--peso-semi)}p{margin:0 0 var(--esp-3)}a{color:var(--color-primario);text-decoration:none}a:hover{text-decoration:underline}small{font-size:var(--fs-sm);color:var(--color-texto-sec)}:focus-visible{outline:none;box-shadow:var(--anillo-foco);border-radius:var(--radio-sm)}.app{min-height:100vh;padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}.app__cabecera{display:flex;align-items:center;justify-content:space-between;gap:var(--esp-3);padding:var(--esp-3) var(--esp-4);padding-top:calc(var(--esp-3) + env(safe-area-inset-top,0px));background:var(--color-superficie);border-bottom:1px solid var(--color-borde);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:saturate(1.2);backdrop-filter:saturate(1.2)}.app__titulo{font-size:var(--fs-lg);font-weight:var(--peso-fuerte);margin:0;letter-spacing:-.01em}.app__contenido{padding:var(--esp-4);max-width:var(--ancho-max);margin:0 auto}.app__acciones{display:inline-flex;align-items:center;gap:var(--esp-3)}.pagina{display:block;animation:aparecer var(--transicion)}@keyframes aparecer{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:var(--color-superficie);border-top:1px solid var(--color-borde);box-shadow:0 -2px 12px #1018280f;padding-bottom:env(safe-area-inset-bottom,0px);z-index:20}.nav__item{min-width:var(--toque-min);min-height:var(--toque-min);flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--esp-2) var(--esp-1);color:var(--color-texto-sec);text-decoration:none;font-size:var(--fs-xs);font-weight:var(--peso-medio);position:relative;transition:color var(--transicion)}.nav__item:hover{color:var(--color-texto);text-decoration:none}.nav__item--activo{color:var(--color-primario);font-weight:var(--peso-semi)}.nav__item--activo:before{content:"";position:absolute;top:0;width:28px;height:3px;border-radius:var(--radio-completo);background:var(--color-primario)}.nav__icono{font-size:1.25rem;line-height:1}.nav__texto{line-height:1}.nav__item--tema{flex:0 0 auto;padding:var(--esp-1) var(--esp-2)}.nav__item--tema:hover{color:inherit}.cabecera-seccion{display:flex;align-items:center;justify-content:space-between;gap:var(--esp-3);margin-bottom:var(--esp-4)}.cabecera-seccion__titulo{margin:0}.subtitulo{color:var(--color-texto-sec);font-size:var(--fs-sm);margin:0}.texto-secundario{color:var(--color-texto-sec)}.texto-suave{color:var(--color-texto-suave)}.tarjeta{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio);padding:var(--esp-4);box-shadow:var(--sombra-sm)}.tarjeta--elevada{box-shadow:var(--sombra-md)}.tarjeta--plana{box-shadow:none}.tarjeta--interactiva{cursor:pointer;transition:transform var(--transicion),box-shadow var(--transicion),border-color var(--transicion)}.tarjeta--interactiva:hover{transform:translateY(-2px);box-shadow:var(--sombra-md);border-color:var(--color-borde-fuerte)}.tarjeta__cabecera{margin-bottom:var(--esp-3)}.tarjeta__cuerpo{color:var(--color-texto-sec)}.tarjeta__pie{margin-top:var(--esp-3);padding-top:var(--esp-3);border-top:1px solid var(--color-borde)}.panel{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-5);box-shadow:var(--sombra-sm)}.grid{display:grid;gap:var(--esp-4)}.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid--auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.fila{display:flex;align-items:center;gap:var(--esp-3)}.fila--entre{justify-content:space-between}.fila--fin{justify-content:flex-end}.fila--envoltura{flex-wrap:wrap}.columna-flex{display:flex;flex-direction:column;gap:var(--esp-3)}.pila>*+*{margin-top:var(--esp-3)}@media(max-width:640px){.grid--2,.grid--3{grid-template-columns:1fr}}.boton{min-height:var(--toque-min);display:inline-flex;align-items:center;justify-content:center;gap:var(--esp-2);padding:var(--esp-2) var(--esp-4);border:1px solid var(--color-borde-fuerte);border-radius:var(--radio);background:var(--color-superficie);color:var(--color-texto);font:inherit;font-weight:var(--peso-semi);line-height:1.2;cursor:pointer;text-decoration:none;transition:background-color var(--transicion),border-color var(--transicion),color var(--transicion),transform var(--transicion),box-shadow var(--transicion)}.boton:hover{background:var(--color-superficie-suave);text-decoration:none}.boton:active{transform:translateY(1px)}.boton:disabled,.boton[disabled]{opacity:.55;cursor:not-allowed;transform:none}.boton--primario{background:var(--color-primario);border-color:var(--color-primario);color:var(--color-sobre-primario);box-shadow:var(--sombra-sm)}.boton--primario:hover{background:var(--color-primario-hover);border-color:var(--color-primario-hover)}.boton--primario:active{background:var(--color-primario-activo)}.boton--secundario{background:var(--color-primario-suave);border-color:var(--color-primario-borde);color:var(--color-primario)}.boton--secundario:hover{background:var(--color-superficie-suave)}.boton--ghost{background:transparent;border-color:transparent;color:var(--color-texto-sec)}.boton--ghost:hover{background:var(--color-superficie-suave);color:var(--color-texto)}.boton--peligro{background:var(--color-error);border-color:var(--color-error);color:#fff}.boton--peligro:hover{filter:brightness(.95)}.boton--whatsapp{border-color:#25d366;color:var(--color-texto)}.boton--whatsapp:hover{background:#25d3661f}.boton--telegram{border-color:#229ed9;color:var(--color-texto)}.boton--telegram:hover{background:#229ed91f}.boton--llamar{border-color:var(--color-solfeo);color:var(--color-texto)}.boton--llamar:hover{background:var(--color-solfeo-suave)}.boton--icono{padding:var(--esp-2);min-width:var(--toque-min);font-size:var(--fs-lg)}.boton--bloque{width:100%}.boton-offline{min-height:var(--toque-min);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--esp-1);border-radius:var(--radio);padding:var(--esp-2) var(--esp-3);font:inherit;font-weight:var(--peso-semi);cursor:pointer;border:1px solid var(--color-borde-fuerte);background:var(--color-superficie);color:var(--color-texto);transition:background-color var(--transicion),border-color var(--transicion),color var(--transicion)}.boton-offline:disabled{cursor:default}.boton-offline--neutro{color:var(--color-texto-sec)}.boton-offline--descargando{border-color:var(--color-primario);color:var(--color-primario);background:var(--color-primario-suave)}.boton-offline--ok{background:var(--color-exito);border-color:var(--color-exito);color:#fff}.boton-offline--caducado{border-color:var(--color-aviso);color:var(--color-aviso);background:var(--color-aviso-suave)}.boton-offline__barra{display:block;width:100%;height:4px;margin-top:var(--esp-1);background:var(--color-borde);border-radius:var(--radio-completo);overflow:hidden}.boton-offline__barra>span{display:block;height:100%;background:var(--color-primario);border-radius:var(--radio-completo);transition:width var(--transicion)}input,select,textarea{font:inherit;color:var(--color-texto);background:var(--color-superficie);border:1px solid var(--color-borde-fuerte);border-radius:var(--radio-sm);padding:var(--esp-2) var(--esp-3);min-height:var(--toque-min);width:100%;transition:border-color var(--transicion),box-shadow var(--transicion)}textarea{min-height:96px;resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primario);box-shadow:var(--anillo-foco)}input::placeholder,textarea::placeholder{color:var(--color-texto-suave)}input:disabled,select:disabled,textarea:disabled{background:var(--color-superficie-suave);color:var(--color-texto-suave)}input[type=checkbox],input[type=radio]{width:auto;min-height:auto;width:20px;height:20px;accent-color:var(--color-primario)}input[type=range]{accent-color:var(--color-primario)}label{display:inline-flex;flex-wrap:wrap;align-items:center;gap:var(--esp-2);color:var(--color-texto);font-weight:var(--peso-medio)}fieldset{border:1px solid var(--color-borde);border-radius:var(--radio);padding:var(--esp-3) var(--esp-4)}legend{font-weight:var(--peso-semi);padding:0 var(--esp-2)}.campo{display:flex;flex-direction:column;gap:var(--esp-2);margin-bottom:var(--esp-4);font-weight:var(--peso-medio)}.campo--linea{flex-direction:row;flex-wrap:wrap;align-items:center;gap:var(--esp-4)}.badge{display:inline-flex;align-items:center;gap:var(--esp-1);padding:2px var(--esp-2);border-radius:var(--radio-completo);font-size:var(--fs-xs);font-weight:var(--peso-semi);line-height:1.6;background:var(--color-superficie-suave);color:var(--color-texto-sec);border:1px solid transparent}.badge--ok{background:var(--color-exito-suave);color:var(--color-exito)}.badge--aviso{background:var(--color-aviso-suave);color:var(--color-aviso)}.badge--error{background:var(--color-error-suave);color:var(--color-error)}.badge--info{background:var(--color-info-suave);color:var(--color-info)}.badge--violin{background:var(--color-violin-suave);color:var(--color-violin)}.badge--lenguaje{background:var(--color-lenguaje-suave);color:var(--color-lenguaje)}.badge--solfeo{background:var(--color-solfeo-suave);color:var(--color-solfeo)}.badge--pendiente{background:var(--color-aviso-suave);color:var(--color-rec-pendiente)}.badge--recuperada{background:var(--color-exito-suave);color:var(--color-rec-recuperada)}.badge--no-recuperable{background:var(--color-superficie-suave);color:var(--color-rec-no-recuperable)}.etiqueta{display:inline-block;padding:2px var(--esp-2);border-radius:var(--radio-completo);font-size:var(--fs-xs);font-weight:var(--peso-fuerte);letter-spacing:.04em;background:var(--color-primario-suave);color:var(--color-primario);vertical-align:middle}.chip{min-height:36px;display:inline-flex;align-items:center;gap:var(--esp-1);padding:var(--esp-1) var(--esp-3);border:1px solid var(--color-borde-fuerte);border-radius:var(--radio-completo);background:var(--color-superficie);color:var(--color-texto-sec);font:inherit;font-size:var(--fs-sm);font-weight:var(--peso-medio);cursor:pointer;transition:background-color var(--transicion),color var(--transicion),border-color var(--transicion)}.chip:hover{background:var(--color-superficie-suave)}.chip--activo{background:var(--color-primario);border-color:var(--color-primario);color:var(--color-sobre-primario)}.lista,.lista-hoy,.lista-alumnos,.lista-recursos{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--esp-2)}.lista-hoy__item,.lista-alumnos__item{display:flex;align-items:center;gap:var(--esp-3);min-height:var(--toque-min);padding:var(--esp-3) var(--esp-4);background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio);color:var(--color-texto);text-decoration:none;box-shadow:var(--sombra-sm);transition:transform var(--transicion),box-shadow var(--transicion),border-color var(--transicion)}.lista-hoy__item:hover,.lista-alumnos__item:hover{transform:translateY(-1px);box-shadow:var(--sombra);border-color:var(--color-borde-fuerte);text-decoration:none}.lista-hoy__item strong{font-variant-numeric:tabular-nums;min-width:56px}.lista-hoy__item small,.lista-alumnos__item small{color:var(--color-texto-sec)}.lista-alumnos__avatar,.ficha__avatar{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:40px;height:40px;border-radius:var(--radio-completo);background:var(--color-primario-suave);color:var(--color-primario);font-weight:var(--peso-fuerte);font-size:var(--fs-sm);text-transform:uppercase}.ficha__avatar{width:56px;height:56px;font-size:var(--fs-md)}.lista-recursos__item{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio);padding:var(--esp-3) var(--esp-4);box-shadow:var(--sombra-sm)}.lista-recursos__fila{display:flex;align-items:center;gap:var(--esp-3)}.lista-recursos__icono{font-size:var(--fs-xl);line-height:1}.lista-recursos__datos{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.lista-recursos__datos strong{overflow-wrap:anywhere}.lista-recursos__meta{color:var(--color-texto-sec);font-size:var(--fs-sm)}.lista-recursos__acciones{display:flex;align-items:center;gap:var(--esp-2);flex-wrap:wrap}.lista-recursos__vacio{text-align:center;color:var(--color-texto-sec);padding:var(--esp-6);border:1px dashed var(--color-borde-fuerte);border-radius:var(--radio)}.tabla{width:100%;border-collapse:collapse;background:var(--color-superficie);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra-sm)}.tabla th,.tabla td{text-align:left;padding:var(--esp-3) var(--esp-4);border-bottom:1px solid var(--color-borde)}.tabla th{background:var(--color-superficie-suave);font-weight:var(--peso-semi);color:var(--color-texto-sec);font-size:var(--fs-sm)}.tabla tbody tr:last-child td{border-bottom:none}.tabla tbody tr:hover{background:var(--color-superficie-suave)}.modal-fondo{position:fixed;top:0;right:0;bottom:0;left:0;background:#1018288c;display:flex;align-items:center;justify-content:center;padding:var(--esp-4);z-index:100;animation:aparecer var(--transicion)}.modal{background:var(--color-superficie-elevada);border:1px solid var(--color-borde);border-radius:var(--radio-lg);box-shadow:var(--sombra-lg);padding:var(--esp-5);width:100%;max-width:520px;max-height:90vh;overflow:auto}.modal__cabecera{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--esp-4)}.modal__pie{display:flex;justify-content:flex-end;gap:var(--esp-2);margin-top:var(--esp-5)}.estado-vacio{text-align:center;color:var(--color-texto-sec);padding:var(--esp-10) var(--esp-4);border:1px dashed var(--color-borde-fuerte);border-radius:var(--radio-lg);background:var(--color-superficie)}.estado-vacio__icono{font-size:2.5rem;opacity:.6;display:block;margin-bottom:var(--esp-2)}.estado-vacio__titulo{color:var(--color-texto);margin-bottom:var(--esp-1)}.cargando{color:var(--color-texto-sec);display:inline-flex;align-items:center;gap:var(--esp-2)}.skeleton{display:block;background:linear-gradient(90deg,var(--color-superficie-suave) 25%,var(--color-borde) 37%,var(--color-superficie-suave) 63%);background-size:400% 100%;border-radius:var(--radio-sm);animation:skeleton-brillo 1.4s ease infinite}.skeleton--texto{height:.9em;margin:.3em 0}.skeleton--titulo{height:1.4em;width:60%}.skeleton--bloque{height:80px}@keyframes skeleton-brillo{0%{background-position:100% 50%}to{background-position:0 50%}}.mensaje-error{color:var(--color-error);font-weight:var(--peso-semi)}.mensaje-ok{color:var(--color-exito);font-weight:var(--peso-semi)}.mensaje-info{color:var(--color-texto-sec)}.indicador{font-size:var(--fs-sm);font-weight:var(--peso-semi);display:inline-flex;align-items:center;gap:var(--esp-1)}.indicador--online{color:var(--color-exito)}.indicador--offline{color:var(--color-inactivo)}.indicador--sincronizando{color:var(--color-primario);animation:parpadeo 1.2s ease-in-out infinite}@keyframes parpadeo{50%{opacity:.4}}.indicador__boton-sync{margin-left:var(--esp-2);padding:var(--esp-1) var(--esp-3);min-height:32px;font-size:var(--fs-xs);font-weight:var(--peso-semi);color:var(--color-sobre-primario);background:var(--color-primario);border:none;border-radius:var(--radio-completo);cursor:pointer;transition:background-color var(--transicion)}.indicador__boton-sync:hover{background:var(--color-primario-hover)}.indicador__boton-sync:focus-visible{outline:none;box-shadow:var(--anillo-foco)}.conmutador-tema{display:inline-flex;align-items:center;justify-content:center;width:var(--toque-min);height:var(--toque-min);border-radius:var(--radio-completo);border:1px solid var(--color-borde-fuerte);background:var(--color-superficie);color:var(--color-texto);font-size:var(--fs-lg);line-height:1;cursor:pointer;transition:background-color var(--transicion),border-color var(--transicion),transform var(--transicion)}.conmutador-tema:hover{background:var(--color-superficie-suave)}.conmutador-tema:active{transform:scale(.94)}.conmutador-tema__icono{display:block;line-height:1}.aviso-legal{border:1px solid var(--color-aviso);background:var(--color-aviso-suave);border-radius:var(--radio);padding:var(--esp-4);margin:var(--esp-4) 0}.aviso-legal__titulo{color:var(--color-aviso);font-weight:var(--peso-fuerte);margin:0 0 var(--esp-2)}.aviso-legal__check{display:flex;align-items:flex-start;gap:var(--esp-2);margin-top:var(--esp-3);font-weight:var(--peso-medio)}.barra-progreso{height:8px;background:var(--color-borde);border-radius:var(--radio-completo);overflow:hidden}.barra-progreso>span{display:block;height:100%;background:var(--color-primario);transition:width var(--transicion)}.login{max-width:380px;margin:10vh auto;display:flex;flex-direction:column;gap:var(--esp-4);background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-6);box-shadow:var(--sombra-md)}.login label{flex-direction:column;align-items:stretch}.login .boton{width:100%}.ficha{display:flex;flex-direction:column;gap:var(--esp-4)}.ficha__cabecera{display:flex;align-items:center;gap:var(--esp-4);flex-wrap:wrap;background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-4);box-shadow:var(--sombra-sm)}.ficha__meta{color:var(--color-texto-sec);margin:var(--esp-1) 0 0}.ficha__offline{margin-left:auto}.ficha__seccion{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio);padding:var(--esp-4);box-shadow:var(--sombra-sm)}.contacto{display:flex;align-items:center;justify-content:space-between;gap:var(--esp-3);flex-wrap:wrap;padding:var(--esp-3) 0;border-bottom:1px solid var(--color-borde)}.contacto:last-child{border-bottom:none}.contacto__info{display:flex;flex-direction:column;gap:2px}.contacto__relacion{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--color-texto-suave)}.contacto__tel{color:var(--color-texto-sec);font-variant-numeric:tabular-nums}.contacto__acciones{display:flex;align-items:center;gap:var(--esp-2);flex-wrap:wrap}.detalle-sesion__acciones{display:flex;gap:var(--esp-2);flex-wrap:wrap;margin-top:var(--esp-4)}.recuperaciones{display:flex;flex-direction:column;gap:var(--esp-4)}.recuperaciones__cabecera{display:flex;align-items:center;justify-content:space-between;gap:var(--esp-3);flex-wrap:wrap}.recuperaciones__columnas{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--esp-4)}.columna{display:flex;flex-direction:column;gap:var(--esp-3);background:var(--color-superficie-suave);border-radius:var(--radio);padding:var(--esp-3)}.columna>h3{margin:0;padding-bottom:var(--esp-2);border-bottom:3px solid var(--color-borde-fuerte)}.tarjeta-recuperacion{background:var(--color-superficie);border:1px solid var(--color-borde);border-left:4px solid var(--color-borde-fuerte);border-radius:var(--radio);padding:var(--esp-3) var(--esp-4);box-shadow:var(--sombra-sm);display:flex;flex-direction:column;gap:var(--esp-2)}.tarjeta-recuperacion__motivo{margin:0;color:var(--color-texto-sec)}.tarjeta-recuperacion__fecha{margin:0;font-size:var(--fs-sm);color:var(--color-texto-suave)}.tarjeta-recuperacion__acciones{display:flex;gap:var(--esp-2);flex-wrap:wrap;margin-top:var(--esp-1)}.gestor-recursos{display:flex;flex-direction:column;gap:var(--esp-4)}.gestor-recursos__cabecera{display:flex;flex-direction:column;gap:var(--esp-3)}.gestor-recursos__filtros{display:flex;align-items:center;gap:var(--esp-2);flex-wrap:wrap}.importar-yt{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-5);box-shadow:var(--sombra-sm)}.importar-yt__progreso{color:var(--color-primario);font-weight:var(--peso-medio)}.reproductor{margin-top:var(--esp-3);padding:var(--esp-3);background:var(--color-superficie-suave);border-radius:var(--radio);display:flex;flex-direction:column;gap:var(--esp-2)}.reproductor audio,.reproductor video{width:100%;border-radius:var(--radio-sm)}.reproductor__badge{align-self:flex-start;display:inline-flex;align-items:center;gap:var(--esp-1);padding:2px var(--esp-2);border-radius:var(--radio-completo);font-size:var(--fs-xs);font-weight:var(--peso-semi);background:var(--color-exito-suave);color:var(--color-exito)}.reproductor__pdf{display:flex;flex-direction:column;gap:var(--esp-2)}.reproductor__iframe{width:100%;height:70vh;border:1px solid var(--color-borde);border-radius:var(--radio-sm);background:var(--color-superficie)}.estudio__pestanas{display:flex;gap:var(--esp-2);margin:var(--esp-3) 0 var(--esp-4)}.estudio__pestana{flex:1;min-height:var(--toque-min);padding:var(--esp-2) var(--esp-3);border:1px solid var(--color-borde-fuerte);border-radius:var(--radio);background:var(--color-superficie);color:var(--color-texto-sec);font:inherit;font-weight:var(--peso-semi);cursor:pointer;transition:background-color var(--transicion),color var(--transicion),border-color var(--transicion)}.estudio__pestana:hover{background:var(--color-superficie-suave)}.estudio__pestana--activa{background:var(--color-primario);border-color:var(--color-primario);color:var(--color-sobre-primario)}.estudio__panel{margin-top:var(--esp-2)}.afinador,.metronomo{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-5);text-align:center;box-shadow:var(--sombra-sm)}.afinador__titulo,.metronomo__titulo{margin:0 0 var(--esp-4);font-size:var(--fs-lg)}.afinador__nota{display:flex;align-items:baseline;justify-content:center;gap:2px;line-height:1;margin:var(--esp-2) 0;color:var(--color-texto)}.afinador__nota--afinada{color:var(--color-exito)}.afinador__nombre{font-size:4rem;font-weight:var(--peso-fuerte)}.afinador__nombre--vacio{color:var(--color-inactivo)}.afinador__octava{font-size:1.75rem;font-weight:var(--peso-semi);color:var(--color-texto-sec)}.afinador__medidor{position:relative;height:48px;margin:var(--esp-3) 0;border:1px solid var(--color-borde);border-radius:var(--radio);background:linear-gradient(90deg,var(--color-superficie-suave),var(--color-superficie-suave) 47%,var(--color-solfeo-suave) 47%,var(--color-solfeo-suave) 53%,var(--color-superficie-suave) 53%);overflow:hidden}.afinador__centro{position:absolute;top:4px;bottom:4px;left:50%;width:2px;transform:translate(-50%);background:var(--color-borde-fuerte)}.afinador__aguja{position:absolute;top:4px;bottom:4px;width:4px;margin-left:-2px;border-radius:var(--radio-completo);background:var(--color-aviso);transition:left .08s linear}.afinador__aguja--afinada{background:var(--color-exito)}.afinador__detalle{display:flex;justify-content:space-between;font-size:var(--fs-sm);color:var(--color-texto-sec);min-height:20px}.afinador__cents{color:var(--color-aviso);font-weight:var(--peso-semi)}.afinador__cents--ok{color:var(--color-exito);font-weight:var(--peso-semi)}.afinador__cuerdas{display:flex;justify-content:space-around;gap:var(--esp-2);list-style:none;padding:0;margin:var(--esp-4) 0}.afinador__cuerda{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--esp-3) var(--esp-1);border:1px solid var(--color-borde);border-radius:var(--radio);color:var(--color-texto-sec);background:var(--color-superficie)}.afinador__cuerda strong{font-size:var(--fs-lg);color:var(--color-texto)}.afinador__cuerda small{color:var(--color-inactivo)}.afinador__cuerda--activa{border-color:var(--color-primario);background:var(--color-primario-suave);color:var(--color-primario)}.afinador__cuerda--activa strong,.afinador__cuerda--activa small{color:var(--color-primario)}.afinador__controles,.metronomo__controles{display:flex;justify-content:center;gap:var(--esp-2);margin-top:var(--esp-3)}.afinador__ayuda{margin:var(--esp-3) 0 0;font-size:var(--fs-sm);color:var(--color-texto-sec)}.metronomo__pulsos{display:flex;justify-content:center;gap:var(--esp-3);margin:var(--esp-2) 0 var(--esp-4)}.metronomo__pulso{width:20px;height:20px;border-radius:var(--radio-completo);background:var(--color-borde);transition:transform .05s linear,background .05s linear}.metronomo__pulso--acento{background:var(--color-inactivo)}.metronomo__pulso--activo{background:var(--color-primario);transform:scale(1.4)}.metronomo__pulso--acento.metronomo__pulso--activo{background:var(--color-aviso)}.metronomo__bpm{display:flex;align-items:baseline;justify-content:center;gap:var(--esp-2);margin:var(--esp-2) 0 var(--esp-4)}.metronomo__bpm-valor{font-size:3rem;font-weight:var(--peso-fuerte)}.metronomo__bpm-unidad{font-size:var(--fs-md);color:var(--color-texto-sec)}.metronomo__campo{display:flex;align-items:center;gap:var(--esp-2);margin:var(--esp-3) 0}.metronomo__campo>label{width:64px;text-align:left;font-weight:var(--peso-semi);color:var(--color-texto-sec)}.metronomo__slider{flex:1;min-height:var(--toque-min)}.metronomo__numero{width:72px;min-height:var(--toque-min);text-align:center}.metronomo__select{flex:1;min-height:var(--toque-min)}.evento--recuperacion{background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.28),rgba(255,255,255,.28) 4px,transparent 4px,transparent 8px)}.calendario{background:var(--color-superficie);border:1px solid var(--color-borde);border-radius:var(--radio-lg);padding:var(--esp-3);box-shadow:var(--sombra-sm);--fc-border-color: var(--color-borde);--fc-page-bg-color: var(--color-superficie);--fc-neutral-bg-color: var(--color-superficie-suave);--fc-neutral-text-color: var(--color-texto-sec);--fc-today-bg-color: var(--color-primario-suave);--fc-now-indicator-color: var(--color-error);--fc-event-bg-color: var(--color-primario);--fc-event-border-color: var(--color-primario);--fc-event-text-color: #ffffff;--fc-list-event-hover-bg-color: var(--color-superficie-suave);--fc-highlight-color: var(--color-primario-suave);--fc-non-business-color: var(--color-superficie-suave)}.calendario .fc{color:var(--color-texto)}.calendario .fc .fc-col-header-cell-cushion,.calendario .fc .fc-timegrid-slot-label-cushion,.calendario .fc .fc-daygrid-day-number{color:var(--color-texto-sec)}.calendario .fc .fc-toolbar-title{color:var(--color-texto);font-size:var(--fs-lg)}.calendario .fc .fc-button{background:var(--color-superficie);border:1px solid var(--color-borde-fuerte);color:var(--color-texto);font-weight:var(--peso-semi);text-transform:none;box-shadow:none;padding:var(--esp-2) var(--esp-3)}.calendario .fc .fc-button:hover{background:var(--color-superficie-suave)}.calendario .fc .fc-button-primary:not(:disabled).fc-button-active,.calendario .fc .fc-button-primary:not(:disabled):active{background:var(--color-primario);border-color:var(--color-primario);color:var(--color-sobre-primario)}.calendario .fc .fc-button:focus-visible{outline:none;box-shadow:var(--anillo-foco)}.calendario .fc .fc-button-primary:disabled{opacity:.5}.calendario .fc .fc-event{border-radius:var(--radio-sm);padding:1px 4px;font-weight:var(--peso-medio);font-size:var(--fs-sm)}*{scrollbar-width:thin;scrollbar-color:var(--color-borde-fuerte) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--color-borde-fuerte);border-radius:var(--radio-completo);border:2px solid var(--color-fondo)}*::-webkit-scrollbar-thumb:hover{background:var(--color-texto-suave)}.sr-solo{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}:root:root{--fuente-base: "Geist", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--color-fondo: oklch(.985 .002 75);--color-superficie: oklch(1 0 0);--color-superficie-elevada: oklch(1 0 0);--color-superficie-suave: oklch(.955 .008 60);--color-tarjeta: var(--color-superficie);--color-borde: oklch(.905 .01 60);--color-borde-fuerte: oklch(.86 .012 60);--color-texto: oklch(.145 .005 30);--color-texto-sec: oklch(.5 .01 50);--color-texto-suave: oklch(.6 .01 50);--color-inactivo: oklch(.68 .01 50);--color-sobre-primario: oklch(1 0 0);--color-primario: oklch(.65 .19 48);--color-primario-hover: oklch(.6 .19 48);--color-primario-activo: oklch(.55 .18 48);--color-primario-oscuro: oklch(.55 .18 48);--color-primario-suave: oklch(.94 .035 55);--color-primario-borde: oklch(.88 .05 55);--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-violin: oklch(.65 .19 48);--color-violin-suave: oklch(.94 .035 55);--radio-sm: .4rem;--radio: .625rem;--radio-lg: .9rem;--color-foco: var(--color-primario);--anillo-foco: 0 0 0 3px oklch(.65 .19 48 / .4)}:root:root[data-tema=oscuro]{--color-fondo: oklch(.155 .015 260);--color-superficie: oklch(.195 .015 255);--color-superficie-elevada: oklch(.225 .015 255);--color-superficie-suave: oklch(.24 .015 255);--color-tarjeta: var(--color-superficie);--color-borde: oklch(1 0 0 / 12%);--color-borde-fuerte: oklch(1 0 0 / 20%);--color-texto: oklch(.94 .005 250);--color-texto-sec: oklch(.65 .01 250);--color-texto-suave: oklch(.6 .01 250);--color-inactivo: oklch(.55 .01 250);--color-sobre-primario: oklch(.13 .01 260);--color-primario: oklch(.72 .19 50);--color-primario-hover: oklch(.78 .19 50);--color-primario-activo: oklch(.82 .18 50);--color-primario-oscuro: oklch(.82 .18 50);--color-primario-suave: oklch(.27 .04 50);--color-primario-borde: oklch(.4 .08 50);--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-violin: oklch(.72 .19 50);--color-violin-suave: oklch(.27 .04 50);--anillo-foco: 0 0 0 3px oklch(.72 .19 50 / .5);color-scheme:dark}@media(prefers-color-scheme:dark){:root:root[data-tema=sistema]{--color-fondo: oklch(.155 .015 260);--color-superficie: oklch(.195 .015 255);--color-superficie-elevada: oklch(.225 .015 255);--color-superficie-suave: oklch(.24 .015 255);--color-tarjeta: var(--color-superficie);--color-borde: oklch(1 0 0 / 12%);--color-borde-fuerte: oklch(1 0 0 / 20%);--color-texto: oklch(.94 .005 250);--color-texto-sec: oklch(.65 .01 250);--color-texto-suave: oklch(.6 .01 250);--color-inactivo: oklch(.55 .01 250);--color-sobre-primario: oklch(.13 .01 260);--color-primario: oklch(.72 .19 50);--color-primario-hover: oklch(.78 .19 50);--color-primario-activo: oklch(.82 .18 50);--color-primario-oscuro: oklch(.82 .18 50);--color-primario-suave: oklch(.27 .04 50);--color-primario-borde: oklch(.4 .08 50);--color-info: var(--color-primario);--color-info-suave: var(--color-primario-suave);--color-violin: oklch(.72 .19 50);--color-violin-suave: oklch(.27 .04 50);--anillo-foco: 0 0 0 3px oklch(.72 .19 50 / .5);color-scheme:dark}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:modal-overlay-aparece .15s ease-out}.modal{width:100%;max-width:32rem;max-height:calc(100dvh - 2rem);display:flex;flex-direction:column;background:var(--color-superficie-elevada);color:var(--color-texto);border:1px solid var(--color-borde);border-radius:var(--radio-lg);box-shadow:0 10px 38px #00000040,0 4px 12px #00000026;animation:modal-aparece .16s ease-out;outline:none}.modal__cabecera{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem .75rem}.modal__titulo{margin:0;font-size:1.125rem;font-weight:600;line-height:1.3;color:var(--color-texto)}.modal__cerrar{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;margin:-.25rem -.5rem 0 0;font-size:1.4rem;line-height:1;color:var(--color-texto-sec);background:transparent;border:none;border-radius:var(--radio-sm);cursor:pointer;transition:background .12s,color .12s}.modal__cerrar:hover{background:var(--color-superficie-suave);color:var(--color-texto)}.modal__cerrar:focus-visible{outline:none;box-shadow:var(--anillo-foco)}.modal__cuerpo{padding:.5rem 1.5rem 1.25rem;overflow-y:auto}.modal__pie{display:flex;align-items:center;justify-content:flex-end;gap:.625rem;padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--color-borde)}@keyframes modal-overlay-aparece{0%{opacity:0}to{opacity:1}}@keyframes modal-aparece{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.formulario{display:flex;flex-direction:column;gap:1rem}.formulario__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.formulario__grid--una{grid-template-columns:1fr}.campo{display:flex;flex-direction:column;gap:.375rem;min-width:0}.campo--ancho-completo{grid-column:1 / -1}.campo__etiqueta{font-size:.875rem;font-weight:500;line-height:1.2;color:var(--color-texto)}.campo__etiqueta--requerido:after{content:" *";color:var(--color-primario)}.campo__control,.campo input,.campo select,.campo textarea{width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.9375rem;line-height:1.4;color:var(--color-texto);background:var(--color-superficie);border:1px solid var(--color-borde-fuerte);border-radius:var(--radio);transition:border-color .12s,box-shadow .12s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.campo textarea{min-height:5rem;resize:vertical}.campo__control:focus,.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--color-primario);box-shadow:var(--anillo-foco)}.campo__control:disabled,.campo input:disabled,.campo select:disabled,.campo textarea:disabled{opacity:.6;cursor:not-allowed}.campo__ayuda{font-size:.8125rem;color:var(--color-texto-suave)}.campo__error{font-size:.8125rem;color:#cc272e}.campo--con-error .campo__control,.campo--con-error input,.campo--con-error select,.campo--con-error textarea{border-color:#cc272e}.campo--checkbox{flex-direction:row;align-items:center;gap:.5rem}.campo--checkbox input{width:auto}.acciones-fila{display:flex;align-items:center;justify-content:flex-end;gap:.625rem}.boton{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;font-family:inherit;font-size:.9375rem;font-weight:500;line-height:1.2;border:1px solid transparent;border-radius:var(--radio);cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.boton:focus-visible{outline:none;box-shadow:var(--anillo-foco)}.boton:disabled{opacity:.6;cursor:not-allowed}.boton--primario{background:var(--color-primario);color:var(--color-sobre-primario)}.boton--primario:hover:not(:disabled){background:var(--color-primario-hover)}.boton--primario:active:not(:disabled){background:var(--color-primario-activo)}.boton--ghost{background:transparent;color:var(--color-texto-sec)}.boton--ghost:hover:not(:disabled){background:var(--color-superficie-suave);color:var(--color-texto)}.boton--contorno{background:var(--color-superficie);color:var(--color-texto);border-color:var(--color-borde-fuerte)}.boton--contorno:hover:not(:disabled){background:var(--color-superficie-suave)}.boton--peligro{background:#cc272e;color:#fff}.boton--peligro:hover:not(:disabled){background:#bb061e}.cabecera{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.625rem 1rem;background:var(--color-superficie);border-bottom:1px solid var(--color-borde)}.cabecera__marca{display:inline-flex;align-items:center;gap:.5rem;justify-self:start;min-width:0}.cabecera__logo{height:2rem;width:auto;display:block;object-fit:contain}.cabecera__logo--oscuro{display:none}:root[data-tema=oscuro] .cabecera__logo--claro{display:none}:root[data-tema=oscuro] .cabecera__logo--oscuro{display:block}@media(prefers-color-scheme:dark){:root[data-tema=sistema] .cabecera__logo--claro{display:none}:root[data-tema=sistema] .cabecera__logo--oscuro{display:block}}.cabecera__guion{color:var(--color-texto-suave);font-weight:400}.cabecera__sede{font-size:1rem;font-weight:600;color:var(--color-texto);white-space:nowrap}.cabecera__titulo{justify-self:center;margin:0;font-size:1.05rem;font-weight:600;color:var(--color-texto);white-space:nowrap}.cabecera__fin{justify-self:end}@media(max-width:540px){.cabecera{gap:.5rem;padding:.5rem .75rem}.cabecera__logo{height:1.5rem}.cabecera__sede{font-size:.875rem}.cabecera__titulo{font-size:.9375rem}}@media(max-width:360px){.cabecera__guion,.cabecera__sede{display:none}}.toast-pwa{position:fixed;left:50%;bottom:calc(5.5rem + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:2000;display:flex;align-items:center;gap:.75rem;max-width:calc(100vw - 2rem);padding:.75rem 1rem;background:var(--color-superficie-elevada);color:var(--color-texto);border:1px solid var(--color-borde);border-radius:var(--radio);box-shadow:0 8px 28px #00000038;animation:toast-pwa-aparece .2s ease-out}.toast-pwa__texto{font-size:.9375rem;line-height:1.3}.toast-pwa__acciones{display:inline-flex;align-items:center;gap:.5rem;margin-left:.25rem}.toast-pwa .boton{padding:.375rem .75rem;font-size:.875rem}@keyframes toast-pwa-aparece{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}@media(max-width:480px){.toast-pwa{flex-direction:column;align-items:stretch;text-align:center}.toast-pwa__acciones{justify-content:center}}.calendario__barra{display:flex;justify-content:flex-end;margin-bottom:.75rem}@media(max-width:480px){.calendario__barra .boton{width:100%}}.evento--cancelada{opacity:.55}.evento--cancelada .fc-event-title,.evento--cancelada .fc-event-time{text-decoration:line-through}.recuperaciones__resumen{margin:0 0 1rem;padding:.625rem .875rem;font-size:.9375rem;font-weight:500;color:var(--color-texto);background:var(--color-superficie-suave);border:1px solid var(--color-borde);border-radius:var(--radio)}
