:root{--color-bg-primary: #F5F7FA;--color-bg-secondary: #FFFFFF;--color-bg-card: #FFFFFF;--color-bg-card-hover: #F0F4FA;--color-bg-input: #FFFFFF;--color-bg-input-focus: #EEF4FF;--color-corp-dark: #003B7A;--color-corp-mid: #1565C0;--color-corp-light: #5B9BD5;--color-accent: #1565C0;--color-accent-dark: #003B7A;--color-accent-glow: rgba(21, 101, 192, .25);--color-accent-subtle: rgba(21, 101, 192, .1);--gradient-brand: linear-gradient(135deg, #1565C0 0%, #003B7A 100%);--gradient-nav: linear-gradient(135deg, #1565C0 0%, #003B7A 100%);--gradient-bg: linear-gradient(160deg, #F5F7FA 0%, #EDF2F7 100%);--gradient-card: #FFFFFF;--color-text-primary: #1A1A2E;--color-text-secondary: #5F6B7A;--color-text-muted: #9AA5B4;--color-text-accent: #1565C0;--color-text-on-dark: #FFFFFF;--color-border: #E0E4EA;--color-border-focus: #1565C0;--color-border-error: rgba(220, 53, 69, .6);--color-error: #DC3545;--color-error-bg: rgba(220, 53, 69, .08);--color-success: #1A7F5A;--color-success-bg: rgba(26, 127, 90, .08);--color-warning: #D97706;--shadow-card: 0 2px 12px rgba(0, 59, 122, .08), 0 1px 3px rgba(0, 0, 0, .06);--shadow-card-hover: 0 8px 24px rgba(0, 59, 122, .14), 0 2px 6px rgba(0, 0, 0, .08);--shadow-accent: 0 4px 16px rgba(21, 101, 192, .2);--shadow-button: 0 4px 14px rgba(21, 101, 192, .3);--shadow-nav: 0 2px 8px rgba(0, 59, 122, .2);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--logo-watermark-url: url(/logo-inatic.jpeg)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background-color:var(--color-bg-primary);background-image:var(--gradient-bg);color:var(--color-text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-text-primary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:#c8d0db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9aa5b4}.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}.alerts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:flex;align-items:center;justify-content:center;animation:alertsFadeIn .15s ease}@keyframes alertsFadeIn{0%{opacity:0}to{opacity:1}}.alerts-modal{background:#fff;border-radius:12px;box-shadow:0 12px 40px #0003;width:100%;max-width:480px;padding:1.5rem;animation:alertsSlideUp .18s ease;max-height:90vh;overflow-y:auto}@keyframes alertsSlideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.alerts-modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.alerts-modal-title-row{display:flex;align-items:center;gap:.5rem}.alerts-modal-icon{font-size:1.2rem}.alerts-modal-title{font-size:1.1rem;font-weight:700;color:var(--color-corp-dark, #1565C0);margin:0}.alerts-modal-close{background:none;border:none;font-size:1rem;color:#6b7280;cursor:pointer;padding:.2rem .4rem;border-radius:4px;line-height:1;flex-shrink:0}.alerts-modal-close:hover{background:#f3f4f6;color:#111}.alerts-modal-desc{font-size:.85rem;color:#4b5563;line-height:1.5;margin-bottom:1.1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.alerts-email-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;min-height:32px}.alerts-loading,.alerts-empty{font-size:.85rem;color:#6b7280;margin:0;padding:.4rem 0}.alerts-email-item{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;gap:.5rem}.alerts-email-text{font-size:.875rem;color:#111827;word-break:break-all}.alerts-item-actions{display:flex;gap:.25rem;flex-shrink:0}.alerts-icon-btn{background:none;border:none;cursor:pointer;font-size:.9rem;padding:.2rem .3rem;border-radius:4px;line-height:1;opacity:.75;transition:opacity .12s,background .12s}.alerts-icon-btn:hover{opacity:1;background:#e5e7eb}.alerts-icon-btn--danger:hover{background:#fee2e2}.alerts-edit-row{display:flex;flex-direction:column;gap:.4rem;width:100%}.alerts-edit-actions{display:flex;gap:.4rem}.alerts-delete-confirm{display:flex;flex-direction:column;gap:.4rem;width:100%}.alerts-delete-text{font-size:.85rem;color:#374151}.alerts-input{width:100%;padding:.45rem .65rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#111827;background:#fff;box-sizing:border-box;transition:border-color .15s}.alerts-input:focus{outline:none;border-color:var(--color-corp-dark, #1565C0);box-shadow:0 0 0 3px #1565c01f}.alerts-btn{padding:.4rem .85rem;border-radius:6px;border:none;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .12s,background .12s;white-space:nowrap}.alerts-btn:disabled{opacity:.5;cursor:not-allowed}.alerts-btn--add{background:var(--color-corp-dark, #1565C0);color:#fff}.alerts-btn--add:hover:not(:disabled){opacity:.88}.alerts-btn--save{background:#16a34a;color:#fff}.alerts-btn--save:hover{opacity:.88}.alerts-btn--cancel{background:#f3f4f6;color:#374151}.alerts-btn--cancel:hover{background:#e5e7eb}.alerts-btn--danger{background:#dc2626;color:#fff}.alerts-btn--danger:hover{opacity:.88}.alerts-add-form{border-top:1px solid #e5e7eb;padding-top:1rem;margin-top:.25rem}.alerts-add-row{display:flex;gap:.5rem;align-items:center}.alerts-field-error{font-size:.8rem;color:#dc2626;margin:.3rem 0 0}.alerts-limit-note{font-size:.78rem;color:#9ca3af;margin:.4rem 0 0}.alerts-limit-reached{font-size:.83rem;color:#6b7280;text-align:center;margin:.75rem 0 0;padding:.5rem;border:1px dashed #d1d5db;border-radius:6px}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-nav{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:56px;background:var(--gradient-nav);border-bottom:none;box-shadow:var(--shadow-nav);position:sticky;top:0;z-index:100}.nav-left{display:flex;align-items:center;gap:2rem}.nav-brand{font-size:var(--font-size-xl);font-weight:700;letter-spacing:2px;color:#fff}.nav-links{display:flex;align-items:center;gap:.25rem}.nav-link{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:#fffc;text-decoration:none;transition:all var(--transition-base);position:relative}.nav-link:hover{color:#fff;background:#ffffff1f}.nav-link.active{color:#fff;background:#fff3;font-weight:600}.nav-link.active:after{content:"";position:absolute;bottom:-13px;left:0;right:0;height:2px;background:#fffc;border-radius:2px 2px 0 0}.nav-right{display:flex;align-items:center;gap:1rem}.nav-username{font-size:var(--font-size-sm);color:#ffffffb3}.nav-username span{color:#fff;font-weight:500}.logout-btn{display:none}.user-menu{position:relative}.user-menu-btn{display:flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.user-menu-btn:hover{background:#ffffff38;border-color:#ffffff73}.user-menu-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000026;z-index:200;overflow:hidden;animation:fadeInDown .15s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-menu-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.7rem 1rem;background:none;border:none;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);text-decoration:none;cursor:pointer;transition:background .15s ease;text-align:left}.user-menu-item:hover{background:#f0f4ff;color:var(--color-corp-mid)}.user-menu-item--danger{color:var(--color-error)}.user-menu-item--danger:hover{background:var(--color-error-bg);color:var(--color-error)}.user-menu-divider{height:1px;background:var(--color-border);margin:.25rem 0}.layout-content{flex:1;display:flex;flex-direction:column}@media(max-width:768px){.layout-nav{padding:.75rem 1rem;height:auto;flex-wrap:wrap;gap:.5rem}.nav-left{width:100%;justify-content:space-between}.nav-links{order:3;width:100%;border-top:1px solid rgba(255,255,255,.2);padding-top:.5rem}.nav-link.active:after{bottom:-8px}.nav-right{gap:.5rem}.nav-filters-slot,.nav-username{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-20%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(21,101,192,.06) 0%,transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-20%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(0,59,122,.04) 0%,transparent 70%);pointer-events:none}.login-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem 2rem;box-shadow:var(--shadow-card);position:relative;z-index:1;animation:slideUp .5s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.login-header{text-align:center;margin-bottom:2.25rem}.login-logo{font-size:var(--font-size-4xl);font-weight:700;letter-spacing:3px;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.35rem;line-height:1}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);letter-spacing:.5px}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:var(--font-size-xs);font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--color-text-secondary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--color-text-muted);pointer-events:none;transition:color var(--transition-fast);z-index:1;display:flex;align-items:center}.form-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);outline:none;transition:all var(--transition-base)}.form-input:focus{border-color:var(--color-border-focus);background:var(--color-bg-input-focus);box-shadow:0 0 0 3px var(--color-accent-subtle)}.form-input:focus+.input-icon,.input-wrapper:has(.form-input:focus) .input-icon{color:var(--color-accent)}.input-toggle{position:absolute;right:1rem;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color var(--transition-fast);border-radius:var(--radius-sm)}.input-toggle:hover{color:var(--color-text-primary)}.input-wrapper--password .form-input{padding-right:3rem}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-error-bg);border:1px solid var(--color-border-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);animation:shake .4s ease,fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-btn{margin-top:.5rem;padding:.875rem;background:var(--gradient-brand);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--font-size-base);font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-button);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #1565c066}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-footer{margin-top:1.75rem;text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted)}.demo-request-wrapper{margin-top:.75rem;display:flex;justify-content:center}.demo-request-btn{background:#fff0f3;border:1px solid #fdd0da;border-radius:var(--radius-md);color:#c06080;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;padding:.625rem 1.25rem;cursor:pointer;width:100%;transition:all var(--transition-base);letter-spacing:.2px}.demo-request-btn:hover{background:#ffe0e8;border-color:#f9a8c0;color:#a04060}.demo-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:100;animation:fadeIn .18s ease}.demo-modal{width:100%;max-width:420px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.75rem 2rem 2rem;box-shadow:0 20px 60px #0000002e;animation:slideUp .22s ease}.demo-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.demo-modal-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin:0}.demo-modal-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.demo-modal-close:hover:not(:disabled){color:var(--color-text-primary)}.demo-modal-close:disabled{opacity:.4;cursor:not-allowed}.demo-input{padding-left:1rem}.demo-input::placeholder{color:var(--color-text-muted);opacity:.45}.demo-success-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0 .5rem;text-align:center}.demo-success-icon{width:48px;height:48px;background:#e8f5e9;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#2e7d32}.demo-success-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin:0}.demo-success-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 .75rem}@media(max-width:480px){.login-card{padding:2rem 1.5rem;border-radius:var(--radius-lg)}.login-logo{font-size:var(--font-size-3xl)}}.dashboard-page{display:flex;flex-direction:column;min-height:calc(100vh - 56px);background:var(--color-bg-primary)}.dash-title-bar{padding:.85rem 2rem 0}.dash-page-title{font-size:1.1rem;font-weight:700;color:var(--color-corp-dark);text-transform:uppercase;letter-spacing:.5px;margin-bottom:0;text-align:left}.dash-filters{display:flex;align-items:flex-end;gap:.65rem;flex-wrap:nowrap}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-label{font-size:.62rem;font-weight:600;color:#ffffffbf;text-transform:uppercase;letter-spacing:.5px}.filter-input,.filter-select{padding:.4rem .55rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;font-family:var(--font-family);font-size:.8rem;outline:none;cursor:pointer;transition:all .2s ease;min-width:105px}.filter-input:focus,.filter-select:focus{border-color:#fff9;background:#ffffff38}.filter-input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.8;cursor:pointer}.filter-select option{background:var(--color-corp-dark);color:#fff}.filter-select:disabled{opacity:.65;cursor:not-allowed}.ms-trigger{display:flex;align-items:center;justify-content:space-between;gap:.5rem;text-align:left;min-width:135px;cursor:pointer}.ms-trigger--readonly{cursor:default;opacity:.85}.ms-arrow{font-size:.55rem;opacity:.75;flex-shrink:0}.ms-panel{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--color-corp-dark);border:1px solid rgba(255,255,255,.25);border-radius:6px;padding:.35rem 0;z-index:100;max-height:220px;overflow-y:auto;box-shadow:0 6px 20px #00000059}.ms-option{display:flex;align-items:center;gap:.5rem;padding:.38rem .75rem;font-size:.78rem;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.ms-option:hover{background:#ffffff1a}.ms-option input[type=checkbox]{accent-color:#4A90E2;width:13px;height:13px;flex-shrink:0;cursor:pointer}.dash-content{flex:1;padding:1.25rem 2rem;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.dash-top-row{display:grid;grid-template-columns:1fr 28%;gap:1.25rem;align-items:start}.chart-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:1.25rem;animation:fadeInUp .35s ease;min-width:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dash-chart-row{display:flex;gap:0;align-items:stretch;min-width:0}.dash-chart-row .chart-card{flex:1;min-width:0}.dash-kpis{display:flex;flex-direction:column;justify-content:space-around;width:120px;flex-shrink:0;padding:.5rem .5rem .5rem 0}.dash-kpi{display:flex;flex-direction:column;align-items:center;text-align:center;line-height:1.1}.dash-kpi-num{font-size:1.6rem;font-weight:800;line-height:1}.dash-kpi-label{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary);margin-top:.15rem}.dash-kpi-total{color:var(--color-corp-mid)}.dash-kpi-verde{color:#28a745}.dash-kpi-amarillo{color:#daa520}.dash-kpi-rojo{color:#dc3545}.dash-kpi-critico{color:#7b0000}.chart-card-estado{display:flex;flex-direction:column;overflow:hidden;min-width:0;max-height:390px;box-sizing:border-box}.chart-card-estado-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.chart-filter-hint{display:block;margin-top:.2rem;font-size:.68rem;color:var(--color-text-secondary)}.chart-card-estado-header .chart-card-title{margin-bottom:0}.expand-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.expand-btn:hover{background:var(--color-bg-secondary);color:var(--color-corp-mid);border-color:var(--color-corp-mid)}.expand-btn--close{font-size:.9rem;border-color:transparent}.chart-estado-scroll{flex:1;overflow-y:auto;min-height:0}.chart-card-title{font-size:.875rem;font-weight:700;color:var(--color-corp-dark);text-transform:uppercase;letter-spacing:.4px;margin:0 0 .75rem}.chart-legend{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.legend-dot--blue{background:#1565c0}.legend-dot--red{background:#dc3545}.legend-label{font-size:.8rem;font-weight:500;color:var(--color-text-secondary);margin-right:.75rem}.dash-state-box{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:4rem 0;color:var(--color-text-secondary);font-size:.875rem}.dash-empty{color:var(--color-text-muted)}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.dash-error{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--color-error-bg);border:1px solid rgba(220,53,69,.25);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;margin:1.5rem 0}.retry-btn{padding:.3rem .75rem;background:none;border:1px solid currentColor;border-radius:var(--radius-sm);color:inherit;font-family:var(--font-family);font-size:.8rem;cursor:pointer;transition:background .2s ease}.retry-btn:hover{background:#dc35451f}.dash-table-section{padding:0;width:100%}.dash-table-footer{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;margin-top:.5rem}.dash-table-visible-count{font-size:.78rem;color:var(--color-text-secondary);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.25rem .6rem;box-shadow:var(--shadow-card)}.dash-table-visible-count strong{color:var(--color-corp-dark)}.dash-table-wrapper{overflow-x:auto;overflow-y:auto;max-height:300px;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);position:relative}.dash-table{width:100%;border-collapse:collapse;font-size:.8rem;background:#fff;table-layout:fixed}.dash-table thead{background:var(--color-corp-dark);position:sticky;top:0;z-index:2}.dash-table th{color:#fff;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.3px;padding:.55rem .5rem;text-align:left;white-space:normal;vertical-align:bottom;line-height:1.2;overflow:hidden;text-overflow:ellipsis}.dash-table th.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.dash-table th.th-sortable:hover{background:#ffffff1f}.th-central-label{display:flex;align-items:center;gap:2px;margin-bottom:.3rem}.th-filter-input{width:100%;padding:.18rem .35rem;font-size:.65rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:3px;color:#fff;outline:none;box-sizing:border-box}.th-filter-input::placeholder{color:#ffffff73}.th-filter-input:focus{background:#fff3;border-color:#ffffff8c}.th-filter-check-group{display:flex;flex-direction:column;gap:2px;margin-top:.2rem}.th-filter-check-label{display:flex;align-items:center;gap:4px;font-size:.6rem;text-transform:none;letter-spacing:0;line-height:1.1;cursor:pointer}.th-filter-check-label input[type=checkbox]{width:12px;height:12px;margin:0;accent-color:#4A90E2}.sort-arrow{margin-left:3px;font-size:.65rem;opacity:1;color:#fff}.sort-arrow--none{opacity:.35}.dash-table td{padding:.4rem .5rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);white-space:normal;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.dash-table tbody tr:nth-child(2n){background:#f8fafc}.dash-table tbody tr:hover{background:#eef4ff}.semaforo-cell{text-align:center;font-size:.9rem}.semaforo-rojo{color:#dc3545;font-weight:700}.semaforo-circulo{display:inline-block;width:12px;height:12px;border-radius:50%}.semaforo-circulo--verde{background:#28a745}.semaforo-circulo--amarillo{background:#daa520}.semaforo-circulo--rojo{background:#ff6b6b}.dias-cell{text-align:right;font-variant-numeric:tabular-nums;width:60px;white-space:nowrap}.estado-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.estado-modal-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;width:80vw;max-width:1100px;max-height:85vh;display:flex;flex-direction:column;padding:1.5rem;animation:fadeInUp .2s ease}.estado-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-shrink:0}.estado-modal-body{overflow-y:auto;flex:1;min-height:0}@media(max-width:768px){.dash-content{padding:1rem}.dash-top-row{grid-template-columns:1fr}.chart-card-estado{height:auto;max-height:400px}}.admin-page{padding:2rem;max-width:1500px;margin:0 auto;width:100%;animation:fadeIn .3s ease;background:var(--color-bg-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.admin-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary)}.admin-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:.25rem}.btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;background:var(--gradient-brand);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-button)}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #1565c059}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-full{width:100%;justify-content:center}.btn-danger{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;background:var(--color-error);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;box-shadow:var(--shadow-button);transition:all var(--transition-base)}.btn-danger:hover{opacity:.9;transform:translateY(-1px)}.btn-danger:disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-header-actions{display:flex;gap:.75rem;align-items:center}.delete-warning{font-size:var(--font-size-sm);color:var(--color-error);background:var(--color-error-bg);padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,80,80,.25);font-weight:500;line-height:1.4;margin:0}.admin-feedback{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;margin-bottom:1rem;animation:fadeIn .25s ease}.admin-feedback--success{background:var(--color-success-bg);border:1px solid rgba(0,212,160,.3);color:var(--color-success)}.admin-feedback--error{background:var(--color-error-bg);border:1px solid rgba(255,80,80,.3);color:var(--color-error)}.admin-toolbar{margin-bottom:1rem}.search-box{display:flex;align-items:center;gap:.6rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.6rem 1rem;max-width:400px;transition:border-color var(--transition-base)}.search-box:focus-within{border-color:var(--color-border-focus);background:var(--color-bg-input-focus)}.search-box svg{color:var(--color-text-muted);flex-shrink:0}.search-box input{background:none;border:none;outline:none;color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);width:100%}.search-box input::placeholder{color:var(--color-text-muted)}.admin-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:4rem 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-card)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table thead{background:var(--color-corp-dark)}.admin-table th{text-align:left;padding:.85rem 1rem;font-size:var(--font-size-xs);font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;border-bottom:none;white-space:nowrap}.admin-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:#f5f7fa}.cell-username{font-weight:600}.cell-password{font-family:monospace;font-size:var(--font-size-xs);white-space:nowrap;min-width:140px}.cell-password__value{letter-spacing:.05em;vertical-align:middle}.eye-btn{background:none;border:none;padding:0 0 0 .4rem;cursor:pointer;font-size:.9rem;vertical-align:middle;opacity:.7;transition:opacity .15s}.eye-btn:hover{opacity:1}.cell-cliente{color:var(--color-text-secondary)}.cell-date{color:var(--color-text-secondary);font-size:var(--font-size-xs);white-space:nowrap}.admin-empty{text-align:center;padding:3rem 1rem!important;color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.3px}.badge--active{background:var(--color-success-bg);color:var(--color-success);border:1px solid rgba(0,212,160,.25)}.badge--inactive{background:var(--color-error-bg);color:var(--color-error);border:1px solid rgba(255,80,80,.25)}.badge--admin{background:#1565c01a;color:var(--color-corp-mid);border:1px solid rgba(21,101,192,.25)}.toggle-btn{padding:.3rem .75rem;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;border:1px solid;transition:all var(--transition-base)}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-btn--deactivate{background:var(--color-error-bg);border-color:#ff50504d;color:var(--color-error)}.toggle-btn--deactivate:hover:not(:disabled){background:#ff505033}.toggle-btn--activate{background:var(--color-success-bg);border-color:#00d4a04d;color:var(--color-success)}.toggle-btn--activate:hover:not(:disabled){background:#00d4a033}.toggle-btn--pw{background:#1565c014;border-color:#1565c04d;color:var(--color-corp-mid);margin-left:.4rem}.toggle-btn--pw:hover{background:#1565c02e}.toggle-btn--cuenta-act{background:var(--color-success-bg);border-color:#00d4a04d;color:var(--color-success);margin-left:.4rem}.toggle-btn--cuenta-act:hover:not(:disabled){background:#00d4a033}.toggle-btn--cuenta-deact{background:#fb8c001a;border-color:#fb8c0059;color:#e65100;margin-left:.4rem}.toggle-btn--cuenta-deact:hover:not(:disabled){background:#fb8c0033}.cell-actions{white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:440px;margin:1rem;box-shadow:var(--shadow-card);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary)}.modal-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary);background:#ffffff0d}.modal-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-label{display:flex;flex-direction:column;gap:.35rem;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.form-label input[type=text],.form-label input[type=password]{padding:.6rem .85rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition-base),background var(--transition-base)}.form-label input:focus{border-color:var(--color-border-focus);background:var(--color-bg-input-focus)}.form-checkbox{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-accent);cursor:pointer}.form-error{font-size:var(--font-size-xs);color:var(--color-error);background:var(--color-error-bg);padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid rgba(255,80,80,.25)}@media(max-width:768px){.admin-page{padding:1rem}.admin-header{flex-direction:column;gap:1rem}.search-box{max-width:100%}.admin-table th:nth-child(6),.admin-table td:nth-child(6),.admin-table th:nth-child(7),.admin-table td:nth-child(7){display:none}}.pen-kpi-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.pen-kpi-box{display:flex;flex-direction:column;gap:.2rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:.8rem 1rem}.pen-kpi-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary)}.pen-kpi-value{font-size:1.45rem;font-weight:800;color:var(--color-corp-mid);line-height:1}.pen-export-actions{display:flex;gap:.6rem;align-items:center}.pen-btn-export{padding:.45rem .85rem;border:1px solid var(--color-corp-mid);border-radius:var(--radius-sm);background:#fff;color:var(--color-corp-mid);font-family:var(--font-family);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s ease}.pen-btn-export:hover{background:var(--color-corp-mid);color:#fff}.pen-filter-bar{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.pen-filter-bar label{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.25px}.pen-operator-select{min-width:230px;max-width:340px;padding:.45rem .55rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-text-primary);font-family:var(--font-family);font-size:.8rem}.pen-empty{background:#fff;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.84rem;text-align:center;padding:1.2rem}.pen-table-wrapper{max-height:clamp(560px,calc(100vh - 290px),85vh)}
