:root{--font-sans:"Satoshi", "Inter", system-ui, -apple-system, sans-serif;--font-display:"Instrument Serif", Georgia, serif;--color-brand:#01696f;--color-brand-hover:#0c4e54;--color-brand-muted:#e6f0f0;--color-bg:#f7f6f2;--color-surface:#f9f8f5;--color-surface-elevated:#fff;--color-text:#28251d;--color-text-muted:#7a7974;--color-border:#d4d1ca;--color-success:#15803d;--color-error:#b91c1c;--color-warning-bg:#fef3c7;--color-warning-text:#92400e;--shadow-sm:0 1px 2px oklch(20% .01 80/.06);--shadow-md:0 4px 12px oklch(20% .01 80/.08);--radius:.5rem;--radius-lg:.75rem;--header-h:3.5rem;--admin-nav-w:14rem;--transition-interactive:.18s cubic-bezier(.16, 1, .3, 1);font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:1.5}[data-theme=dark]{--color-brand:#4f98a3;--color-brand-hover:#227f8b;--color-brand-muted:#1e3338;--color-bg:#171614;--color-surface:#1c1b19;--color-surface-elevated:#242320;--color-text:#cdccca;--color-text-muted:#797876;--color-border:#393836;--color-success:#4ade80;--color-error:#f87171;--color-warning-bg:#422006;--color-warning-text:#fcd34d;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000059}*,:before,:after{box-sizing:border-box}body{background:var(--color-bg);min-height:100vh;color:var(--color-text);margin:0}a{color:var(--color-brand);text-decoration:none}a:hover{text-decoration:underline}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-shell__body{flex:1;min-height:0;display:flex}.app-shell__body--admin{position:relative}.app-shell__main{flex:1;min-width:0}.header{z-index:100;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0}.header__inner{max-width:72rem;height:var(--header-h);align-items:center;gap:1rem;margin:0 auto;padding:0 1rem;display:flex}.header__brand{color:var(--color-brand);white-space:nowrap;font-weight:700;text-decoration:none}.header__version{color:var(--color-text-muted);margin-left:.35rem;font-size:.75rem;font-weight:400}.header__nav{flex:1;gap:.5rem;display:flex;overflow-x:auto}.header__link{border-radius:var(--radius);color:var(--color-text);white-space:nowrap;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.9rem;text-decoration:none;display:inline-flex}.header__link:hover,.header__link.active{background:var(--color-brand-muted);color:var(--color-brand);text-decoration:none}.header__link--muted{color:var(--color-text-muted)}.header__actions{align-items:center;gap:.35rem;display:flex}.icon-btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:2.25rem;height:2.25rem;color:var(--color-text);cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{background:var(--color-brand-muted)}.footer{border-top:1px solid var(--color-border);background:var(--color-surface);margin-top:auto}.footer__inner{max-width:72rem;color:var(--color-text-muted);margin:0 auto;padding:1rem;font-size:.85rem}.admin-nav__toggle{z-index:120;background:var(--color-brand);color:#fff;width:3rem;height:3rem;box-shadow:var(--shadow-md);cursor:pointer;border:none;border-radius:50%;display:none;position:fixed;bottom:1rem;right:1rem}.admin-nav{width:var(--admin-nav-w);background:var(--color-surface);border-right:1px solid var(--color-border);min-height:calc(100vh - var(--header-h));flex-direction:column;flex-shrink:0;padding:1rem .75rem;display:flex}.admin-nav__footer{border-top:1px solid var(--color-border);margin-top:auto;padding-top:1rem}.admin-nav__logout{justify-content:flex-start;width:100%}.admin-nav__title{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin:0 .5rem .75rem;font-size:.8rem}.admin-nav__link{border-radius:var(--radius);color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:.15rem;padding:.55rem .65rem;font-size:.9rem;text-decoration:none;display:flex}.admin-nav__link:hover,.admin-nav__link.active{background:var(--color-brand-muted);color:var(--color-brand);text-decoration:none}.admin-nav__backdrop{display:none}@media (width<=768px){.admin-nav__toggle{justify-content:center;align-items:center;display:inline-flex}.admin-nav{top:var(--header-h);z-index:110;box-shadow:var(--shadow-md);transition:transform .2s;position:fixed;bottom:0;left:0;transform:translate(-100%)}.admin-nav--open{transform:translate(0)}.admin-nav__backdrop{inset:var(--header-h) 0 0 0;z-index:105;background:#00000059;display:block;position:fixed}}.page{max-width:48rem;margin:0 auto;padding:1.5rem 1rem 2.5rem}.page--wide{max-width:72rem}.page--centered{min-height:calc(100vh - var(--header-h) - 5rem);justify-content:center;align-items:center;display:flex}.page--flush-top{padding-top:0}.admin-page{max-width:none;padding:1.25rem 1rem 2rem}.muted{color:var(--color-text-muted);font-size:.9rem}.ok{color:var(--color-success)}.err{color:var(--color-error)}.banner{background:var(--color-warning-bg);color:var(--color-warning-text);border-radius:var(--radius);padding:.6rem .85rem;font-size:.9rem}.hero{align-items:center;min-height:max(42vh,22rem);margin-bottom:1rem;display:flex;position:relative;overflow:hidden}.hero__media,.hero__carousel{position:absolute;inset:0}.hero__video{object-fit:cover;width:100%;height:100%}.hero__video--slot{opacity:0;transition:opacity 1s;position:absolute;inset:0}.hero__video--visible,.hero--video-ready .hero__video--visible{opacity:1}.hero:not(.hero--video-ready) .hero__video--visible{opacity:0}.hero__fallback{z-index:0;background:linear-gradient(135deg,#01696f 0%,#024a50 45%,#0a2e33 100%);animation:12s ease-in-out infinite alternate hero-shift;position:absolute;inset:0}.hero--video-ready .hero__fallback{opacity:.35}@keyframes hero-shift{0%{filter:hue-rotate()}to{filter:hue-rotate(12deg)}}.hero__overlay{z-index:1;background:linear-gradient(105deg,#0c262aeb 0%,#0c262ab8 42%,#0c262a73 100%);position:absolute;inset:0}.hero__content{z-index:2;color:#fff;max-width:72rem;margin:0 auto;padding:2.5rem 1rem;position:relative}.hero__content h1{max-width:36rem;margin:0 0 .75rem;font-size:clamp(1.5rem,3vw,2.25rem)}.hero__subtitle{opacity:.92;max-width:36rem;margin:0 0 1rem}.hero__bullets{flex-wrap:wrap;gap:.75rem 1.5rem;margin:0;padding:0;font-size:.9rem;list-style:none;display:flex}.hero__bullets li{align-items:center;gap:.35rem;display:inline-flex}.hero__ctas{flex-wrap:wrap;gap:.65rem;margin-top:1.25rem;display:flex}.hero__ctas a{text-decoration:none}.hero__ctas .btn--primary{color:#0c4e54;background:#fff;border-color:#fff;font-weight:600}.hero__ctas .btn--primary:hover{color:#0c4e54;background:#e8f4f5}.hero__ctas .btn--hero-secondary{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:1px solid #ffffff8c}.hero__ctas .btn--hero-secondary:hover{color:#fff;background:#ffffff38;border-color:#ffffffbf}@media (prefers-reduced-motion:reduce){.hero__video--slot{transition:none}.hero__video{display:none}.hero__fallback{animation:none}}.hero__carousel-dots{z-index:2;gap:.35rem;display:flex;position:absolute;bottom:1rem;right:1rem}.hero__carousel-dot{background:#ffffff59;border-radius:50%;width:.45rem;height:.45rem}.hero__carousel-dot--active{background:#ffffffe6}.btn{border-radius:var(--radius);font:inherit;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;text-decoration:none;display:inline-flex}.btn--primary{background:var(--color-brand);color:#fff}.btn--primary:hover{background:var(--color-brand-hover)}.btn{transition:background var(--transition-interactive), border-color var(--transition-interactive), color var(--transition-interactive), box-shadow var(--transition-interactive)}.btn--secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.btn--ghost{color:var(--color-text);background:0 0}.btn--ghost:hover{background:var(--color-brand-muted)}.btn--danger{background:var(--color-error);color:#fff}.btn:disabled{opacity:.55;cursor:not-allowed}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-interactive), box-shadow var(--transition-interactive)}.card--padded{padding:1rem}.badge{vertical-align:middle;text-transform:capitalize;border-radius:999px;margin-left:.35rem;padding:.15rem .45rem;font-size:.72rem;font-weight:600;display:inline-block}.badge--default,.badge--validado{background:var(--color-brand-muted);color:var(--color-brand)}.badge--activo{color:#0c4e54;background:#d4ecee;border:1px solid #9fd0d5}.badge--archivado,.badge--inactivo{color:#475569;background:#e2e8f0}[data-theme=dark] .badge--archivado,[data-theme=dark] .badge--inactivo{color:#cbd5e1;background:#2a3f44}.badge--en-curso{color:#1d4ed8;background:#dbeafe}[data-theme=dark] .badge--en-curso{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .badge--activo{color:#7ec8cf;background:#1a3d42;border-color:#2a5f66}.field{flex-direction:column;gap:.35rem;display:flex}.field__label{font-size:.9rem;font-weight:500}.field__error{color:var(--color-error);font-size:.8rem}.input,.textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font:inherit;padding:.55rem .65rem}.input--error,.textarea.input--error{border-color:var(--color-error)}.textarea{resize:vertical;min-height:5rem}.form-stack{flex-direction:column;gap:.85rem;max-width:24rem;display:flex}.progress__header{justify-content:space-between;margin-bottom:.35rem;font-size:.85rem;display:flex}.progress__track{background:var(--color-border);border-radius:999px;height:.55rem;overflow:hidden}.progress__fill{background:var(--color-brand);border-radius:999px;height:100%;transition:width .6s cubic-bezier(.16,1,.3,1)}.spinner{color:var(--color-text-muted);align-items:center;gap:.5rem;padding:1rem 0;display:flex}.spinner__icon{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--color-text-muted);padding:2rem 1rem}.empty-state h3{color:var(--color-text);margin:0 0 .5rem}.modal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:min(100%,28rem);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.modal__header{justify-content:space-between;align-items:center;padding:1rem 1rem .5rem;display:flex}.modal__header h2{margin:0;font-size:1.1rem}.modal__close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem}.modal__body{padding:.5rem 1rem 1rem}.modal__footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.5rem;padding:.75rem 1rem 1rem;display:flex}.toast-stack{z-index:300;flex-direction:column;gap:.5rem;max-width:min(22rem,100vw - 2rem);display:flex;position:fixed;bottom:1rem;right:1rem}.toast{border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.65rem .85rem;font-size:.9rem;animation:.2s toast-in}.toast--success{color:#166534;background:#dcfce7}.toast--error{color:#991b1b;background:#fee2e2}.toast--info{background:var(--color-surface-elevated);border:1px solid var(--color-border)}[data-theme=dark] .toast--success{color:#bbf7d0;background:#14532d}[data-theme=dark] .toast--error{color:#fecaca;background:#7f1d1d}@keyframes toast-in{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.programa-list{gap:.85rem;padding:0;list-style:none;display:grid}@media (width>=640px){.programa-list--grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1024px){.programa-list--grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.programa-card__cta,.programa-card__actions{margin-top:.75rem}.catalog-title{font-family:var(--font-display);margin:0 0 1rem;font-weight:400}.programa-card h2,.programa-card h3{margin:0 0 .35rem}.modulo-list{padding-left:1.25rem}.modulo-list li.inactive{opacity:.6}.stats{color:var(--color-text-muted);font-size:.85rem}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:.85rem;margin-bottom:1.5rem;display:grid}.kpi-grid .card strong{color:var(--color-text-muted);margin-bottom:.25rem;font-size:.85rem;display:block}.kpi-grid .card p{color:var(--color-brand);margin:0;font-size:1.35rem;font-weight:700}.kpi-grid--loading{opacity:.72;pointer-events:none}.tracker-table{border-collapse:collapse;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;font-size:.88rem;overflow:hidden}.tracker-table th,.tracker-table td{border-bottom:1px solid var(--color-border);text-align:left;padding:.55rem .65rem}.tracker-table th{background:var(--color-brand-muted);font-weight:600}.tracker-wrap{overflow-x:auto}.section-title{margin:1.5rem 0 .75rem;font-size:1.1rem}.admin-section{margin-bottom:1.25rem}.section-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.section-header .section-title{margin:0}.admin-tabs{flex-wrap:wrap;gap:.35rem;margin:1rem 0;display:flex}.admin-tabs__btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;font:inherit;padding:.45rem .85rem}.admin-tabs__btn--active{background:var(--color-brand-muted);border-color:var(--color-brand);color:var(--color-brand)}.form-stack--wide{max-width:36rem}.btn-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.btn-row--compact .btn{padding:.35rem .6rem;font-size:.85rem}.filters-row{flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.field--inline{flex-direction:row;align-items:center;gap:.5rem}.row-muted{opacity:.65}.import-result{margin-top:.75rem;font-size:.9rem}.import-errors{color:var(--color-error);margin:.5rem 0 0;padding-left:1.25rem;font-size:.85rem}.back-link{margin-bottom:.75rem;font-size:.9rem;display:inline-block}.page--auth .card{width:min(100%,28rem)}.page--auth h1,.hero__content h1,h1,h2.section-title,.admin-welcome h2{font-family:var(--font-display);font-weight:400}.footer__nav{flex-wrap:wrap;gap:1rem;margin-top:.5rem;display:flex}.footer__nav a{font-size:.9rem}.quick-links{grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:.75rem;margin-top:1rem;margin-bottom:1rem;display:grid}.quick-link-card{transition:border-color var(--transition-interactive), box-shadow var(--transition-interactive), transform var(--transition-interactive)}.quick-link-card:hover,.quick-link-card:focus-within{border-color:var(--color-brand);box-shadow:var(--shadow-md);transform:translateY(-1px)}.quick-link-card--skeleton{pointer-events:none}.quick-link-card--skeleton:hover{border-color:var(--color-border);box-shadow:var(--shadow-sm);transform:none}.quick-link-card__btn{width:100%;color:inherit;text-align:left;font:inherit;cursor:pointer;background:0 0;border:none;flex-direction:column;gap:.25rem;padding:0;text-decoration:none;display:flex}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:.75rem;display:grid}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;display:flex}.modulo-grid{grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:.85rem;margin:1rem 0;display:grid}.modulo-card__header{align-items:flex-start;gap:.75rem;display:flex}.modulo-card__orden{color:var(--color-brand);font-size:1.25rem;font-weight:700}.modulo-card--inactive{opacity:.6}.modulo-card__link{margin-top:.5rem;font-weight:500;display:inline-block}.recurso-list{margin:.5rem 0 0;padding-left:1.1rem;font-size:.9rem}.modulo-checklist{margin:0;padding:0;list-style:none}.modulo-checklist li{margin-bottom:.35rem}.modulos-fieldset{border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem}.tracker-actions{flex-direction:column;gap:.35rem;min-width:10rem;display:flex}.cell-email{word-break:break-all;font-size:.82rem}.cell-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:10rem;font-size:.82rem;overflow:hidden}.audit-detail{background:var(--color-bg);border-radius:var(--radius);max-width:20rem;margin-top:.5rem;padding:.5rem;font-size:.75rem;overflow-x:auto}.programa-header h1{margin-bottom:.5rem}.programa-meta{margin-bottom:1rem}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-brand);outline-offset:2px}.skeleton{background:linear-gradient(90deg, var(--color-border) 0%, color-mix(in srgb, var(--color-border) 55%, var(--color-surface)) 50%, var(--color-border) 100%);border-radius:var(--radius);background-size:200% 100%;animation:1.2s ease-in-out infinite skeleton-shimmer}.skeleton--icon{border-radius:.25rem;width:1.25rem;height:1.25rem;margin-bottom:.35rem}.skeleton--title{width:70%;height:.9rem}.skeleton--line{height:.75rem;margin-bottom:.4rem}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.file-input{align-items:center;max-width:100%;display:inline-flex;position:relative}.file-input__native{opacity:0;cursor:pointer;width:100%;position:absolute;inset:0}.file-input__label{border:1px dashed var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);transition:border-color var(--transition-interactive), background var(--transition-interactive);padding:.5rem 1rem;font-size:.9rem;display:inline-flex}.file-input:hover .file-input__label,.file-input:focus-within .file-input__label{border-color:var(--color-brand);background:var(--color-brand-muted)}.file-field__hint{margin-top:.35rem;font-size:.85rem;display:block}@media (width<=768px){.toast-stack{bottom:4.5rem}}
