@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;900&family=DM+Mono:wght@300;400;500&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,700&family=Outfit:wght@400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,700&family=Outfit:wght@600&display=swap";body{background:#0b0e14;font-family:DM Mono,monospace}.login-root{min-height:100vh;display:grid;grid-template-columns:1fr 480px;background:#0b0e14;position:relative;overflow:hidden}.left-panel{display:flex;flex-direction:column;justify-content:center;padding:60px 80px;position:relative;overflow:hidden}.grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px}.orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.orb-1{width:500px;height:500px;background:#e8a8380f;top:-100px;left:-150px}.orb-2{width:400px;height:400px;background:#4ab3e80d;bottom:-80px;right:-100px}.school-badge{display:flex;align-items:center;gap:14px;margin-bottom:64px;position:relative}.badge-icon{width:48px;height:48px;border:2px solid var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--accent);position:relative}.badge-icon:after{content:"";position:absolute;inset:-4px;border:1px solid var(--accent);border-radius:10px;opacity:.3}.badge-name{font-family:Playfair Display,serif;font-size:14px;color:#f0f0f0;font-weight:700;letter-spacing:1px}.badge-sub{font-size:10px;color:#4a5568;letter-spacing:2px;text-transform:uppercase;margin-top:2px}.hero-title{font-family:Playfair Display,serif;font-size:clamp(38px,4vw,58px);font-weight:900;line-height:1.1;color:#f0ede8;margin-bottom:20px;position:relative}.hero-title span{color:var(--accent)}.hero-sub{font-size:12px;color:#3a4a5a;letter-spacing:2px;line-height:1.8;min-height:22px;border-left:2px solid var(--accent);padding-left:14px;position:relative}.hero-sub:after{content:"▋";animation:blink 1s step-end infinite;color:var(--accent);margin-left:2px}@keyframes blink{50%{opacity:0}}.features{margin-top:60px;display:flex;flex-direction:column;gap:16px;position:relative}.feature-item{display:flex;align-items:center;gap:12px;font-size:11px;color:#2a3a4a;letter-spacing:1px}.feature-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.6;flex-shrink:0}.right-panel{background:#0f1520;border-left:1px solid #1a2030;display:flex;flex-direction:column;justify-content:center;padding:48px;position:relative}.form-eyebrow{font-size:10px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:8px}.form-title{font-family:Playfair Display,serif;font-size:28px;font-weight:700;color:#e8e4dc;margin-bottom:32px}.role-group{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:28px}.role-btn{background:transparent;border:1px solid #1e2a3a;border-radius:8px;padding:10px 8px;cursor:pointer;text-align:center;transition:all .2s;position:relative;overflow:hidden}.role-btn.active{border-color:var(--accent);background:#ffffff08}.role-btn:hover:not(.active){border-color:#2a3a4a;background:#ffffff05}.role-icon{font-size:16px;color:var(--accent);display:block;margin-bottom:4px;opacity:.7;transition:opacity .2s}.role-btn.active .role-icon{opacity:1}.role-label{font-size:10px;color:#4a5568;letter-spacing:1px;text-transform:uppercase;transition:color .2s}.role-btn.active .role-label{color:#8a9aaa}.role-indicator{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .2s}.role-btn.active .role-indicator{transform:scaleX(1)}.field-group{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.field-label{font-size:10px;letter-spacing:2px;color:#3a4a5a;text-transform:uppercase}.field-wrap{position:relative}.field-input{width:100%;background:#080c12;border:1px solid #1a2030;border-radius:6px;padding:12px 14px;color:#d0ccc4;font-family:DM Mono,monospace;font-size:13px;outline:none;transition:border-color .2s,box-shadow .2s;appearance:none}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.field-input.has-error{border-color:#e85050}.field-input::placeholder{color:#2a3a4a}.pass-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#3a4a5a;cursor:pointer;font-size:11px;letter-spacing:1px;padding:4px;transition:color .2s}.pass-toggle:hover{color:var(--accent)}.field-error{font-size:10px;color:#e85050;letter-spacing:1px;min-height:14px}.submit-btn{width:100%;padding:14px;background:var(--accent);border:none;border-radius:6px;color:#0b0e14;font-family:DM Mono,monospace;font-size:12px;font-weight:500;letter-spacing:3px;text-transform:uppercase;cursor:pointer;margin-top:8px;transition:opacity .2s,transform .1s;position:relative;overflow:hidden}.submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:#0b0e14;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:6px;padding:10px 14px;font-size:11px;letter-spacing:1px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}.alert-error{background:#e8505014;border:1px solid rgba(232,80,80,.3);color:#e85050}.alert-success{background:#6dd6a014;border:1px solid rgba(109,214,160,.3);color:#6dd6a0}.divider{height:1px;background:#1a2030;margin:28px 0}.forgot-link{font-size:10px;color:#2a3a4a;letter-spacing:1px;text-decoration:none;text-align:center;display:block;margin-top:16px;cursor:pointer;transition:color .2s}.forgot-link:hover{color:var(--accent)}.version-tag{position:absolute;bottom:20px;right:24px;font-size:9px;color:#1a2030;letter-spacing:2px}.success-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;animation:fadeIn .4s ease}.success-icon{font-size:40px;color:#6dd6a0}.success-text{font-family:Playfair Display,serif;font-size:22px;color:#e8e4dc}.success-sub{font-size:11px;color:#3a4a5a;letter-spacing:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(max-width:820px){.login-root{grid-template-columns:1fr}.left-panel{display:none}.right-panel{padding:40px 28px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.shell-root{display:flex;min-height:100vh;background:#f0ede8;font-family:DM Sans,system-ui,sans-serif;font-size:14px;color:#1c1b18}.sidebar{width:228px;flex-shrink:0;background:#1c1b18;display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto}@media(max-width:820px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:300;transform:translate(-100%);transition:transform .22s ease}.sidebar.open{transform:none}.sidebar-overlay{display:block!important}}.sidebar-overlay{display:none;position:fixed;inset:0;z-index:299;background:#00000073}.sidebar-logo{padding:20px 18px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:8px}.logo-mark{width:32px;height:32px;border-radius:8px;background:#0f6e56;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-text{font-family:Outfit,sans-serif;font-size:17px;font-weight:600;color:#fff;letter-spacing:-.2px}.nav-section-label{font-size:10px;font-weight:500;color:#ffffff4d;letter-spacing:.8px;text-transform:uppercase;padding:12px 18px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;margin:1px 8px;border-radius:8px;cursor:pointer;color:#ffffff8c;border:none;background:none;width:calc(100% - 16px);text-align:left;font-size:13.5px;font-family:inherit;transition:background .13s,color .13s;text-decoration:none}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:#0f6e5640;color:#4ecca0}.nav-item.active svg{color:#4ecca0}.nav-item-label{flex:1}.nav-badge{font-size:10px;font-weight:600;background:#e24b4a;color:#fff;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.sidebar-footer{margin-top:auto;padding:12px 8px 16px;border-top:1px solid rgba(255,255,255,.08)}.user-pill{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit;transition:background .13s}.user-pill:hover{background:#ffffff0f}.user-avatar{width:30px;height:30px;border-radius:50%;background:#0f6e56;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:12.5px;color:#fffc;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-rol{font-size:11px;color:#ffffff59}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:54px;background:#f0ede8e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.08);display:flex;align-items:center;padding:0 24px;gap:8px;position:sticky;top:0;z-index:200}.topbar-hamburger{display:none;background:none;border:none;cursor:pointer;color:#888;padding:4px;margin-right:4px}@media(max-width:820px){.topbar-hamburger{display:flex}}.topbar-title{font-family:Outfit,sans-serif;font-size:15px;font-weight:600;color:#1c1b18;flex:1}.topbar-btn{position:relative;width:36px;height:36px;border-radius:9px;background:none;border:1px solid rgba(0,0,0,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5a5855;transition:background .12s,color .12s}.topbar-btn:hover{background:#0000000d;color:#1c1b18}.topbar-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;background:#e24b4a;color:#fff;font-size:9px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;border:2px solid #F0EDE8;padding:0 3px;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.page-content{padding:28px;flex:1}@media(max-width:600px){.page-content{padding:16px}}.skeleton{border-radius:6px;background:linear-gradient(90deg,#e8e5e0 25%,#f0ede8,#e8e5e0 75%);background-size:400px 100%;animation:shimmer 1.3s infinite}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.lp{font-family:DM Sans,system-ui,sans-serif}.lfb{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:18px}.lfi{padding:7px 11px;border:1.5px solid #E2E0D9;border-radius:8px;font-size:13px;font-family:inherit;color:#1c1b18;background:#fff;outline:none;transition:border-color .13s;cursor:pointer}.lfi:focus{border-color:#0f6e56}.resumen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:20px}.res-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:10px;padding:12px 14px}.logro-row{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:11px;margin-bottom:8px;transition:box-shadow .13s}.logro-row:hover{box-shadow:0 3px 14px #00000012}.logro-icono{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.sk{background:linear-gradient(90deg,#e8e5e0 25%,#f0ede8,#e8e5e0 75%);background-size:400px 100%;animation:shim 1.3s infinite;border-radius:6px}@keyframes shim{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
