:root{font-family:Plus Jakarta Sans,Inter,system-ui,-apple-system,sans-serif;color-scheme:light;--bg: #f3f6fb;--card: rgba(255, 255, 255, .78);--text: #1b1f2a;--muted: #5f6b7a;--accent: #1a6b3c;--accent-light: #edfaf3;--accent-mid: #bbf7d0;--accent-text: #166534;--blue: #1d4ed8;--blue-light: #eff6ff;--blue-mid: #bfdbfe;--radius: 20px;--radius-sm: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow: 0 24px 60px rgba(17, 25, 40, .18);--card-border: rgba(255, 255, 255, .34);--tenant-overlay: linear-gradient(135deg, rgba(10, 20, 15, .72) 0%, rgba(15, 60, 35, .55) 40%, rgba(10, 30, 50, .5) 100%)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);min-height:100svh;-webkit-font-smoothing:antialiased}.tenant-bg{position:relative;min-height:100svh}.tenant-bg:before{content:"";position:fixed;inset:0;background-image:var(--tenant-bg-url, radial-gradient(circle at 12% 12%, #e2e8f0 0%, #cbd5e1 38%, #94a3b8 100%));background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.34;filter:blur(0px);pointer-events:none;z-index:0}.tenant-bg:after{content:"";position:fixed;inset:0;background:var(--tenant-overlay, linear-gradient(135deg, rgba(10, 20, 15, .72) 0%, rgba(15, 60, 35, .55) 40%, rgba(10, 30, 50, .5) 100%));opacity:.78;pointer-events:none;z-index:0}.auth-page,.auth-wrapper{min-height:100svh;display:flex;align-items:stretch;justify-content:center;padding:clamp(12px,2.4vw,28px);background:radial-gradient(circle at top,var(--accent-light),var(--bg))}.tenant-bg .auth-page{background:transparent}.auth-page,.auth-shell,.auth-main{position:relative;z-index:1}.auth-shell{min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(16px,2.5vw,28px);width:min(1180px,100%);align-items:start}.auth-wrapper--centered,.auth-page--centered{align-items:center;padding-block:clamp(20px,6vh,56px)}.auth-shell--auth{margin-inline:auto;align-items:center}.auth-shell--auth .auth-main{width:min(1040px,100%)}.auth-main{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,32px);align-items:stretch}.auth-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--card-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:clamp(24px,4vw,36px);display:flex;flex-direction:column;gap:14px}.auth-panel,.auth-sideCard{color:var(--text);padding:32px;border-radius:var(--radius);background:#ffffff6b;border:1px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-panel h2,.auth-sideCard h2{margin-top:0}.auth-panel ul,.auth-sideCard ul{padding-left:20px;margin:0;display:grid;gap:10px}.auth-side{display:flex;flex-direction:column;justify-content:flex-end}.role-illustration{width:100%;min-height:220px;background-size:contain;background-position:center;background-repeat:no-repeat;margin-bottom:16px;opacity:.92}.auth-page--director .role-illustration{background-image:url(/assets/illustrations/director.svg)}.auth-page--docente .role-illustration{background-image:url(/assets/illustrations/docente.svg)}.auth-page--alumno .role-illustration{background-image:url(/assets/illustrations/alumno-puzzle.svg)}.auth-sideCard{margin-top:auto}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:8px}.auth-logo{width:clamp(44px,6vw,64px);height:auto;object-fit:contain;border-radius:12px}.auth-brand-fallback{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;background:var(--blue-light);color:var(--accent);font-weight:600;font-size:14px}.auth-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;background:var(--accent-light);color:var(--accent-text);border:1px solid var(--accent-mid);padding:8px 12px;border-radius:999px;width:fit-content}.auth-subtitle{margin:0;color:var(--muted)}.auth-note{color:var(--muted);margin:0}.auth-field{display:grid;gap:8px;font-size:14px}.auth-field--inline{grid-template-columns:auto 1fr;align-items:center;gap:10px}.auth-field-group{display:grid;gap:12px}.auth-field input:not([type=checkbox]):not([type=radio]){padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);font-size:15px;width:100%}.auth-field select,.auth-field textarea{padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);font-size:15px;width:100%;background:#fff}.auth-card form{display:grid;gap:14px}.auth-card form .auth-button{justify-self:stretch}.auth-check{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}.auth-button{border:none;border-radius:12px;padding:12px 16px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 12px 24px #00000026}.auth-button--ghost{background:transparent;color:var(--accent);border:1px solid rgba(47,133,90,.2);box-shadow:none}.auth-button--compact{padding:8px 12px;font-size:13px;font-weight:700}.auth-card--wide{width:100%}.auth-section{display:grid;gap:16px;margin-top:8px}.auth-section-head h2{margin:0 0 4px}.auth-section-head p{margin:0}.auth-card--student-dashboard{gap:20px}.auth-student-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,.08)}.auth-student-header h1{margin:0;font-size:clamp(1.6rem,2.6vw,2.1rem)}.auth-student-header .auth-subtitle{margin-top:6px}.auth-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.auth-dashboard-card{background:#ffffffd1;border-radius:18px;padding:18px;border:1px solid rgba(255,255,255,.6);box-shadow:0 18px 30px #0f172a1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;gap:12px}.auth-dashboard-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.auth-dashboard-head h3{margin:0}.auth-count{display:inline-flex;align-items:center;justify-content:center;min-width:36px;padding:4px 10px;border-radius:999px;background:var(--accent-light);color:var(--accent-text);border:1px solid var(--accent-mid);font-weight:600;font-size:13px}.auth-actions{display:flex;flex-wrap:wrap;gap:12px}.auth-table{overflow-x:auto;border-radius:16px;border:1px solid rgba(0,0,0,.08)}.auth-table table{width:100%;border-collapse:collapse;font-size:14px}.auth-table th,.auth-table td{padding:12px 14px;text-align:left;border-bottom:1px solid rgba(0,0,0,.06)}.auth-table th{background:color-mix(in srgb,var(--accent-light) 78%,#ffffff 22%);font-weight:600}.auth-link{background:none;border:none;padding:0;color:var(--accent);font-weight:600;cursor:pointer;text-decoration:none;font-size:14px}.auth-action-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.auth-action-item{position:relative;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:none;background:var(--accent-light);color:var(--accent-text);border:1px solid var(--accent-mid);font-weight:600;font-size:16px;text-decoration:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.auth-action-item:hover,.auth-action-item:focus-visible{background:#2f855a33;box-shadow:0 6px 12px #1f6f462e;transform:translateY(-1px)}.auth-action-item:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1f2933;color:#fff;padding:6px 10px;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.auth-action-item:hover:after,.auth-action-item:focus-visible:after{opacity:1;transform:translate(-50%,-2px)}.auth-card-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.auth-card-grid--student{align-items:stretch}.auth-mini-card{background:#fffc;border-radius:16px;padding:18px;border:1px solid rgba(255,255,255,.56);box-shadow:0 14px 24px #0f172a17;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;gap:10px}.auth-mini-card--highlight{background:linear-gradient(180deg,#3b5bdb14,#fffffff2)}.auth-icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:var(--blue-light);font-size:18px}.auth-tags{display:flex;flex-wrap:wrap;gap:6px}.auth-tag{background:var(--accent-light);color:var(--accent-text);border:1px solid var(--accent-mid);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.auth-status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}.auth-status--active{background:#2f855a24;color:#1f6f46}.auth-status--inactive{background:#b91c1c1f;color:#b91c1c}.auth-inline-note{margin-top:8px;font-size:13px;color:var(--muted)}.auth-preview{display:flex;gap:8px;align-items:center;font-size:14px;color:var(--muted)}.auth-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;align-items:end}.auth-button:hover{filter:brightness(1.05)}.auth-error{background:#dc35451f;border:1px solid rgba(220,53,69,.3);color:#b42333;padding:10px 12px;border-radius:10px;font-size:14px}.auth-alert{background:var(--blue-light);border:1px solid rgba(59,91,219,.25);color:var(--accent);padding:10px 12px;border-radius:10px;font-size:14px}.auth-footer,.auth-footer-note{font-size:13px;color:var(--muted)}.auth-options{display:grid;gap:12px;margin-top:6px}.auth-option{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:#f9fafb;cursor:pointer;text-decoration:none;color:inherit}.auth-option input{margin-top:2px}.auth-muted{display:block;font-size:12px;color:var(--muted);margin-top:2px}.auth-shell--dashboard{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;width:min(1180px,100%);align-items:stretch;margin-inline:auto}.auth-topbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:14px;background:#ffffffe0;border:1px solid rgba(255,255,255,.62);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-topbar__crumb{font-size:12px;color:var(--muted);opacity:.9}.auth-topbar__sep{color:#64748b80}.auth-topbar__pill{margin-left:auto;display:inline-flex;align-items:center;border-radius:999px;padding:5px 12px;font-size:11px;font-weight:700;color:var(--accent-text);background:var(--accent-light);border:1px solid var(--accent-mid)}.auth-hero{border-radius:14px;padding:clamp(16px,2.6vw,24px);position:relative;overflow:hidden;background:linear-gradient(100deg,#0f172a9e,#1e293b6b 46%,#3341552e);color:#fff}.auth-hero:after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.24);border-radius:inherit;pointer-events:none}.auth-hero>*{position:relative;z-index:1}.auth-hero__kicker{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-mid);font-weight:700}.auth-hero h1,.auth-hero .auth-subtitle,.auth-hero .auth-note{color:#fffffff0}.auth-hero .auth-subtitle,.auth-hero .auth-note{color:#ffffffb8}@media(max-width:900px){.auth-shell--dashboard{gap:10px;grid-template-columns:minmax(0,1fr)}.auth-topbar{flex-wrap:wrap}.auth-topbar__pill{margin-left:0}.auth-main{grid-template-columns:1fr}.role-illustration{display:none}.auth-brand{justify-content:center}.auth-side{order:2}.auth-wrapper,.auth-page{align-items:stretch}.auth-wrapper--centered,.auth-page--centered{align-items:center;padding-block:20px}.auth-shell--auth{grid-template-columns:minmax(0,1fr);gap:14px}.auth-table{display:none}.auth-card-grid{grid-template-columns:1fr;gap:14px}}@media(max-width:640px){.auth-wrapper,.auth-page{padding-inline:12px}.auth-card,.auth-panel,.auth-sideCard{padding:18px;border-radius:16px}}.auth-welcome{margin:0 0 4px;font-size:.82rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.auth-student-header--dashboard{align-items:flex-start}.auth-student-top-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.auth-pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;background:var(--blue-light);color:var(--accent);font-weight:700;font-size:.78rem}.auth-hamburger-menu{position:relative}.auth-hamburger-menu summary{list-style:none;cursor:pointer;border:1px solid rgba(59,91,219,.2);border-radius:12px;padding:8px 12px;font-weight:800;background:#fff}.auth-hamburger-menu summary::-webkit-details-marker{display:none}.auth-hamburger-dropdown{position:absolute;right:0;margin-top:8px;min-width:160px;border:1px solid rgba(15,23,42,.12);background:#fff;border-radius:12px;padding:10px;box-shadow:0 16px 28px #0f172a24;display:grid;gap:8px;z-index:10}.auth-hamburger-dropdown form{display:block}.auth-hamburger-dropdown .auth-link{text-align:left;width:100%}.auth-course-accordion-list,.auth-settings-accordion{display:grid;gap:10px}.auth-course-accordion,.auth-settings-accordion{border:1px solid rgba(15,23,42,.1);border-radius:14px;padding:10px 14px;background:#fff}.auth-course-accordion>summary,.auth-settings-accordion>summary{cursor:pointer;font-weight:700;display:flex;justify-content:space-between;align-items:center}.auth-course-accordion[open]>summary,.auth-settings-accordion[open]>summary{margin-bottom:10px}.auth-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.auth-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:1rem;overflow-y:auto;z-index:1200}.auth-modal.is-open{display:flex}.auth-modal__backdrop{position:fixed;inset:0;background:#020617d1;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.auth-modal__card{position:relative;z-index:1;margin:auto;width:min(520px,calc(100% - 2rem));max-height:calc(100svh - 2rem);border-radius:16px;background:#fff;border:1px solid rgba(15,23,42,.12);box-shadow:0 20px 34px #0f172a33;padding:20px;display:grid;gap:14px}.auth-modal__card h3{margin:0}body.student-modal-open{overflow:hidden}.auth-list{margin:0;padding-left:18px;color:#0f172ac7}.auth-list li{margin:4px 0}
