:root{--primary:#00695c;--primary-container:#004d40;--secondary:#00acc1;--secondary-container:#80deea;--tertiary:#003d33;--on-primary:#fff;--on-secondary:#fff;--on-primary-container:#b2dfdb;--surface:#f9f9f9;--surface-bright:#f9f9f9;--surface-container:#eee;--surface-container-high:#e8e8e8;--surface-container-highest:#e2e2e2;--surface-container-low:#f3f3f3;--surface-container-lowest:#fff;--surface-dim:#dadada;--surface-variant:#e2e2e2;--on-surface:#1a1c1c;--on-surface-variant:#454652;--outline:#767683;--outline-variant:#c6c5d4;--error:#ba1a1a;--error-container:#ffdad6;--on-error:#fff;--on-error-container:#93000a;--grad-primary:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);--grad-hero:linear-gradient(135deg, #004d40 0%, #00695c 50%, #00acc1 100%);--font-display:"Manrope", sans-serif;--font-body:"Inter", sans-serif;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 2px 8px #1a1c1c0f;--shadow-md:0 4px 24px #1a1c1c14;--shadow-lg:0 8px 40px #1a1c1c1a;--sidebar-w:256px;--fs-xs:clamp(.625rem, .6rem + .125vw, .6875rem);--fs-sm:clamp(.75rem, .7rem + .25vw, .875rem);--fs-base:clamp(.875rem, .85rem + .125vw, 1rem);--fs-lg:clamp(1.125rem, 1.05rem + .375vw, 1.375rem);--fs-xl:clamp(1.5rem, 1.3rem + 1vw, 2.25rem)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;max-width:100vw;font-size:16px}body{font-family:var(--font-body);background:var(--surface);color:var(--on-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c6c5d433;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#c6c5d466}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.app-container{grid-template-columns:var(--sidebar-w) 1fr;width:100vw;height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--surface-container-high);padding:var(--sp-6) 0;z-index:20;border-right:1px solid #c6c5d41a;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-logo{align-items:center;gap:var(--sp-3);padding:0 var(--sp-5) var(--sp-6);display:flex}.sidebar-logo-mark{border-radius:var(--radius-md);background:var(--grad-primary);color:#fff;width:36px;height:36px;font-family:var(--font-display);justify-content:center;align-items:center;font-size:.875rem;font-weight:800;display:flex}.sidebar-logo-text .institution{font-family:var(--font-display);color:var(--primary-container);font-size:1rem;font-weight:800;line-height:1}.sidebar-logo-text .system{color:var(--on-surface-variant);text-transform:uppercase;margin-top:2px;font-size:.625rem}.sidebar-nav{padding:var(--sp-4) var(--sp-3);gap:var(--sp-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;color:var(--outline);padding:var(--sp-4) var(--sp-3) var(--sp-2);font-size:.625rem;font-weight:600}.nav-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--radius-lg);cursor:pointer;color:var(--on-surface-variant);font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{background:var(--surface-dim);color:var(--on-surface)}.nav-item.active{background:var(--surface-container-lowest);color:var(--primary-container);box-shadow:var(--shadow-sm);font-weight:600}.nav-item.active:before{content:"";background:var(--primary-container);border-radius:var(--radius-full);width:3px;height:60%;position:absolute;top:20%;left:0}.nav-badge{background:var(--error-container);color:var(--on-error-container);border-radius:var(--radius-full);margin-left:auto;padding:2px 7px;font-size:.625rem;font-weight:700}.sidebar-footer{padding:var(--sp-4) var(--sp-3);border-top:1px solid #c6c5d41a}.sidebar-user{align-items:center;gap:var(--sp-3);padding:var(--sp-3);border-radius:var(--radius-lg);display:flex}.avatar{background:var(--grad-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8125rem;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;font-weight:600;line-height:1.2;overflow:hidden}.user-role{color:var(--on-surface-variant);font-size:.6875rem}.topbar{align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-8);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;background:#f9f9f9cc;border-bottom:1px solid #c6c5d426;flex-shrink:0;display:flex}.topbar-title{flex:1;min-width:0}.topbar-heading{font-family:var(--font-display);font-weight:700;font-size:var(--fs-lg);color:var(--on-surface);white-space:nowrap;text-overflow:ellipsis;line-height:1;overflow:hidden}.topbar-subtitle{color:var(--on-surface-variant);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.75rem;overflow:hidden}.topbar-actions{align-items:center;gap:var(--sp-3);display:flex}.btn-icon{background:var(--surface-container-lowest);border-radius:var(--radius-lg);cursor:pointer;width:38px;height:38px;color:var(--on-surface-variant);box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon:hover{background:var(--surface-container);color:var(--on-surface)}.btn-primary{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:var(--grad-primary);color:#fff;border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-md);touch-action:manipulation;-webkit-tap-highlight-color:transparent;border:none;min-height:44px;font-weight:600;transition:transform .2s;display:flex}.btn-primary:hover{transform:translateY(-1px)}.btn-secondary{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border:1px solid var(--outline-variant);background:var(--surface-container-lowest);color:var(--on-surface);border-radius:var(--radius-lg);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px;font-weight:600;transition:all .2s;display:flex}.btn-secondary:hover{background:var(--surface-container-low)}.touch-manipulation{touch-action:manipulation}.tap-highlight-transparent{-webkit-tap-highlight-color:transparent}.search-bar{align-items:center;gap:var(--sp-2);background:var(--surface-container-lowest);border-radius:var(--radius-lg);padding:var(--sp-2) var(--sp-3);box-shadow:var(--shadow-sm);border:1px solid #c6c5d426;min-width:220px;display:flex}.search-bar input{width:100%;color:var(--on-surface);background:0 0;border:none;outline:none;font-size:.875rem}.main-content{background:var(--surface);flex-direction:column;flex:1;display:flex;overflow:hidden}.page-body{padding:var(--sp-8);gap:var(--sp-8);flex-direction:column;flex:1;display:flex;overflow-y:auto}.kpi-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.kpi-card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--sp-6);box-shadow:var(--shadow-sm)}.kpi-value{font-family:var(--font-display);font-size:var(--fs-xl);font-weight:800;line-height:1}.kpi-label{color:var(--on-surface-variant);margin-top:var(--sp-2);font-size:.75rem}.card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:var(--sp-6) var(--sp-6) var(--sp-2)}.card-body{padding:0 var(--sp-6) var(--sp-6)}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table thead th{text-transform:uppercase;color:var(--outline);padding:var(--sp-3) var(--sp-4);text-align:left;background:var(--surface-container-low);font-size:.6875rem;font-weight:600}.data-table tbody td{padding:var(--sp-4) var(--sp-4);border-bottom:1px solid #c6c5d40d;font-size:.875rem}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;opacity:1;background:#0006;transition:opacity .3s;position:fixed;inset:0}.drawer-panel{background:var(--surface-container-lowest);width:480px;max-width:90vw;box-shadow:var(--shadow-lg);z-index:101;flex-direction:column;animation:.4s cubic-bezier(.16,1,.3,1) slideInRight;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{padding:var(--sp-6);border-bottom:1px solid var(--outline-variant);justify-content:space-between;align-items:center;display:flex}.drawer-header h2{font-family:var(--font-display);font-size:1.25rem;font-weight:800}.drawer-body{padding:var(--sp-6);flex:1;overflow-y:auto}.drawer-footer{padding:var(--sp-6);border-top:1px solid var(--outline-variant);background:var(--surface-container-low)}.form-grid{gap:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.input-field{flex-direction:column;gap:6px;display:flex}.input-field label{color:var(--on-surface-variant);text-transform:uppercase;font-size:.75rem;font-weight:600}.input-text{border-radius:var(--radius-md);border:1px solid var(--outline-variant);background:var(--surface-container-lowest);width:100%;padding:10px 14px;font-family:inherit;font-size:.875rem;transition:all .2s}.input-text:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #00695c1a}.alert-box{align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-6);border-radius:var(--radius-xl);border:1px solid var(--outline-variant);box-shadow:var(--shadow-lg);color:var(--on-surface);background:#fff;display:flex}.alert-box.successful{color:#065f46;background:#f0fdf4;border-color:#10b981}.alert-box.successful .material-icons-round{color:#10b981}.status-badge{border-radius:var(--radius-full);text-transform:uppercase;padding:4px 10px;font-size:.625rem;font-weight:700}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:199;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;display:none;position:fixed;inset:0}.loading{color:#ffffffb3;width:100vw;height:100vh;font-family:var(--font-display);letter-spacing:.5px;justify-content:center;align-items:center;gap:var(--sp-3);background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);flex-direction:column;font-size:1rem;font-weight:500;display:flex}.loading:before{content:"";border:3px solid #ffffff1a;border-left-color:#6366f1;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.animate-in{will-change:opacity, transform;animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-spin{will-change:transform;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}}.mobile-only{display:none!important}@media (width<=768px){.mobile-only{display:flex!important}.app-container{flex-direction:column;display:flex}.sidebar{width:var(--sidebar-w);box-shadow:var(--shadow-lg);z-index:200;transition:transform .3s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.main-content{width:100vw}.topbar{padding:var(--sp-3) var(--sp-4)}.topbar-heading{font-size:.9375rem}.topbar-subtitle,.topbar-action-label,.search-bar{display:none}.page-body{padding:var(--sp-4)}.kpi-grid{grid-template-columns:1fr}}.portal-grid-main{gap:var(--sp-6);grid-template-columns:1.8fr 1.2fr;display:grid}.portal-grid-inner{gap:var(--sp-6);grid-template-columns:1fr 1fr;display:grid}.portal-header{padding:var(--sp-8) var(--sp-6);background:var(--grad-primary);border-radius:var(--radius-xl);color:#fff;align-items:center;min-height:160px;display:flex;position:relative;overflow:hidden}.portal-header-content{align-items:center;gap:var(--sp-6);z-index:1;display:flex;position:relative}.portal-header-avatar{border-radius:var(--radius-xl);background:#fff3;border:4px solid #fff3;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;font-size:2.5rem;font-weight:800;display:flex}@media (width<=768px){.portal-grid-main,.portal-grid-inner{gap:var(--sp-4);grid-template-columns:1fr}.portal-header{padding:var(--sp-4)}.portal-header-content{gap:var(--sp-3);text-align:center;flex-direction:column}.portal-header-avatar{width:70px;height:70px;font-size:1.75rem}.portal-header-stats{gap:var(--sp-2)!important;flex-direction:column!important}.portal-header-stats>div{border-left:none!important;padding-left:0!important}}.login-container{background:var(--surface);height:100vh;display:flex}.login-visual{background:#00695c url(https://images.unsplash.com/photo-1523050335392-9bef867a4975?q=80&w=2070&auto=format&fit=crop) 50%/cover no-repeat;flex:1.2;position:relative}.login-overlay{padding:var(--sp-12);color:#fff;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#004d40e6 0%,#00695cd9 50%,#00acc1cc 100%);flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:0}.login-branding{gap:var(--sp-4);flex-direction:column;display:flex}.login-logo{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#fff3;border:1px solid #ffffff4d;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.login-logo span{font-size:32px}.login-branding h1{font-family:var(--font-display);font-size:var(--fs-xl);margin-top:var(--sp-4);text-shadow:0 2px 4px #0003;font-weight:800;line-height:1.1}.login-branding p{font-size:var(--fs-lg);opacity:.9;text-shadow:0 1px 2px #0000001a;max-width:480px}.login-footer{opacity:.7;letter-spacing:.5px;font-size:.75rem;font-weight:500}.login-form-side{padding:var(--sp-8);background:var(--surface);flex:1;justify-content:center;align-items:center;display:flex}.login-form-wrapper{flex-direction:column;width:100%;max-width:420px;display:flex}.login-header{margin-bottom:var(--sp-8)}.login-header h2{font-family:var(--font-display);color:var(--on-surface);font-size:2rem;font-weight:800;line-height:1.2}.login-header p{color:var(--on-surface-variant);margin-top:var(--sp-2);font-size:1rem}.search-input-wrapper{border:1px solid var(--outline-variant);border-radius:var(--radius-md);background:#fff;align-items:center;gap:12px;padding:12px 16px;transition:all .2s;display:flex;box-shadow:0 1px 2px #00000005}.search-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #00695c1a}.search-input-wrapper input{width:100%;color:var(--on-surface);font-size:.875rem;font-family:var(--font-body);background:0 0;border:none;outline:none}.search-input-wrapper input::placeholder{color:var(--outline-variant)}@media (width<=768px){.login-container{flex-direction:column}.login-visual{display:none}.login-form-side{padding:var(--sp-6)}.login-form-wrapper{max-width:100%}:root{--caja-cols:1fr}}
