.login-root{min-height:100vh;display:flex;font-family:var(--font-body);background:var(--c-surface)}.login-side{width:440px;flex-shrink:0;background:linear-gradient(135deg,var(--c-navy-darkest) 0%,var(--c-navy-dark) 50%,var(--c-navy) 100%);display:flex;align-items:center;justify-content:center;padding:48px 40px;position:relative;overflow:hidden}.login-side:before{content:"";position:absolute;top:-100px;right:-100px;bottom:-100px;left:-100px;background-image:radial-gradient(circle,rgba(255,255,255,.08) 1.5px,transparent 1.5px);background-size:32px 32px;z-index:1;opacity:.85;animation:grid-move 80s linear infinite;pointer-events:none}.login-side:after{content:"";position:absolute;top:-100px;right:-50px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,93,10,.28) 0%,rgba(232,93,10,.05) 50%,transparent 70%);pointer-events:none;z-index:1;animation:fire-pulse 10s ease-in-out infinite alternate}.login-side__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;max-width:320px;width:100%}.login-side__logo{width:100%;margin-bottom:24px;display:flex;justify-content:center;align-items:center;align-self:center;filter:drop-shadow(0 8px 24px rgba(232,93,10,.3));animation:logo-float 5s ease-in-out infinite;z-index:2}.login-side__logo-img{width:200px;height:auto;object-fit:contain;display:block}.login-side__title{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:800;color:var(--c-text-on-dark);letter-spacing:-.03em;margin:0 0 12px;line-height:1.1;text-shadow:0 2px 4px rgba(0,0,0,.3)}.login-side__desc{font-size:var(--text-lg);color:#ffffffa6;line-height:1.6;margin:0 0 36px;max-width:320px}.login-side__features{list-style:none;padding:0;margin:0 0 40px;display:flex;flex-direction:column;gap:14px;width:100%}.login-side__features li{display:flex;align-items:center;gap:12px;font-size:var(--text-md);color:#ffffffd9}.feat-ico{width:32px;height:32px;background:#e85d0a2e;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);flex-shrink:0;border:1px solid rgba(232,93,10,.25)}.login-side__law{font-size:var(--text-sm);color:#ffffff59;margin:0 0 12px;letter-spacing:.06em;text-transform:uppercase;font-family:var(--font-mono)}.login-side__verify-btn{margin-top:12px;display:inline-flex;align-items:center;gap:8px;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.12);border-radius:var(--r-xl);padding:10px 18px;color:#ffffffd9;font-size:var(--text-md);font-weight:600;font-family:var(--font-display);cursor:pointer;letter-spacing:-.01em;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--t-spring);width:100%;justify-content:center}.login-side__verify-btn:hover{background:#e85d0a33;border-color:var(--c-orange);color:var(--c-text-on-dark);transform:translateY(-2px);box-shadow:0 6px 20px #e85d0a40}.login-side__verify-btn:active{transform:translateY(0)}.login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:radial-gradient(circle at center,var(--c-bg-subtle) 0%,var(--c-bg) 100%);position:relative;overflow:hidden}.login-main:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(14,42,94,.03) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-card{width:100%;max-width:440px;background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:var(--r-4xl);border:1px solid rgba(255,255,255,.6);padding:40px 40px 32px;box-shadow:0 10px 30px -10px #0e2a5e26,0 1px 3px #0e2a5e0d,inset 0 1px #fffc;position:relative;z-index:2;animation:card-appear .65s cubic-bezier(.16,1,.3,1) both}.login-card__header{margin-bottom:28px}.login-card__badge{width:52px;height:52px;background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-light) 100%);border-radius:var(--r-2xl);display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 8px 24px #0e2a5e33;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.2)}.login-card__badge:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);background-size:200% 200%;animation:shine-sweep 3s ease-in-out infinite}.login-card__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800;color:var(--c-navy);margin:0 0 6px;letter-spacing:-.02em}.login-card__sub{font-size:var(--text-lg);color:var(--c-text-body);margin:0;line-height:1.5;opacity:.85}.login-form{display:flex;flex-direction:column;gap:20px}.login-card .form-label{font-size:var(--text-md);font-weight:600;color:var(--c-navy-dark);margin-bottom:2px}.login-card .form-input{background:#fff9;border:1.5px solid rgba(14,42,94,.12);border-radius:var(--r-xl);height:46px;font-size:var(--text-lg);padding:0 16px;color:var(--c-navy);transition:all var(--t-base)}.login-card .form-input-wrap .form-input{padding-left:42px}.login-card .form-input-icon{left:14px;color:var(--c-navy);opacity:.55;transition:all var(--t-base)}.login-card .form-input:focus{background:var(--c-surface);border-color:var(--c-orange);box-shadow:0 0 0 4px #e85d0a1f}.login-card .form-input-wrap:focus-within .form-input-icon{color:var(--c-orange);opacity:.9;transform:scale(1.05)}.login-card .form-input--error{border-color:var(--c-error)!important;box-shadow:0 0 0 4px #d930251f!important}.form-forgot{font-size:var(--text-sm);font-weight:600;color:var(--c-orange);background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color var(--t-fast)}.form-forgot:hover{text-decoration:none;color:var(--c-orange-dark)}.login-recordar{display:flex;align-items:center;gap:8px;margin:-4px 0 4px;font-size:13px;color:#5a6b82;cursor:pointer;-webkit-user-select:none;user-select:none}.login-recordar input{width:15px;height:15px;cursor:pointer;accent-color:#E85D0A}.login-error{display:flex;align-items:center;gap:10px;background:var(--c-error-subtle);border:1px solid var(--c-error-border);border-radius:var(--r-xl);padding:12px 16px;font-size:var(--text-md);color:var(--c-error-text);line-height:1.45;animation:login-shake .4s cubic-bezier(.36,.07,.19,.97) both}.login-hint{font-size:var(--text-base);color:var(--c-text-body);text-align:center;padding:10px 14px;background:#0e2a5e0a;border-radius:var(--r-xl);border:1px solid rgba(14,42,94,.06)}.login-card .btn-primary{height:48px;border-radius:var(--r-xl);background:linear-gradient(135deg,var(--c-orange) 0%,var(--c-orange-dark) 100%);font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--c-text-on-dark);box-shadow:0 4px 14px #e85d0a59;border:none;cursor:pointer;transition:all var(--t-spring)}.login-card .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e85d0a73}.login-card .btn-primary:active:not(:disabled){transform:translateY(0)}.login-card .btn-secondary{height:48px;border-radius:var(--r-xl);font-size:var(--text-md);transition:all var(--t-spring)}.login-card .btn-secondary:hover:not(:disabled){transform:translateY(-2px);background:#0e2a5e0a}.login-card .btn-secondary:active:not(:disabled){transform:translateY(0)}.login-card__footer{margin-top:28px;padding-top:20px;border-top:1px solid rgba(14,42,94,.08);display:flex;flex-direction:column;gap:12px;align-items:center}.login-card__footer-roles{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.role-chip{font-size:var(--text-sm);font-weight:700;padding:4px 12px;border-radius:var(--r-full);letter-spacing:.02em;transition:all var(--t-fast)}.role-chip:hover{transform:translateY(-1px)}.role-chip--administrador{background:var(--c-navy);color:var(--c-text-on-dark)}.role-chip--supervisor{background:var(--c-navy-subtle);color:var(--c-navy-medium)}.role-chip--inspector{background:var(--c-orange-subtle);color:var(--c-orange-dark)}.role-chip--consulta{background:var(--c-bg);color:var(--c-text-secondary)}.login-card__footer-text{font-size:var(--text-sm);color:var(--c-text-secondary);margin:0;letter-spacing:.02em;opacity:.7}.recover-ok{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;text-align:center}.recover-ok__ico{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--c-success-subtle);color:var(--c-success);border-radius:50%;margin-bottom:8px;border:1.5px solid var(--c-success-border)}.recover-ok p{font-size:var(--text-lg);font-weight:600;color:var(--c-navy);margin:0}.recover-ok__hint{font-size:var(--text-md)!important;font-weight:400!important;color:var(--c-text-secondary)!important;opacity:.8}.login-public-btns-mobile{display:none}.login-public-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 18px;background:var(--c-surface);border:1.5px solid rgba(14,42,94,.12);border-radius:var(--r-xl);color:var(--c-navy);font-size:var(--text-md);font-weight:600;font-family:var(--font-display);cursor:pointer;letter-spacing:-.01em;box-shadow:var(--shadow-card);transition:all var(--t-spring)}.login-public-btn:hover{background:var(--c-orange-faint);border-color:var(--c-orange);color:var(--c-orange-dark);box-shadow:0 4px 12px #e85d0a26;transform:translateY(-2px)}.login-public-btn:active{transform:translateY(0)}@keyframes grid-move{0%{transform:translate(0)}to{transform:translate(32px,32px)}}@keyframes fire-pulse{0%{transform:scale(1) translate(0);opacity:.7}50%{transform:scale(1.15) translate(-20px,20px);opacity:.9}to{transform:scale(.9) translate(10px,-10px);opacity:.6}}@keyframes logo-float{0%,to{transform:translateY(0);filter:drop-shadow(0 8px 24px rgba(232,93,10,.3))}50%{transform:translateY(-8px);filter:drop-shadow(0 14px 32px rgba(232,93,10,.5))}}@keyframes card-appear{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shine-sweep{0%{background-position:-200% -200%}to{background-position:200% 200%}}@keyframes login-shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}@media (max-width: 820px){.login-side{display:none}.login-root{background:var(--c-bg);flex-direction:column}.login-main{flex-direction:column;align-items:center;justify-content:flex-start;padding-top:48px;gap:0;background:radial-gradient(circle at top,var(--c-bg-subtle) 0%,var(--c-bg) 100%)}.login-card{box-shadow:0 10px 30px #0e2a5e14;border-color:#0e2a5e14;background:var(--c-surface);max-width:440px}.login-public-btns-mobile{display:flex;flex-direction:column;gap:12px;width:100%;max-width:440px;padding:0 0 20px}}@media (max-width: 480px){.login-main{padding:24px 16px 32px}.login-card{padding:32px 24px 28px;border-radius:var(--r-3xl)}.login-card__title{font-size:22px}.login-public-btns-mobile{padding:0 0 16px}}:root{--c-navy: #0E2A5E;--c-navy-dark: #091D42;--c-navy-darkest: #060F1F;--c-navy-medium: #1A4494;--c-navy-light: #133577;--c-navy-subtle: #E4EEF9;--c-navy-subtle-border: #C4D8F4;--c-orange: #E85D0A;--c-orange-dark: #C94D06;--c-orange-subtle: #FDEEDE;--c-orange-subtle-border: #F8B07F;--c-orange-faint: #FFF5F0;--c-amber: #F5A623;--c-success: #1E7D3F;--c-success-dark: #155E30;--c-success-subtle: #E6F4EC;--c-success-border: #A3D4B5;--c-success-text: #174D2A;--c-error: #D93025;--c-error-dark: #B22318;--c-error-text: #7A1510;--c-error-subtle: #FDECEA;--c-error-border: #F5B8B5;--c-warning: #C94D06;--c-warning-subtle: #FDEEDE;--c-warning-border: #F8B07F;--c-amber-subtle: #FEF3DA;--c-amber-text: #C07D00;--c-amber-dark-text: #7A4F00;--c-amber-border: #F5D98A;--c-blue: #2E6ACC;--c-blue-light: #5B8FD9;--c-purple: #8604FF;--c-purple-subtle: #d1c7fa;--c-purple-text: #432874;--c-bg: #EDEAE4;--c-bg-subtle: #F7F5F2;--c-surface: #ffffff;--c-surface-hover: #F7F5F2;--c-navy-subtle-hover: #F0F5FC;--c-border: #D6D1CA;--c-border-hover: #C0B9B1;--c-border-strong: #B4B2A9;--c-border-subtle: #F0EDE8;--c-text: #0E2A5E;--c-text-body: #2A3F5F;--c-text-secondary: #5A6B82;--c-text-muted: #9AAABB;--c-text-dim: #888780;--c-text-subtle: #C0B9B1;--c-text-on-dark: #ffffff;--c-text-darko: #060F1F;--font-display: "Sora", system-ui, sans-serif;--font-body: "Inter", "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-2xs: 9px;--text-xs: 10px;--text-sm: 11px;--text-sm: 11.5px;--text-base: 12px;--text-base: 12.5px;--text-md: 13px;--text-md: 13.5px;--text-lg: 14px;--text-xl: 15px;--text-2xl: 16px;--text-3xl: 22px;--text-4xl: 26px;--text-5xl: 30px;--sp-1: 4px;--sp-2: 6px;--sp-3: 8px;--sp-4: 10px;--sp-5: 12px;--sp-6: 14px;--sp-7: 16px;--sp-8: 20px;--sp-9: 24px;--sp-10: 28px;--sp-11: 32px;--sp-12: 40px;--r-xs: 4px;--r-sm: 6px;--r-md: 7px;--r-lg: 8px;--r-xl: 10px;--r-2xl: 12px;--r-3xl: 14px;--r-4xl: 16px;--r-full: 99px;--h-topbar: 58px;--h-btn-sm: 32px;--h-btn-md: 38px;--h-btn-lg: 44px;--h-input-sm: 32px;--h-input-md: 40px;--h-input-lg: 42px;--h-icon-btn: 28px;--shadow-topbar: 0 2px 12px rgba(6, 15, 31, .35);--shadow-card: 0 1px 4px rgba(14, 42, 94, .05);--shadow-card-md: 0 2px 6px rgba(14, 42, 94, .06);--shadow-card-hover: 0 10px 32px rgba(14, 42, 94, .16);--shadow-modal: 0 24px 80px rgba(14, 42, 94, .28);--shadow-btn-orange: 0 2px 8px rgba(232, 93, 10, .3);--shadow-btn-orange-h: 0 4px 14px rgba(232, 93, 10, .4);--shadow-btn-green: 0 2px 8px rgba(30, 125, 63, .25);--shadow-focus-navy: 0 0 0 3px rgba(14, 42, 94, .08);--shadow-focus-error: 0 0 0 3px rgba(217, 48, 37, .08);--shadow-editor: 0 1px 4px rgba(14, 42, 94, .05);--t-fast: .12s ease;--t-base: .15s ease;--t-slow: .22s ease;--t-spring: .22s cubic-bezier(.22, 1, .36, 1);--z-topbar: 20;--z-overlay: 1000}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:var(--text-md);line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--c-border-hover)}:focus-visible{outline:2px solid var(--c-orange);outline-offset:2px}::selection{background:var(--c-navy-subtle);color:var(--c-navy)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:var(--text-xl);color:var(--c-text-muted);gap:var(--sp-3)}@keyframes fo-spin{to{transform:rotate(360deg)}}@keyframes fo-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes fo-fade-in{0%{opacity:0}to{opacity:1}}@keyframes fo-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes fo-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}@keyframes fo-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fo-dropdown-in{0%{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fo-slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);border:none;border-radius:var(--r-lg);font-family:var(--font-body);font-size:var(--text-md);font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--t-base),box-shadow var(--t-base),border-color var(--t-base),color var(--t-base),transform var(--t-fast);text-decoration:none}.btn:disabled{cursor:not-allowed;opacity:.5;box-shadow:none!important}.btn-primary{height:var(--h-btn-md);padding:0 var(--sp-9);background:var(--c-orange);color:var(--c-text-on-dark);box-shadow:var(--shadow-btn-orange);font-family:var(--font-display);font-weight:700;letter-spacing:-.01em}.btn-primary:hover:not(:disabled){background:var(--c-orange-dark);box-shadow:var(--shadow-btn-orange-h)}.btn-primary--lg{height:var(--h-btn-lg);font-size:var(--text-lg)}.btn-primary--sm{height:var(--h-btn-sm);font-size:var(--text-base);padding:0 var(--sp-7)}.btn-secondary{height:var(--h-btn-md);padding:0 var(--sp-7);background:var(--c-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-secondary:hover:not(:disabled){background:var(--c-bg-subtle);border-color:var(--c-border-hover)}.btn-secondary--sm{height:var(--h-btn-sm);font-size:var(--text-base)}.btn-cancel{height:var(--h-btn-md);padding:0 var(--sp-7);background:var(--c-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-cancel:hover:not(:disabled){background:var(--c-bg-subtle);border-color:var(--c-border-hover)}.btn-navy{height:var(--h-btn-md);padding:0 var(--sp-7);background:var(--c-navy);color:var(--c-text-on-dark);border:1.5px solid var(--c-navy)}.btn-navy:hover:not(:disabled){background:var(--c-navy-medium);border-color:var(--c-navy-medium)}.btn-navy--sm{height:var(--h-btn-sm);font-size:var(--text-base)}.btn-success{height:var(--h-btn-md);padding:0 var(--sp-7);background:var(--c-success);color:var(--c-text-on-dark);border:1.5px solid var(--c-success);box-shadow:var(--shadow-btn-green)}.btn-success:hover:not(:disabled){background:var(--c-success-dark);border-color:var(--c-success-dark)}.btn-success--sm{height:var(--h-btn-sm);font-size:var(--text-base)}.btn-danger{height:var(--h-btn-md);padding:0 var(--sp-7);background:var(--c-error);color:var(--c-text-on-dark);border:1.5px solid var(--c-error)}.btn-danger:hover:not(:disabled){background:#b71c1c;border-color:#b71c1c}.btn-danger--sm{height:var(--h-btn-sm);font-size:var(--text-base)}.btn--full{width:100%;display:flex}.btn-ghost-dark{height:34px;padding:0 var(--sp-6);background:transparent;color:#fff9;border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r-lg);font-size:var(--text-base)}.btn-ghost-dark:hover:not(:disabled){background:#ffffff14;border-color:#ffffff52;color:var(--c-text-on-dark)}.btn-ghost-dark:disabled{opacity:.45;cursor:not-allowed}.btn-dashed{width:100%;height:auto;padding:var(--sp-3) var(--sp-5);background:none;border:1.5px dashed var(--c-border);color:var(--c-text-muted);font-size:var(--text-base);border-radius:var(--r-lg);transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast)}.btn-dashed:hover{border-color:var(--c-orange);color:var(--c-orange);background:var(--c-orange-faint)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:var(--h-icon-btn);height:var(--h-icon-btn);border-radius:var(--r-sm);border:1.5px solid var(--c-border);cursor:pointer;background:var(--c-surface);color:var(--c-text-secondary);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);flex-shrink:0}.btn-icon:hover{background:var(--c-bg-subtle)}.btn-icon--danger:hover{background:var(--c-error-subtle);border-color:var(--c-error-border);color:var(--c-error)}.btn-icon--primary{border-color:var(--c-navy);color:var(--c-navy)}.btn-icon--primary:hover{background:var(--c-navy-subtle)}.btn-spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.35);border-top-color:var(--c-text-on-dark);border-radius:50%;animation:fo-spin .7s linear infinite;flex-shrink:0}.btn-spinner--dark{border-color:#0e2a5e33;border-top-color:var(--c-navy)}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);font-size:var(--text-xs);font-weight:700;padding:2px var(--sp-3);border-radius:var(--r-full);white-space:nowrap;letter-spacing:.02em}.badge-navy{background:var(--c-navy-subtle);color:var(--c-navy-medium)}.badge-orange{background:var(--c-orange-subtle);color:var(--c-orange-dark)}.badge-success{background:var(--c-success-subtle);color:var(--c-success-text)}.badge-error{background:var(--c-error-subtle);color:var(--c-error-text)}.badge-warning{background:var(--c-warning-subtle);color:var(--c-warning)}.badge-neutral{background:var(--c-bg);color:var(--c-text-secondary)}.badge-amber{background:#f5a62326;color:#8a5800}.badge-outline{background:transparent;border:1.5px solid var(--c-border);color:var(--c-text-secondary)}.badge-dot:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--r-sm);font-size:var(--text-sm);font-weight:700;white-space:nowrap;letter-spacing:.02em}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-badge--borrador{background:var(--c-bg);color:var(--c-text-secondary)}.status-badge--borrador:before{background:var(--c-text-muted)}.status-badge--pendiente{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--pendiente:before{background:var(--c-amber-text)}.status-badge--pagada{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--pagada:before{background:var(--c-success)}.status-badge--vencida{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--vencida:before{background:var(--c-error)}.status-badge--anulada{background:var(--c-bg);color:var(--c-text-muted)}.status-badge--anulada:before{background:var(--c-border-hover)}.status-badge--en_progreso{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--en_progreso:before{background:var(--c-amber)}.status-badge--completada{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--completada:before{background:var(--c-success)}.status-badge--cancelada{background:var(--c-bg);color:var(--c-text-secondary)}.status-badge--cancelada:before{background:var(--c-border-hover)}.status-badge--aprobado{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--aprobado:before{background:var(--c-success)}.status-badge--aprobado_condicionado{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--aprobado_condicionado:before{background:var(--c-amber)}.status-badge--reprobado{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--reprobado:before{background:var(--c-error)}.status-badge--sin_concepto{background:var(--c-bg);color:var(--c-text-secondary)}.status-badge--sin_concepto:before{background:var(--c-border-hover)}.status-badge--favorable{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--favorable:before{background:var(--c-success)}.status-badge--condicionado{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--condicionado:before{background:var(--c-amber)}.status-badge--no_favorable{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--no_favorable:before{background:var(--c-error)}.status-badge--provisional{background:var(--c-navy-subtle);color:var(--c-navy-medium)}.status-badge--provisional:before{background:var(--c-blue)}.status-badge--activo{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--activo:before{background:var(--c-success)}.status-badge--suspendido{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--suspendido:before{background:var(--c-amber)}.status-badge--inactivo{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--inactivo:before{background:var(--c-error)}.status-badge--bloqueado{background:var(--c-purple-subtle);color:var(--c-purple)}.status-badge--bloqueado:before{background:var(--c-purple)}.status-badge--eliminado{background:var(--c-warning-subtle);color:var(--c-warning)}.status-badge--eliminado:before{background:var(--c-warning)}.status-badge--vigente{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--vigente:before{background:var(--c-success)}.status-badge--vencido{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--vencido:before{background:var(--c-error)}.status-badge--revocado{background:var(--c-bg);color:var(--c-text-secondary)}.status-badge--revocado:before{background:var(--c-border-hover)}.status-badge--verde{background:var(--c-success-subtle);color:var(--c-success)}.status-badge--verde:before{background:var(--c-success)}.status-badge--amarillo{background:var(--c-amber-subtle);color:var(--c-amber-text)}.status-badge--amarillo:before{background:var(--c-amber)}.status-badge--rojo{background:var(--c-error-subtle);color:var(--c-error)}.status-badge--rojo:before{background:var(--c-error)}.status-badge--fisico{background:var(--c-navy-subtle);color:var(--c-navy)}.status-badge--fisico:before{background:var(--c-navy-subtle);color:var(--c-navy)}.status-badge--digital{background:var(--c-orange-subtle);color:var(--c-orange-dark)}.status-badge--digital:before{background:var(--c-orange-subtle);color:var(--c-orange-dark)}.chip{font-size:var(--text-sm);padding:2px var(--sp-3);border-radius:var(--r-full);background:var(--c-navy-subtle);color:var(--c-navy-medium);border:1px solid var(--c-navy-subtle-border);font-weight:500}.chip--warning{background:var(--c-orange-subtle);color:var(--c-orange-dark);border-color:var(--c-orange-subtle-border)}.chip--tipo{background:var(--c-bg);color:var(--c-text-secondary);border:none;border-radius:var(--r-xs);font-weight:600}.alert{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-10);font-size:var(--text-md);font-weight:600;animation:fo-slide-down .25s ease;border-bottom:1px solid transparent}.alert__close{margin-left:auto;background:none;border:none;cursor:pointer;opacity:.5;transition:opacity var(--t-fast);display:flex;color:inherit;padding:2px}.alert__close:hover{opacity:1}.alert--success{background:var(--c-success-subtle);color:var(--c-success-text);border-color:var(--c-success-border)}.alert--error{background:var(--c-error-subtle);color:var(--c-error-text);border-color:var(--c-error-border)}.alert--warning{background:var(--c-warning-subtle);color:var(--c-warning);border-color:var(--c-warning-border)}.alert--info{background:var(--c-navy-subtle);color:var(--c-navy);border-color:var(--c-navy-subtle-border)}.toast{position:fixed;bottom:24px;right:24px;z-index:calc(var(--z-overlay) + 10);min-width:280px;max-width:420px;padding:var(--sp-5) var(--sp-7);border-radius:var(--r-2xl);font-size:var(--text-md);font-weight:600;box-shadow:var(--shadow-modal);animation:fo-scale-in .2s ease;display:flex;align-items:center;gap:var(--sp-4)}.toast--success{background:var(--c-success);color:var(--c-text-on-dark)}.toast--error{background:var(--c-error);color:var(--c-text-on-dark)}.toast--warning{background:var(--c-warning);color:var(--c-text-on-dark)}.toast--info{background:var(--c-navy);color:var(--c-text-on-dark)}.form-field{display:flex;flex-direction:column;gap:5px}.form-label{font-size:var(--text-base);font-weight:600;color:var(--c-navy);letter-spacing:.02em;line-height:1.2}.form-label--row{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-5)}.form-forgot{font-size:var(--text-base);font-weight:600;color:var(--c-orange);background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.form-forgot:hover{text-decoration:underline;color:var(--c-orange-dark)}.form-input,.form-select,.form-textarea{border:1.5px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--text-md);font-family:var(--font-body);padding:0 var(--sp-5);height:var(--h-input-md);outline:none;width:100%;background:var(--c-bg-subtle);color:var(--c-navy);transition:border-color var(--t-base),box-shadow var(--t-base),background var(--t-base)}.form-input::placeholder,.form-textarea::placeholder{color:var(--c-text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--c-navy);background:var(--c-surface);box-shadow:var(--shadow-focus-navy)}.form-input--error,.form-select--error,.form-textarea--error{border-color:var(--c-error)!important;box-shadow:var(--shadow-focus-error)!important}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--c-bg);color:var(--c-text-muted);cursor:not-allowed}.form-textarea{height:auto;min-height:70px;padding:var(--sp-4) var(--sp-5);resize:vertical}.form-input-wrap{position:relative;display:flex;align-items:center}.form-input-wrap .form-input{padding-left:36px}.form-input-icon{position:absolute;left:11px;color:var(--c-navy);opacity:.4;pointer-events:none}.form-input-toggle{position:absolute;right:11px;background:none;border:none;cursor:pointer;color:var(--c-navy);opacity:.4;padding:4px;transition:opacity var(--t-fast)}.form-input-toggle:hover{opacity:.8}.form-error{font-size:var(--text-sm);color:var(--c-error-text);display:flex;align-items:center;gap:5px}.form-hint{font-size:var(--text-sm);color:var(--c-text-muted);line-height:1.4}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#060f1f8c;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);padding:var(--sp-7);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fo-fade-in .18s ease}.modal{background:var(--c-surface);border-radius:var(--r-4xl);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal);animation:fo-scale-in .2s ease}.modal--sm{max-width:400px}.modal--md{max-width:560px}.modal--lg{max-width:720px}.modal--xl{max-width:900px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-7) var(--sp-9);background:var(--c-navy);border-radius:var(--r-4xl) var(--r-4xl) 0 0;flex-shrink:0;gap:var(--sp-5)}.modal__title{margin:0;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--c-text-on-dark);letter-spacing:-.01em}.modal__close{background:none;border:none;cursor:pointer;color:#ffffff80;display:flex;align-items:center;padding:5px;border-radius:var(--r-md);transition:background var(--t-fast),color var(--t-fast);flex-shrink:0}.modal__close:hover{background:#ffffff1a;color:var(--c-text-on-dark)}.modal__body{padding:var(--sp-8) var(--sp-9);display:flex;flex-direction:column;gap:var(--sp-6);overflow-y:auto;flex:1;min-height:0}.modal__footer{display:flex;justify-content:flex-end;gap:var(--sp-4);padding:var(--sp-6) var(--sp-9);border-top:1px solid var(--c-border);background:var(--c-bg-subtle);border-radius:0 0 var(--r-4xl) var(--r-4xl);flex-shrink:0}.modal__confirm-text{font-size:var(--text-md);color:var(--c-text-secondary);line-height:1.6;text-align:center;padding:var(--sp-3) 0}.card{background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--r-2xl);box-shadow:var(--shadow-card)}.card--hover{transition:border-color var(--t-spring),box-shadow var(--t-spring),transform var(--t-spring);cursor:pointer;overflow:hidden}.card--hover:hover{border-color:var(--c-navy-subtle-border);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card--accent{position:relative;overflow:hidden}.card--accent:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--c-orange);border-radius:var(--r-2xl) var(--r-2xl) 0 0;transform:scaleX(0);transform-origin:left;transition:transform var(--t-spring)}.card--accent:hover:before{transform:scaleX(1)}.card-empty{padding:var(--sp-12) var(--sp-8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-5);color:var(--c-text-muted);text-align:center;font-size:var(--text-md);font-style:italic}.list-item{padding:var(--sp-5) var(--sp-7);border-bottom:1px solid var(--c-bg);cursor:pointer;transition:background var(--t-fast);display:flex;align-items:flex-start;gap:var(--sp-4)}.list-item:hover{background:var(--c-bg-subtle)}.list-item--active{background:var(--c-navy-subtle);border-left:3px solid var(--c-navy)}.list-item__name{font-size:var(--text-md);font-weight:600;color:var(--c-navy);line-height:1.3}.list-item__meta{font-size:var(--text-sm);color:var(--c-text-secondary);margin-top:2px;display:flex;flex-wrap:wrap;gap:5px;align-items:center}.list-empty{padding:40px var(--sp-8);text-align:center;color:var(--c-text-muted);font-size:var(--text-md);font-style:italic}.tabs{display:flex;border-bottom:1px solid var(--c-border)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:var(--sp-4) var(--sp-1);font-size:var(--text-base);font-weight:600;font-family:var(--font-body);color:var(--c-text-secondary);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:color var(--t-fast),border-color var(--t-fast);margin-bottom:-1px}.tab:hover{color:var(--c-navy)}.tab--active{color:var(--c-navy);border-bottom-color:var(--c-orange)}.tabs-wide .tab{flex:none;padding:var(--sp-4) var(--sp-7)}.section-block{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-xl);margin-bottom:var(--sp-7);overflow:hidden;box-shadow:var(--shadow-card)}.section-block__header{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-5) var(--sp-7);background:var(--c-bg-subtle);border-bottom:1px solid var(--c-border);cursor:pointer;transition:background var(--t-fast);-webkit-user-select:none;user-select:none}.section-block__header:hover{background:var(--c-bg)}.section-block__index{font-size:var(--text-md);font-weight:700;color:var(--c-navy);flex-shrink:0}.section-block__name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--c-navy);flex:1;letter-spacing:-.01em}.section-block__norm{font-size:var(--text-sm);color:var(--c-text-secondary);font-family:var(--font-mono)}.section-block__body{padding:var(--sp-5) var(--sp-7);display:flex;flex-direction:column;gap:var(--sp-3)}.item-row{display:flex;align-items:flex-start;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);border:1.5px solid var(--c-border);border-radius:var(--r-lg);background:var(--c-surface);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.item-row:hover{border-color:var(--c-navy);box-shadow:0 1px 4px #0e2a5e14}.item-row__num{font-size:var(--text-sm);font-weight:700;color:var(--c-text-muted);margin-top:2px;min-width:20px;flex-shrink:0}.item-row__content{flex:1;min-width:0}.item-row__text{font-size:var(--text-md);color:var(--c-navy);font-weight:500;line-height:1.4}.item-row__meta{font-size:var(--text-sm);color:var(--c-text-secondary);margin-top:3px;display:flex;gap:var(--sp-3);align-items:center;flex-wrap:wrap}.item-row__actions{display:flex;gap:var(--sp-1);flex-shrink:0}.options-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.option-notice{font-size:var(--text-sm);color:var(--c-warning);margin-top:4px;font-style:italic}.spinner{width:20px;height:20px;border:2.5px solid var(--c-border);border-top-color:var(--c-navy);border-radius:50%;animation:fo-spin .7s linear infinite;flex-shrink:0}.spinner--sm{width:14px;height:14px;border-width:2px}.spinner--lg{width:28px;height:28px;border-width:3px}.spinner--white{border-color:#ffffff40;border-top-color:#fff}.spinner--orange{border-color:#e85d0a33;border-top-color:var(--c-orange)}.editor-header{padding:var(--sp-7) var(--sp-9);background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:var(--sp-5);box-shadow:var(--shadow-editor);flex-shrink:0}.editor-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--c-navy);flex:1;letter-spacing:-.01em;min-width:0}.editor-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--sp-5);color:var(--c-text-muted);text-align:center;font-size:var(--text-md)}.toolbar-bar{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-9);background:var(--c-bg-subtle);border-bottom:1px solid var(--c-border);font-size:var(--text-md);color:var(--c-navy);flex-wrap:wrap;flex-shrink:0}.toolbar-bar select{height:var(--h-btn-sm);padding:0 var(--sp-3);border:1.5px solid var(--c-border);border-radius:var(--r-md);font-family:var(--font-body);font-size:var(--text-md);color:var(--c-navy);background:var(--c-surface);outline:none;cursor:pointer}.toolbar-bar select:focus{border-color:var(--c-navy);box-shadow:var(--shadow-focus-navy)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-md)}.data-table th{text-align:left;font-size:var(--text-base);font-weight:700;color:var(--c-text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:var(--sp-4) var(--sp-5);border-bottom:2px solid var(--c-border);background:var(--c-bg-subtle);white-space:nowrap}.data-table td{padding:var(--sp-5);border-bottom:1px solid var(--c-bg);color:var(--c-navy);vertical-align:middle}.data-table tr:hover td{background:var(--c-bg-subtle)}.data-table tr:last-child td{border-bottom:none}.pagination{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-5) var(--sp-7);font-size:var(--text-base);color:var(--c-text-secondary)}.page-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--c-border);border-radius:var(--r-md);background:var(--c-surface);cursor:pointer;font-size:var(--text-md);color:var(--c-navy);transition:background var(--t-fast),border-color var(--t-fast)}.page-btn:hover:not(:disabled){background:var(--c-bg-subtle)}.page-btn--active{background:var(--c-navy);color:#fff;border-color:var(--c-navy)}.filter-bar{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-5) var(--sp-7);border-bottom:1px solid var(--c-border);background:var(--c-surface);flex-wrap:wrap}.filter-bar .form-input{max-width:260px}.filter-label{font-size:var(--text-base);font-weight:600;color:var(--c-text-secondary);white-space:nowrap}.avatar{width:34px;height:34px;border-radius:var(--r-lg);background:var(--c-navy-light);border:1.5px solid rgba(255,255,255,.14);color:var(--c-text-on-dark);font-family:var(--font-display);font-size:var(--text-md);font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-user-select:none;user-select:none}.avatar--lg{width:44px;height:44px;font-size:var(--text-2xl)}.page-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-2)}.page-welcome__icon{width:56px;height:56px;background:var(--c-orange);border-radius:var(--r-4xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-1);box-shadow:var(--shadow-btn-orange)}.page-welcome__title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:800;color:var(--c-navy);letter-spacing:-.02em}.page-welcome__title span{color:var(--c-orange)}.page-welcome__sub{font-size:var(--text-md);color:var(--c-text-muted);line-height:1.5;max-width:420px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#060f1f8c;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:var(--c-surface);border-radius:var(--r-4xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal);display:flex;flex-direction:column}.modal-box--sm{max-width:440px}.modal-box--lg{max-width:680px}.modal-box--xl{max-width:820px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 24px 16px;background:var(--c-navy);border-bottom:1px solid rgba(255,255,255,.07);border-radius:var(--r-4xl) var(--r-4xl) 0 0;position:sticky;top:0;z-index:2;flex-shrink:0}.modal-header--light{background:var(--c-bg-subtle);border-bottom:1px solid var(--c-border)}.modal-header--danger{background:var(--c-error-subtle);border-bottom:1px solid var(--c-error-border)}.modal-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--c-text-on-dark);letter-spacing:-.01em;margin:0;flex:1}.modal-header--light .modal-title{color:var(--c-navy)}.modal-header--danger .modal-title{color:var(--c-error-text)}.modal-close{background:none;border:none;cursor:pointer;color:#ffffff80;display:flex;align-items:center;padding:5px;border-radius:var(--r-md);transition:background var(--t-fast),color var(--t-fast);flex-shrink:0}.modal-close:hover{background:#ffffff1a;color:var(--c-text-on-dark)}.modal-header--light .modal-close{color:var(--c-text-muted)}.modal-header--light .modal-close:hover{background:var(--c-bg);color:var(--c-navy)}.modal-header--danger .modal-close{color:var(--c-error-dark)}.modal-header--danger .modal-close:hover{background:#d930251f;color:var(--c-error-text)}.modal-body{padding:22px 24px;display:flex;flex-direction:column;gap:14px;flex:1;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid var(--c-border);background:var(--c-bg-subtle);border-radius:0 0 var(--r-4xl) var(--r-4xl);flex-shrink:0;position:sticky;bottom:0}.modal-error{display:flex;align-items:center;gap:6px;background:var(--c-error-subtle);border:1px solid var(--c-error-border);border-radius:var(--r-lg);padding:8px 12px;font-size:var(--text-md);color:var(--c-error-text)}.modal-error--sm{font-size:var(--text-base);padding:5px 10px}.page-header{display:flex;align-items:center;gap:var(--sp-5);padding:var(--sp-6) var(--sp-9);background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;flex-wrap:wrap}.page-header__info{display:flex;align-items:center;gap:var(--sp-5);flex:1;min-width:0}.page-header__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--c-navy-subtle);border-radius:var(--r-lg);color:var(--c-navy);flex-shrink:0}.page-header__text{flex:1;min-width:0}.page-header__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--c-navy);letter-spacing:-.01em;margin:0;line-height:1.2}.page-header__desc{font-size:var(--text-md);color:var(--c-text-muted);margin-top:2px;margin-bottom:0}.page-header__actions{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-1);padding:var(--sp-4) var(--sp-7);border-top:1px solid var(--c-border);background:var(--c-bg-subtle);flex-shrink:0}.page-btn{display:inline-flex;align-items:center;justify-content:center;height:28px;min-width:28px;padding:0 var(--sp-2);border-radius:var(--r-sm);border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text-secondary);font-size:var(--text-sm);font-weight:600;font-family:var(--font-body);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}.page-btn:hover:not(:disabled){background:var(--c-navy-subtle);border-color:var(--c-blue-light);color:var(--c-navy)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-btn--active{background:var(--c-navy);border-color:var(--c-navy);color:var(--c-text-on-dark)}.page-info{font-size:var(--text-sm);color:var(--c-text-secondary);padding:0 var(--sp-3);white-space:nowrap;flex-shrink:0}.badge--vigente{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--vencido{background:var(--c-error-subtle);color:var(--c-error-text);border:1px solid var(--c-error-border)}.badge--revocado{background:var(--c-bg);color:var(--c-text-secondary);border:1px solid var(--c-border)}.badge--favorable{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--condicionado{background:var(--c-amber-subtle);color:var(--c-amber-dark-text);border:1px solid var(--c-amber-border)}.badge--no_favorable{background:var(--c-error-subtle);color:var(--c-error-text);border:1px solid var(--c-error-border)}.badge--provisional{background:var(--c-navy-subtle);color:var(--c-navy-medium);border:1px solid var(--c-navy-subtle-border)}.badge--borrador{background:var(--c-bg);color:var(--c-text-secondary);border:1px solid var(--c-border)}.badge--pendiente{background:var(--c-amber-subtle);color:var(--c-amber-dark-text);border:1px solid var(--c-amber-border)}.badge--pagada{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--anulada{background:var(--c-error-subtle);color:var(--c-error-text);border:1px solid var(--c-error-border)}.badge--en_progreso{background:var(--c-navy-subtle);color:var(--c-navy-medium);border:1px solid var(--c-navy-subtle-border)}.badge--completada{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--cancelada{background:var(--c-bg);color:var(--c-text-secondary);border:1px solid var(--c-border)}.badge--reprogramada{background:var(--c-purple-subtle);color:var(--c-purple-text);border:1px solid var(--c-purple-subtle)}.badge--programada{background:var(--c-navy-subtle);color:var(--c-navy-medium);border:1px solid var(--c-navy-subtle-border)}.badge--urgente{background:var(--c-error-subtle);color:var(--c-error-text);border:1px solid var(--c-error-border)}.badge--validada{background:var(--c-navy-subtle);color:var(--c-navy-medium);border:1px solid var(--c-navy-subtle-border)}.badge--rechazada{background:var(--c-error-subtle);color:var(--c-error-text);border:1px solid var(--c-error-border)}.badge--convertida{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--eliminado{background:var(--c-purple-subtle);color:var(--c-purple-text);border:1px solid var(--c-purple-subtle)}.badge--activo{background:var(--c-success-subtle);color:var(--c-success-text);border:1px solid var(--c-success-border)}.badge--inactivo{background:var(--c-bg);color:var(--c-text-secondary);border:1px solid var(--c-border)}.badge--suspendido{background:var(--c-amber-subtle);color:var(--c-amber-dark-text);border:1px solid var(--c-amber-border)}.badge--bloqueado{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd}.alert--ok{background:var(--c-success-subtle);color:var(--c-success-text);border-color:var(--c-success-border)}@media (max-width: 768px){.modal-overlay{padding:0;align-items:flex-end}.modal-box{max-width:100%;max-height:92dvh;border-radius:var(--r-4xl) var(--r-4xl) 0 0}.modal-box--sm,.modal-box--lg,.modal-box--xl{max-width:100%}.alert{padding:var(--sp-4) var(--sp-7)}.filter-bar{gap:var(--sp-3)}.filter-bar .form-input{max-width:100%}.toolbar-bar{padding:var(--sp-3) var(--sp-7);gap:var(--sp-3)}.editor-header{padding:var(--sp-5) var(--sp-7);flex-wrap:wrap;gap:var(--sp-3)}}@media (max-width: 480px){.modal__body{padding:var(--sp-7)}.modal__footer{padding:var(--sp-5) var(--sp-7);flex-wrap:wrap}.modal__footer>*{flex:1;justify-content:center}.btn-volver span{display:none}.btn-volver{padding:6px 9px}}@media (max-width: 900px){.usuarios-layout--split{flex-direction:column}.usuarios-panel{padding:16px}}.cal-topbar{background:var(--c-navy);border-bottom:1px solid rgba(255,255,255,.07);padding:0 28px;height:var(--h-topbar);display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:var(--z-topbar);box-shadow:var(--shadow-topbar)}.cal-topbar__title{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--c-text-on-dark);flex:1;letter-spacing:-.01em}@media (max-width: 820px){.cal-topbar{height:auto;flex-wrap:wrap;padding:8px 14px;gap:8px}.cal-topbar__title{flex:1 1 auto;min-width:0}.insp-topbar__actions{width:100%}.insp-topbar__actions .btn-primario,.insp-topbar__actions .btn-secundario{flex:1;justify-content:center}}.estado-badge{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-sm);font-weight:700;padding:3px 9px;border-radius:var(--r-sm);text-transform:capitalize;white-space:nowrap;letter-spacing:.02em}.estado-badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.sol-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--r-full);font-size:var(--text-sm);font-weight:700;white-space:nowrap;letter-spacing:.04em}.sol-badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.sol-badge--warning{background:var(--c-amber-subtle);color:var(--c-amber-text)}.sol-badge--warning:before{background:var(--c-amber)}.sol-badge--info{background:var(--c-navy-subtle);color:var(--c-navy-medium)}.sol-badge--info:before{background:var(--c-blue)}.sol-badge--success{background:var(--c-success-subtle);color:var(--c-success)}.sol-badge--success:before{background:var(--c-success)}.sol-badge--danger{background:var(--c-error-subtle);color:var(--c-error)}.sol-badge--danger:before{background:var(--c-error)}.btn-volver{display:flex;align-items:center;gap:6px;background:transparent;border:1.5px solid rgba(255,255,255,.18);color:#ffffffa6;font-size:var(--text-base);font-weight:600;font-family:inherit;cursor:pointer;padding:6px 12px;border-radius:var(--r-md);transition:background var(--t-base),border-color var(--t-base),color var(--t-base);white-space:nowrap}.btn-volver:hover{background:#ffffff14;border-color:#ffffff4d;color:var(--c-text-on-dark)}.btn-primario{height:var(--h-btn-md);padding:0 22px;background:var(--c-orange);color:var(--c-text-on-dark);border:none;border-radius:var(--r-lg);font-size:var(--text-md);font-weight:700;font-family:var(--font-display);cursor:pointer;transition:background var(--t-base),box-shadow var(--t-base);box-shadow:0 2px 8px #e85d0a47;letter-spacing:-.01em;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.btn-primario:hover:not(:disabled){background:var(--c-orange-dark);box-shadow:0 4px 14px #e85d0a61}.btn-primario:disabled{background:var(--c-text-muted);box-shadow:none;cursor:not-allowed}.btn-secundario{height:var(--h-btn-md);padding:0 18px;background:var(--c-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);display:inline-flex;align-items:center;gap:6px}.btn-secundario:hover:not(:disabled){background:var(--c-bg-subtle);border-color:var(--c-border-hover)}.btn-secundario:disabled{opacity:.5;cursor:not-allowed}.usuarios-alerta{padding:10px 28px;font-size:var(--text-md);font-weight:600;display:flex;align-items:center;gap:8px;animation:fo-slide-down .25s ease}.usuarios-alerta--ok{background:var(--c-success-subtle);color:var(--c-success-text);border-bottom:1px solid var(--c-success-border)}.usuarios-alerta--error{background:var(--c-error-subtle);color:var(--c-error-text);border-bottom:1px solid var(--c-error-border)}.usuarios-layout{display:flex;gap:0;flex:1;overflow:hidden}.usuarios-panel{flex:1;overflow:auto;padding:20px 28px;min-width:0}.usuarios-layout--split .usuarios-panel{flex:1.4}.filtros-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.filtros-buscar{flex:1;min-width:200px;height:var(--h-btn-md);padding:0 12px;border:1.5px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--text-md);font-family:inherit;background:var(--c-bg-subtle);color:var(--c-navy);outline:none;transition:border-color var(--t-base),box-shadow var(--t-base),background var(--t-base)}.filtros-buscar::placeholder{color:var(--c-text-muted)}.filtros-buscar:focus{border-color:var(--c-navy);background:var(--c-surface);box-shadow:var(--shadow-focus-navy)}.filtros-bar select{height:var(--h-btn-md);padding:0 10px;border:1.5px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--text-md);font-family:inherit;background:var(--c-bg-subtle);color:var(--c-navy);cursor:pointer;outline:none;transition:border-color var(--t-base),box-shadow var(--t-base)}.filtros-bar select:focus{border-color:var(--c-navy);box-shadow:var(--shadow-focus-navy)}.filtros-bar input[type=date]{height:var(--h-btn-md);padding:0 10px;border:1.5px solid var(--c-border);border-radius:var(--r-lg);font-size:var(--text-md);font-family:inherit;background:var(--c-bg-subtle);color:var(--c-navy);cursor:pointer;outline:none;transition:border-color var(--t-base),box-shadow var(--t-base)}.filtros-bar input[type=date]:focus{border-color:var(--c-navy);box-shadow:var(--shadow-focus-navy)}.tabla-wrap{overflow-x:auto;border-radius:var(--r-2xl);border:1px solid var(--c-border);background:var(--c-surface);box-shadow:var(--shadow-card-md)}.usuarios-tabla{width:100%;border-collapse:collapse;font-size:var(--text-md)}.usuarios-tabla thead th{padding:11px 16px;text-align:left;font-size:var(--text-sm);font-weight:700;color:#ffffffa6;letter-spacing:.08em;text-transform:uppercase;background:var(--c-navy);border-bottom:none;white-space:nowrap}.usuarios-tabla tbody tr{border-bottom:1px solid var(--c-bg);cursor:pointer;transition:background .1s}.usuarios-tabla tbody tr:hover{background:var(--c-navy-subtle-hover)}.usuarios-tabla tbody tr:last-child{border-bottom:none}.usuarios-tabla td{padding:11px 16px;vertical-align:middle;color:var(--c-navy)}.fila-activa{background:var(--c-navy-subtle)!important}.fila-eliminada{opacity:.5}.tabla-cargando,.tabla-vacio{text-align:center;padding:52px!important;color:var(--c-text-muted);font-size:var(--text-md);font-style:italic}.celda-usuario{display:flex;align-items:center;gap:10px}.mini-avatar{width:32px;height:32px;border-radius:var(--r-lg);background:var(--c-navy);color:var(--c-text-on-dark);font-family:var(--font-display);font-size:var(--text-md);font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cel-nombre{font-weight:600;color:var(--c-navy);font-size:var(--text-md)}.cel-correo{font-size:var(--text-sm);color:var(--c-text-secondary)}.acciones-row{display:flex;gap:6px;align-items:center}.btn-tabla{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--r-md);border:1.5px solid var(--c-border);cursor:pointer;background:var(--c-surface);color:var(--c-text-secondary);font-size:var(--text-md);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);padding:0}.btn-tabla:hover{background:var(--c-bg-subtle)}.btn-tabla--danger:hover{background:var(--c-error-subtle);border-color:var(--c-error-border);color:var(--c-error)}.btn-tabla--ok:hover{background:var(--c-success-subtle);border-color:var(--c-success-border);color:var(--c-success)}.btn-tabla-estado{height:var(--h-icon-btn);padding:0 8px;border:1.5px solid var(--c-border);border-radius:var(--r-md);font-size:var(--text-base);font-family:inherit;background:var(--c-bg-subtle);color:var(--c-navy);cursor:pointer;outline:none;transition:border-color var(--t-fast)}.btn-tabla-estado:focus{border-color:var(--c-navy)}.page-root{min-height:100vh;display:flex;flex-direction:column;background:var(--c-bg);font-family:var(--font-body)}.topbar{height:var(--h-topbar);background:var(--c-navy);border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;padding:0 var(--sp-10);gap:var(--sp-6);position:sticky;top:0;z-index:var(--z-topbar);box-shadow:var(--shadow-topbar);flex-shrink:0}.topbar__brand{display:flex;align-items:center;gap:var(--sp-4);text-decoration:none}.topbar__brand-mark{width:34px;height:34px;background:var(--c-orange);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.topbar__brand-mark img{width:100%;height:100%;object-fit:contain;padding:4px}.topbar__name{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--c-text-on-dark);letter-spacing:-.01em;white-space:nowrap}.topbar__name-sub{display:block;font-size:var(--text-xs);color:#ffffff59;letter-spacing:.05em;text-transform:uppercase;line-height:1;margin-top:1px;font-family:var(--font-body);font-weight:400}.topbar__page-title{display:flex;align-items:center;gap:var(--sp-3);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--c-text-on-dark);letter-spacing:-.01em;flex:1;min-width:0}.topbar__user{display:flex;align-items:center;gap:var(--sp-5);margin-left:auto}.topbar__user-info{display:flex;flex-direction:column;gap:2px;text-align:right}.topbar__user-name{font-size:var(--text-md);font-weight:600;color:var(--c-text-on-dark);white-space:nowrap}.topbar__user-role{font-size:var(--text-sm);font-weight:700;padding:1px var(--sp-3);border-radius:var(--r-full);text-transform:capitalize;width:fit-content;margin-left:auto;letter-spacing:.02em;background:#e85d0a2e;color:var(--c-amber)}.topbar__user-role--admin{background:#e85d0a2e;color:var(--c-amber)}.topbar__user-role--inspector{background:#e85d0a24;color:#f07230}.topbar__user-role--supervisor{background:#5b8fd92e;color:#8fb5e8}.topbar__user-role--consulta{background:#ffffff17;color:#ffffff80}.topbar__actions{display:flex;align-items:center;gap:var(--sp-4);margin-left:auto}.split-pane{display:flex;flex:1;overflow:hidden;min-height:0}.sidebar{width:320px;min-width:260px;max-width:360px;background:var(--c-surface);border-right:1px solid var(--c-border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar--narrow{width:260px;min-width:220px}.sidebar--wide{width:380px;min-width:320px}.sidebar__header{padding:var(--sp-6) var(--sp-7);border-bottom:1px solid var(--c-border);font-size:var(--text-sm);font-weight:700;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.sidebar__scroll{overflow-y:auto;flex:1}.sidebar__tabs{border-bottom:1px solid var(--c-border);flex-shrink:0}.main-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.main-panel__scroll{flex:1;overflow-y:auto;padding:var(--sp-8) var(--sp-9)}.main-panel__scroll--compact{padding:var(--sp-5) var(--sp-7)}.page-content{flex:1;padding:var(--sp-10) var(--sp-10);max-width:1280px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:var(--sp-10)}.page-content--narrow{max-width:800px}.page-content--wide{max-width:1440px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-5);margin-bottom:var(--sp-5);flex-wrap:wrap}.section-header__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--c-navy);letter-spacing:-.01em}.section-header__sub{font-size:var(--text-sm);color:var(--c-text-secondary);margin-top:2px}.section-header__actions{display:flex;align-items:center;gap:var(--sp-3)}@media (max-width: 768px){.topbar{padding:0 var(--sp-5);gap:var(--sp-3);height:52px}.topbar__user-info{display:none}.split-pane{flex-direction:column;overflow:auto}.sidebar{width:100%;min-width:unset;max-width:unset;border-right:none;border-bottom:1px solid var(--c-border);max-height:55vh;flex-shrink:0}.sidebar--mobile-hidden,.main-panel--mobile-hidden{display:none}.mobile-back{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-7);background:var(--c-bg-subtle);border:none;border-bottom:1px solid var(--c-border);color:var(--c-navy);font-size:var(--text-md);font-weight:600;font-family:var(--font-body);cursor:pointer;width:100%;text-align:left;flex-shrink:0}.mobile-back:hover{background:var(--c-bg)}.page-content{padding:var(--sp-7) var(--sp-7);gap:var(--sp-7)}.main-panel__scroll{padding:var(--sp-5) var(--sp-7)}}@media (max-width: 480px){.topbar{padding:0 var(--sp-4)}.page-content{padding:var(--sp-5);gap:var(--sp-5)}.sidebar--narrow{width:100%}}.mobile-back{display:none}@media (max-width: 768px){.mobile-back{display:flex}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-start{display:flex;align-items:flex-start}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-5{gap:var(--sp-5)}.gap-6{gap:var(--sp-6)}.gap-7{gap:var(--sp-7)}.gap-8{gap:var(--sp-8)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--sp-5)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--sp-6)}@media (max-width: 768px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.text-navy{color:var(--c-navy)}.text-orange{color:var(--c-orange)}.text-secondary{color:var(--c-text-secondary)}.text-muted{color:var(--c-text-muted)}.text-success{color:var(--c-success)}.text-error{color:var(--c-error-text)}.text-warning{color:var(--c-warning)}.text-white{color:var(--c-text-on-dark)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semi{font-weight:600}.font-bold{font-weight:700}.font-black{font-weight:800}.text-center{text-align:center}.text-right{text-align:right}.uppercase{text-transform:uppercase;letter-spacing:.06em}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.italic{font-style:italic}.leading-tight{line-height:1.3}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--sp-1)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.mb-5{margin-bottom:var(--sp-5)}.ml-auto{margin-left:auto}.p-0{padding:0}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.show-mobile{display:none}@media (max-width: 768px){.hide-mobile{display:none!important}.show-mobile{display:flex}}.divider{border:none;border-top:1px solid var(--c-border);margin:var(--sp-5) 0}.shadow-card{box-shadow:var(--shadow-card)}.shadow-modal{box-shadow:var(--shadow-modal)}.info-bar{display:flex;flex-wrap:wrap;gap:var(--sp-4) var(--sp-8);justify-content:center;font-family:var(--font-mono);font-size:var(--text-base);color:var(--c-text-muted);padding:var(--sp-6) var(--sp-8);background:var(--c-surface);border-radius:var(--r-xl);border:1px solid var(--c-border);box-shadow:var(--shadow-card)}.info-bar strong{color:var(--c-navy);font-weight:700}.info-bar__dot{color:var(--c-border);-webkit-user-select:none;user-select:none}.fo-spin{animation:fo-spin .7s linear infinite}.fo-shake{animation:fo-shake .35s ease}
