: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: #1d4ed8;--accent-light: #eff6ff;--accent-mid: #bfdbfe;--accent-text: #1e40af;--blue: #0f766e;--blue-light: #f0fdfa;--blue-mid: #99f6e4;--radius: 20px;--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(8, 24, 40, .62) 0%, rgba(20, 66, 102, .48) 40%, rgba(6, 92, 86, .45) 100%)}*{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, 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, radial-gradient(circle at 20% 10%, rgba(255, 255, 255, .45), rgba(15, 23, 42, .08)));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,3vw,32px);width:min(1180px,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);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:#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(1180px,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:#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:#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:#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}.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:16px;background:#ffffffeb;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:20px;padding:clamp(18px,3vw,28px);position:relative;overflow:hidden;background:linear-gradient(90deg,#070b1394,#0f172a57 48%,#0f172a14);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-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}:root{--bg: #f1f6ff;--card: #ffffff;--text: #11233b;--muted: #4c6078;--accent: #1f5bb5;--accent2: #36b7b0;--tenant-overlay: linear-gradient(135deg, rgba(31, 91, 181, .32), rgba(54, 183, 176, .28))}.auth-page--alumno,.auth-wrapper{--student-space-1: .5rem;--student-space-2: 1rem;--student-space-3: 1.5rem;--student-radius-sm: 14px;--student-radius-md: 18px;--student-radius-lg: 24px;--student-shadow-1: 0 10px 24px rgba(15, 23, 42, .1);--student-shadow-2: 0 20px 44px rgba(15, 23, 42, .14);--student-gradient-primary: linear-gradient(120deg, #1d4ed8 0%, #0ea5e9 52%, #14b8a6 100%);--student-gradient-secondary: linear-gradient(120deg, #ffffff 0%, #f0f9ff 100%);animation:studentPageIn .32s ease-out both}@keyframes studentPageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.auth-page--alumno .auth-card,.auth-wrapper .auth-card{border-radius:var(--student-radius-lg);box-shadow:var(--student-shadow-2);border:1px solid rgba(148,163,184,.2)}.auth-page--alumno .auth-panel,.auth-page--alumno .auth-sideCard,.auth-wrapper .auth-panel,.auth-wrapper .auth-sideCard{background:linear-gradient(135deg,#1d4ed824,#4fd1c547);border-radius:var(--student-radius-md)}.auth-page--alumno .auth-button,.auth-wrapper .auth-button{position:relative;isolation:isolate;border-radius:var(--student-radius-sm);font-size:1rem;font-weight:700;color:#fff;background:var(--student-gradient-primary);border:1px solid rgba(14,116,144,.4);box-shadow:0 12px 26px #1d4ed847;transition:transform .18s ease,box-shadow .22s ease,filter .22s ease}.auth-page--alumno .auth-button:after,.auth-wrapper .auth-button:after{content:"";position:absolute;inset:1px;border-radius:inherit;background:linear-gradient(135deg,#ffffff38,#fff0);opacity:0;transition:opacity .18s ease;z-index:-1}.auth-page--alumno .auth-button:hover,.auth-wrapper .auth-button:hover{transform:translateY(-2px);box-shadow:0 16px 30px #1d4ed857}.auth-page--alumno .auth-button:hover:after,.auth-wrapper .auth-button:hover:after{opacity:1}.auth-page--alumno .auth-button:active,.auth-wrapper .auth-button:active{transform:translateY(1px) scale(.99);box-shadow:0 8px 16px #1d4ed83d}.auth-page--alumno .auth-button:focus-visible,.auth-wrapper .auth-button:focus-visible,.auth-page--alumno .auth-link:focus-visible,.auth-wrapper .auth-link:focus-visible,.auth-page--alumno summary:focus-visible,.auth-wrapper summary:focus-visible{outline:3px solid #0f766e;outline-offset:2px}.auth-page--alumno .auth-button:disabled,.auth-wrapper .auth-button:disabled{cursor:not-allowed;transform:none;opacity:.78;box-shadow:none;filter:saturate(.8)}.auth-page--alumno .auth-button--ghost,.auth-wrapper .auth-button--ghost{color:#0f3b94;border-color:#3b82f659;background:var(--student-gradient-secondary);box-shadow:0 8px 18px #0e749029}.auth-page--alumno .auth-button--ghost:hover,.auth-wrapper .auth-button--ghost:hover{box-shadow:0 12px 24px #0e749033}.auth-page--alumno .auth-subtitle,.auth-page--alumno .auth-muted,.auth-wrapper .auth-subtitle,.auth-wrapper .auth-muted{font-size:clamp(.98rem,1.1vw,1.06rem);line-height:1.65}.auth-page--alumno .auth-muted,.auth-wrapper .auth-muted{text-align:justify;text-justify:inter-word}.auth-page--alumno .auth-card,.auth-page--alumno .auth-mini-card,.auth-page--alumno .auth-section,.auth-wrapper .auth-card,.auth-wrapper .auth-mini-card,.auth-wrapper .auth-section{animation:studentCardIn .26s ease-out both}@keyframes studentCardIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-page--alumno :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard),.auth-wrapper :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard){overflow:hidden}.auth-page--alumno :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown),.auth-wrapper :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown){scrollbar-width:thin;scrollbar-color:rgba(29,78,216,.45) rgba(226,232,240,.85)}.auth-page--alumno :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown)::-webkit-scrollbar,.auth-wrapper :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown)::-webkit-scrollbar{width:10px;height:10px}.auth-page--alumno :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown)::-webkit-scrollbar-thumb,.auth-wrapper :is(.auth-card,.auth-section,.auth-mini-card,.auth-panel,.auth-sideCard,.auth-hamburger-dropdown)::-webkit-scrollbar-thumb{border-radius:999px;border:2px solid transparent;background-clip:padding-box;background-color:#1d4ed86b}@media(prefers-reduced-motion:reduce){.auth-page--alumno,.auth-wrapper,.auth-page--alumno *,.auth-wrapper *{animation:none!important;transition:none!important}}.game-mode-card{position:relative;cursor:pointer;transition:border-color .2s,box-shadow .2s}.game-mode-card--active{border-color:#818cf8!important;box-shadow:0 0 0 3px #818cf840!important}.game-mode-badge{display:inline-block;margin-top:8px;padding:3px 12px;border-radius:999px;font-size:.75rem;font-weight:700;background:#818cf81f;color:#818cf8;border:1px solid rgba(129,140,248,.3)}.game-mode-card--active .game-mode-badge{background:#818cf8;color:#fff;border-color:#818cf8}#game-mode-toast{position:fixed;bottom:24px;right:24px;z-index:9999;background:#1e293b;color:#e2e8f0;padding:12px 20px;border-radius:12px;font-size:.88rem;font-weight:600;box-shadow:0 8px 32px #0000004d;transform:translateY(20px);opacity:0;transition:transform .25s,opacity .25s;pointer-events:none}#game-mode-toast.show{transform:translateY(0);opacity:1}body[data-role=alumno]{--student-bg: #f4f7ff;--student-surface: #ffffff;--student-sidebar: #0b172a;--student-border: #dbe4f3;--student-text: #0f172a;--student-muted: #4b5563;--student-accent: #2563eb;--student-accent-soft: #dbeafe}body[data-role=alumno] .shell{display:flex;min-height:100vh}body[data-role=alumno] .sidebar{width:232px;background:var(--student-sidebar);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:100}body[data-role=alumno] .sidebar-brand{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1)}body[data-role=alumno] .brand-logo{display:flex;align-items:center;gap:10px}body[data-role=alumno] .brand-logo--stack{flex-direction:column;gap:8px;align-items:flex-start}body[data-role=alumno] .brand-icon{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#0ea5e9);font-weight:800;font-size:20px;overflow:hidden;flex-shrink:0}body[data-role=alumno] .brand-icon.has-logo{background:transparent}body[data-role=alumno] .brand-name{font-size:18px;font-weight:700}body[data-role=alumno] .sb-section-label{font-size:10px;color:#ffffff73;padding:10px 16px 4px;text-transform:uppercase}body[data-role=alumno] .sb-item{display:flex;gap:10px;align-items:center;padding:9px 16px;color:#ffffffbf;text-decoration:none;border-left:2px solid transparent;transition:.2s ease}body[data-role=alumno] .sb-item:hover{background:#ffffff14;color:#fff}body[data-role=alumno] .sb-item.active{background:#2563eb3d;border-left-color:#93c5fd;color:#fff}body[data-role=alumno] .sb-spacer{flex:1}body[data-role=alumno] .sb-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:10px;align-items:center}body[data-role=alumno] .sb-footer-main{min-width:0;display:flex;align-items:center;gap:10px;flex:1}body[data-role=alumno] .sb-avatar{width:30px;height:30px;border-radius:50%;background:#1d4ed8;display:grid;place-items:center;font-weight:700}body[data-role=alumno] .sb-user-name{font-size:12px}body[data-role=alumno] .sb-user-role{font-size:10px;color:#fff9}body[data-role=alumno] .sb-settings-link{flex-shrink:0;width:34px;height:34px;border-radius:10px;border:1px solid rgba(255,255,255,.22);background:#ffffff14;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;font-size:16px;transition:background .2s ease,border-color .2s ease,transform .2s ease}body[data-role=alumno] .sb-settings-link:hover{background:#ffffff29;border-color:#ffffff5c;transform:translateY(-1px)}body[data-role=alumno] .sb-settings-link.active{background:#2563eb59;border-color:#93c5fdcc}body[data-role=alumno] .main{flex:1;min-width:0;display:flex;flex-direction:column;background-image:linear-gradient(135deg,#081828a8,#14426685,#065c5675),var(--branding-bg);background-size:cover;background-position:center}body[data-role=alumno] .topbar{height:56px;display:flex;align-items:center;gap:8px;padding:0 16px;background:#080f2080;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}body[data-role=alumno] .tb-hamburger,body[data-role=alumno] .tb-btn{width:34px;height:34px;border:1px solid rgba(255,255,255,.26);background:#ffffff14;color:#fff;border-radius:8px}body[data-role=alumno] .tb-pill{padding:5px 10px;border-radius:999px;background:#2563eb40;font-size:11px;font-weight:700}body[data-role=alumno] .topbar-spacer{flex:1}body[data-role=alumno] .content{padding:18px}body[data-role=alumno] .modules-block{background:#ffffffeb;border-radius:16px;padding:16px;box-shadow:0 20px 40px #0f172a2e}body[data-role=alumno] .hero-banner{border-radius:16px;padding:18px;background:linear-gradient(135deg,#1d4ed8,#0ea5e9);color:#fff;margin-bottom:14px}body[data-role=alumno] .hero-content{display:flex;align-items:center;justify-content:space-between;gap:12px}body[data-role=alumno] .hero-controls{display:flex;flex-direction:column;align-items:flex-end;gap:10px}body[data-role=alumno] .hero-kicker{font-size:11px;text-transform:uppercase;opacity:.8}body[data-role=alumno] .hero-title{font-size:28px;font-weight:800}body[data-role=alumno] .hero-title em{font-family:"Instrument Serif",serif;font-weight:400}body[data-role=alumno] .hero-sub{opacity:.92}body[data-role=alumno] .game-mode-switch{border:1px solid rgba(255,255,255,.38);background:#0f172a3d;color:#fff;min-width:160px;border-radius:999px;padding:7px 9px 7px 12px;display:inline-flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;font-size:12px;font-weight:700;transition:background .2s ease,border-color .2s ease,opacity .2s ease}body[data-role=alumno] .game-mode-switch:disabled{opacity:.7;cursor:wait}body[data-role=alumno] .game-mode-switch__track{width:42px;height:22px;border-radius:999px;background:#0f172a99;border:1px solid rgba(255,255,255,.24);padding:2px;display:inline-flex}body[data-role=alumno] .game-mode-switch__thumb{width:16px;height:16px;border-radius:50%;background:#fff;transform:translate(0);transition:transform .2s ease}body[data-role=alumno] .game-mode-switch.is-on{background:#22c55e2e;border-color:#86efaccc}body[data-role=alumno] .game-mode-switch.is-on .game-mode-switch__track{background:#22c55e8c;border-color:#86eface6}body[data-role=alumno] .game-mode-switch.is-on .game-mode-switch__thumb{transform:translate(20px)}body[data-role=alumno] .modules-grid{display:grid;gap:12px}body[data-role=alumno] .grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}body[data-role=alumno] .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}body[data-role=alumno] .mod-card{background:var(--student-surface);border:1px solid var(--student-border);border-radius:14px;padding:14px}body[data-role=alumno] .mod-link{text-decoration:none;color:inherit;display:block}body[data-role=alumno] .mod-name{font-weight:700;margin-bottom:6px}body[data-role=alumno] .mod-desc{color:var(--student-muted);font-size:14px}body[data-role=alumno] .mod-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}body[data-role=alumno] .mod-btn{text-decoration:none;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:700}body[data-role=alumno] .mod-btn.a{background:#2563eb;color:#fff}body[data-role=alumno] .mod-btn.ghost{border:1px solid #cbd5e1;color:#1e3a8a;background:#fff}body[data-role=alumno] .section-head{display:flex;align-items:center;gap:10px;margin:14px 0}body[data-role=alumno] .section-line{flex:1;height:1px;background:#dbe4f3}body[data-role=alumno] .progress-track{height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden;margin:8px 0}body[data-role=alumno] .progress-track span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#14b8a6,#3b82f6)}body[data-role=alumno] .status-card--ok{border-color:#86efac;background:#f0fdf4}body[data-role=alumno] .status-card--warn{border-color:#fcd34d;background:#fffbeb}body[data-role=alumno] .course-card.is-complete{border-color:#86efac}body[data-role=alumno] .area-section{padding:16px 12px}body[data-role=alumno] .area-section-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--student-accent);background:var(--student-accent-soft);display:inline-block;padding:4px 12px;border-radius:999px;margin-bottom:14px}body[data-role=alumno] .course-slider-wrap{position:relative;padding:0 4px}body[data-role=alumno] .course-slider{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:6px 2px 14px;scrollbar-width:none}body[data-role=alumno] .course-slider::-webkit-scrollbar{display:none}body[data-role=alumno] .slider-arrow{position:absolute;top:42%;transform:translateY(-50%);z-index:10;width:34px;height:34px;border-radius:50%;border:1px solid rgba(37,99,235,.2);background:#fffffff5;box-shadow:0 4px 16px #0f172a2e;font-size:20px;font-weight:900;color:#1d4ed8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s,box-shadow .15s;line-height:1}body[data-role=alumno] .slider-arrow:hover{background:#eff6ff;box-shadow:0 6px 20px #1d4ed83d;transform:translateY(-50%) scale(1.1)}body[data-role=alumno] .slider-arrow--prev{left:-12px}body[data-role=alumno] .slider-arrow--next{right:-12px}body[data-role=alumno] .slider-arrow.hidden{opacity:0;pointer-events:none}body[data-role=alumno] .course-card-v2{flex:0 0 clamp(220px,72vw,280px);width:clamp(220px,72vw,280px);scroll-snap-align:start;background:var(--student-surface);border:1px solid var(--student-border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .22s,transform .22s;box-shadow:0 2px 10px #0f172a14}body[data-role=alumno] .course-card-v2:hover{box-shadow:0 10px 32px #0f172a26;transform:translateY(-3px)}body[data-role=alumno] .course-card-v2.is-complete{border-color:#86efac;background:linear-gradient(180deg,#f0fdf4,#fff 60%)}@media(min-width:900px){body[data-role=alumno] .course-card-v2{flex:0 0 260px;width:260px}}body[data-role=alumno] .course-video-wrap{position:relative;width:100%;height:130px;background:#0b172a;cursor:pointer;overflow:hidden;flex-shrink:0}@media(max-width:600px){body[data-role=alumno] .course-video-wrap{height:148px}}body[data-role=alumno] .course-video-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}body[data-role=alumno] .course-video-wrap:hover .course-video-thumb{transform:scale(1.04)}body[data-role=alumno] .course-video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#0710242e,#0710240f);transition:background .2s}body[data-role=alumno] .course-video-wrap:hover .course-video-overlay{background:linear-gradient(160deg,#0710246b,#0710243d)}body[data-role=alumno] .course-play-hint{display:flex;flex-direction:column;align-items:center;gap:5px;opacity:0;transition:opacity .2s}body[data-role=alumno] .course-video-wrap:hover .course-play-hint{opacity:1}body[data-role=alumno] .course-play-btn{width:46px;height:46px;border-radius:50%;border:2px solid rgba(255,255,255,.92);background:#2563ebd9;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:none;transition:transform .18s,background .18s;box-shadow:0 6px 18px #00000059}body[data-role=alumno] .course-play-btn svg{width:20px;height:20px}body[data-role=alumno] .course-video-wrap:hover .course-play-btn{transform:scale(1.14);background:#2563eb}body[data-role=alumno] .course-play-label{font-size:10px;font-weight:700;color:#fffffff2;text-shadow:0 1px 4px rgba(0,0,0,.6);letter-spacing:.03em;white-space:nowrap}body[data-role=alumno] .course-video-close{position:absolute;top:7px;right:7px;width:26px;height:26px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:12px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3}body[data-role=alumno] .course-video-wrap.is-playing .course-video-close{display:flex}body[data-role=alumno] .course-no-video{width:100%;height:130px;flex-shrink:0;background:linear-gradient(135deg,#1d4ed8,#0ea5e9 60%,#14b8a6);display:flex;align-items:center;justify-content:center;font-size:36px}body[data-role=alumno] .course-card-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:9px;flex:1}body[data-role=alumno] .course-card-title{font-weight:800;font-size:14px;color:var(--student-text);display:flex;align-items:center;justify-content:space-between;gap:8px;line-height:1.3}body[data-role=alumno] .course-badge-done{width:20px;height:20px;border-radius:50%;background:#22c55e;color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}body[data-role=alumno] .course-progress-wrap{display:flex;align-items:center;gap:8px}body[data-role=alumno] .course-progress-track{flex:1;height:7px;border-radius:999px;background:#e2e8f0;overflow:hidden}body[data-role=alumno] .course-progress-track span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#14b8a6,#3b82f6);border-radius:999px;transition:width .4s ease}body[data-role=alumno] .course-progress-pct{font-size:11px;font-weight:700;color:var(--student-accent);white-space:nowrap;min-width:30px;text-align:right}body[data-role=alumno] .course-stats{display:flex;gap:10px;flex-wrap:wrap;font-size:11px;color:var(--student-muted);font-weight:600}body[data-role=alumno] .course-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}@keyframes btnGlow{0%{box-shadow:0 4px 14px #2563eb73}50%{box-shadow:0 4px 22px #2563ebc7,0 0 0 5px #2563eb24}to{box-shadow:0 4px 14px #2563eb73}}@keyframes btnShimmer{0%{background-position:-200% center}to{background-position:200% center}}body[data-role=alumno] .mod-btn.a{position:relative;animation:btnGlow 2.4s ease-in-out infinite;background:linear-gradient(90deg,#1d4ed8,#0ea5e9,#1d4ed8);background-size:200% auto;overflow:hidden}body[data-role=alumno] .mod-btn.a:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.28) 50%,transparent 100%);background-size:200% auto;animation:btnShimmer 2.2s linear infinite;border-radius:inherit;pointer-events:none}body[data-role=alumno] .mod-btn.a:hover{animation:none;box-shadow:0 6px 24px #2563eb8c;transform:translateY(-2px)}body[data-role=alumno] .mod-btn.ghost{transition:background .18s,box-shadow .18s,transform .15s,border-color .18s}body[data-role=alumno] .mod-btn.ghost:hover{background:#eff6ff;border-color:#93c5fd;box-shadow:0 4px 14px #2563eb29;transform:translateY(-1px)}.temas-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:16px;z-index:1500}.temas-modal.is-open{display:flex}.temas-modal__backdrop{position:fixed;inset:0;background:#020617bf;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.temas-modal__card{position:relative;z-index:1;width:min(560px,calc(100% - 32px));max-height:calc(100svh - 32px);border-radius:20px;background:#fff;box-shadow:0 28px 60px #0f172a47;display:flex;flex-direction:column;overflow:hidden;animation:modalIn .22s ease-out both}@keyframes modalIn{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.temas-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 20px 14px;border-bottom:1px solid #e2e8f0}.temas-modal__badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:4px 10px;border-radius:999px;background:#dbeafe;color:#1d4ed8;margin-bottom:6px}.temas-modal__header h3{margin:0;font-size:18px;font-weight:800;color:#0f172a}.temas-modal__close{width:32px;height:32px;border-radius:50%;background:#f1f5f9;border:none;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;color:#475569;flex-shrink:0;transition:background .15s}.temas-modal__close:hover{background:#e2e8f0}.temas-modal__progress{padding:12px 20px;border-bottom:1px solid #f1f5f9;display:flex;flex-direction:column;gap:6px}.temas-modal__progress-bar{height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.temas-modal__progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#14b8a6,#3b82f6);border-radius:999px;transition:width .4s ease}.temas-modal__progress-label{font-size:12px;color:#64748b;font-weight:600}.temas-modal__list{overflow-y:auto;flex:1;padding:12px 14px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:rgba(37,99,235,.35) #f1f5f9}.temas-modal__item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;transition:background .15s,border-color .15s}.temas-modal__item:hover{background:#f0f9ff;border-color:#bfdbfe}.temas-modal__item.is-done{background:#f0fdf4;border-color:#86efac}.temas-modal__item.is-locked{opacity:.6}.tema-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.tema-icon--done{background:#22c55e;color:#fff}.tema-icon--locked{background:#e2e8f0;color:#94a3b8;font-size:14px}.tema-icon--open{background:#dbeafe;color:#2563eb;font-size:11px}.temas-modal__item-info{flex:1;min-width:0}.temas-modal__item-title{font-weight:700;font-size:14px;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.temas-modal__item-sub{font-size:12px;color:#64748b;margin-top:2px}.temas-modal__item-action{flex-shrink:0}.tema-pill{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;text-decoration:none;white-space:nowrap}.tema-pill--done{background:#dcfce7;color:#16a34a}.tema-pill--active{background:linear-gradient(90deg,#2563eb,#0ea5e9);color:#fff;box-shadow:0 4px 10px #2563eb4d;transition:box-shadow .15s,transform .15s}.tema-pill--active:hover{box-shadow:0 6px 14px #2563eb66;transform:translateY(-1px)}.temas-modal__empty{text-align:center;color:#94a3b8;font-size:14px;padding:20px}.temas-modal__footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid #e2e8f0}body.temas-modal-open{overflow:hidden}body[data-role=alumno] .sidebar-overlay{display:none;position:fixed;inset:0;background:#02061773;z-index:90}body[data-role=alumno] .tb-hamburger{display:none}@media(max-width:1024px){body[data-role=alumno] .tb-hamburger{display:inline-grid;place-items:center}body[data-role=alumno] .sidebar{position:fixed;left:0;transform:translate(-105%);transition:transform .25s ease}body[data-role=alumno] .sidebar.open{transform:translate(0)}body[data-role=alumno] .sidebar-overlay.open{display:block}body[data-role=alumno] .grid-2,body[data-role=alumno] .grid-3{grid-template-columns:1fr}}@media(max-width:768px){body[data-role=alumno] .content{padding:10px}body[data-role=alumno] .modules-block{padding:12px;border-radius:14px}body[data-role=alumno] .hero-banner{padding:14px}body[data-role=alumno] .hero-title{font-size:22px}body[data-role=alumno] .hero-sub{font-size:13px}body[data-role=alumno] .hero-controls{width:100%;align-items:stretch}body[data-role=alumno] .game-mode-switch{width:100%;min-width:0}body[data-role=alumno] .section-head h2{font-size:16px}body[data-role=alumno] .modules-grid.grid-3{grid-template-columns:1fr;gap:8px}body[data-role=alumno] .slider-arrow{display:none}body[data-role=alumno] .course-slider-wrap{padding:0}body[data-role=alumno] .area-section{padding:12px 8px}body[data-role=alumno] .mod-card{padding:12px}body[data-role=alumno] .mod-btn{padding:9px 12px;font-size:12px}}@media(max-width:480px){body[data-role=alumno] .course-card-v2{flex:0 0 clamp(200px,80vw,260px);width:clamp(200px,80vw,260px)}body[data-role=alumno] .hero-title{font-size:20px}body[data-role=alumno] .hero-content{flex-direction:column;align-items:flex-start;gap:6px}body[data-role=alumno] .sb-footer{padding:12px}body[data-role=alumno] .sb-user-name{font-size:11px}body[data-role=alumno] .sb-user-role{font-size:9px}}.brand-logo-image{width:100%;height:100%;object-fit:contain;border-radius:0}.sb-modal{position:fixed;inset:0;background:#00000073;z-index:300;display:none;align-items:center;justify-content:center;padding:20px}.sb-modal.open{display:flex}.sb-modal-card{position:relative;width:100%;max-width:460px;background:#fff;border-radius:16px;padding:22px;box-shadow:0 22px 48px #0f172a52}.sb-modal-card h3{margin-bottom:12px;font-size:30px}.sb-modal-card input[type=file]{width:100%;margin-bottom:10px}.sb-modal-close{position:absolute;top:10px;right:10px;border:none;background:#f1f5f9;color:#0f172a;width:30px;height:30px;border-radius:50%;font-size:22px;line-height:1;cursor:pointer}.sb-modal-help{font-size:13px;color:#1e293b;margin-bottom:16px}.sb-modal-error{margin:0 0 10px;font-size:13px;color:#b91c1c;font-weight:600}.sb-modal-thumb-wrap{margin-bottom:10px}.sb-modal-thumb{width:82px;height:82px;border-radius:12px;object-fit:cover;border:1px solid #e2e8f0}.sb-modal-actions{display:flex;justify-content:flex-end;gap:8px}.sb-modal-btn{border:1px solid transparent;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:700;cursor:pointer}.sb-modal-btn--ghost{background:#fff;color:#1e293b;border-color:#cbd5e1}.sb-modal-btn--primary{background:#2563eb;color:#fff}.sb-avatar-trigger{border:none;background:transparent;padding:0;cursor:pointer;border-radius:999px}.sb-avatar-trigger:focus-visible{outline:2px solid #f59e0b;outline-offset:2px}.sb-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
