:root{font-family:Inter,system-ui,-apple-system,sans-serif;color-scheme:light;--bg: #f3f6fb;--card: #ffffff;--text: #1b1f2a;--muted: #5f6b7a;--accent: #3b5bdb;--accent2: #8cb4ff;--radius: 20px;--shadow: 0 24px 60px rgba(17, 25, 40, .18)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);min-height:100svh}.tenant-bg{position:relative;min-height:100svh}.tenant-bg:before{content:"";position:fixed;inset:0;background-image:var(--tenant-bg-url, none);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.28;filter:blur(0px);pointer-events:none;z-index:0}.tenant-bg:after{content:"";position:fixed;inset:0;background:var(--tenant-overlay, radial-gradient(circle at 20% 10%, rgba(255, 255, 255, .45), rgba(15, 23, 42, .08)));opacity:.55;pointer-events:none;z-index:0}.auth-page,.auth-wrapper{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:clamp(16px,3vw,40px);background:radial-gradient(circle at top,var(--accent2),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,3vw,32px);width:min(1100px,100%);align-items:center}.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);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:#ffffff59;border:1px solid rgba(255,255,255,.4);-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:#3b5bdb1f;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:#3b5bdb1a;color:var(--accent);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:min(1100px,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:#fff;border-radius:18px;padding:18px;border:1px solid rgba(15,23,42,.1);box-shadow:0 12px 24px #0f172a0f;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:#2f855a26;color:var(--accent);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:#2f855a14;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:#2f855a1f;color:var(--accent);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:#fff;border-radius:16px;padding:18px;border:1px solid rgba(15,23,42,.08);box-shadow:0 10px 22px #0f172a0f;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:#3b5bdb1f;font-size:18px}.auth-tags{display:flex;flex-wrap:wrap;gap:6px}.auth-tag{background:#2f855a1f;color:var(--accent);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:#3b5bdb1f;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}@media(max-width:900px){.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-table{display:none}.auth-card-grid{grid-template-columns:1fr;gap:14px}}.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:#3b5bdb1f;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}
