@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#41b6e6;--brand-dark:#1a9fd4;--brand-light:#e8f7fd;--brand-mid:#b3e4f7;--brand-glow:#41b6e626;--bg:#f4f6f9;--surface:#fff;--surface2:#f8f9fb;--surface3:#eef0f4;--surface4:#e8eaee;--border:#0000000f;--border-sm:#00000012;--border-md:#0000001a;--border-strong:#00000026;--text:#0d1117;--text-2:#3d4556;--text-3:#8892a4;--text-4:#b8c0cc;--ok:#059669;--ok-bg:#d1fae5;--ok-border:#6ee7b7;--riesgo:#d97706;--riesgo-bg:#fef3c7;--riesgo-border:#fcd34d;--critico:#dc2626;--critico-bg:#fee2e2;--critico-border:#fca5a5;--sidebar-w:256px;--topbar-h:60px;--radius:14px;--radius-sm:10px;--radius-xs:6px;--radius-lg:20px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 2px 4px #0000000f, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-md:0 8px 24px #0000001a, 0 4px 8px #0000000d;--shadow-lg:0 20px 48px #00000024, 0 8px 16px #0000000f;--shadow-brand:0 4px 16px #41b6e64d;--font:"Outfit", system-ui, sans-serif;--mono:"JetBrains Mono", monospace;--transition:.18s cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth;font-size:14px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}.app-layout{min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-w);z-index:100;transition:transform var(--transition);background:#0d1117;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar:after{content:"";pointer-events:none;background:linear-gradient(#41b6e633,#0000 40% 60%,#41b6e61a);width:1px;height:100%;position:absolute;top:0;right:0}.sidebar-logo{border-bottom:1px solid #ffffff0d;flex-shrink:0;padding:24px 20px 20px}.sidebar-nav{scrollbar-width:none;flex:1;padding:8px 12px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section{letter-spacing:.12em;text-transform:uppercase;color:#fff3;padding:20px 8px 6px;font-size:.64rem;font-weight:700}.nav-item{color:#ffffff73;cursor:pointer;transition:all var(--transition);text-align:left;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:9px 12px;font-size:.875rem;font-weight:500;display:flex}.nav-item:hover{color:#ffffffd9;background:#ffffff0f}.nav-item.active{color:#fff;background:#41b6e61f;font-weight:600}.nav-item.active .nav-icon{color:var(--brand)}.nav-icon{text-align:center;width:20px;transition:color var(--transition);flex-shrink:0;font-size:1rem}.nav-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-left:auto}.nav-dot-ok{background:var(--ok);box-shadow:0 0 6px #05966999}.nav-dot-warn{background:var(--riesgo);box-shadow:0 0 6px #d9770699}.nav-dot-crit{background:var(--critico);box-shadow:0 0 6px #dc262699}.sidebar-footer{border-top:1px solid #ffffff0d;flex-shrink:0;padding:16px 16px 20px}.user-chip{align-items:center;gap:10px;margin-bottom:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--brand), #1a9fd4);color:#fff;letter-spacing:.02em;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.78rem;font-weight:800;display:flex;box-shadow:0 2px 8px #41b6e64d}.user-name{color:#fff;font-size:.88rem;font-weight:700}.user-rol{color:#ffffff4d;text-transform:uppercase;letter-spacing:.06em;margin-top:1px;font-size:.7rem}.logout-btn{border-radius:var(--radius-xs);color:#ffffff4d;cursor:pointer;width:100%;transition:all var(--transition);font-size:.78rem;font-family:var(--font);text-align:left;background:#ffffff0a;border:1px solid #ffffff14;padding:8px 12px}.logout-btn:hover{color:#fca5a5;background:#dc26261f;border-color:#dc262640}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100dvh;padding:32px 36px}.topbar{height:var(--topbar-h);z-index:99;background:#0d1117;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:0 16px;display:none;position:sticky;top:0}.menu-btn{cursor:pointer;color:#ffffffb3;width:40px;height:40px;transition:all var(--transition);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.menu-btn:hover{background:#ffffff1a}.page-container{max-width:1200px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.03em;color:var(--text);font-size:1.6rem;font-weight:800;line-height:1.1}.page-subtitle{color:var(--text-3);margin-top:4px;font-size:.82rem;font-weight:500}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs);padding:20px 22px}.card-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:16px;font-size:.68rem;font-weight:800}.kpi-grid{grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:28px;display:grid}.kpi-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs);transition:all var(--transition);padding:18px 20px;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.kpi-card:before{content:"";background:linear-gradient(90deg, var(--brand), var(--brand-dark));opacity:0;height:3px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.kpi-card:hover:before{opacity:1}.kpi-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:10px;font-size:.68rem;font-weight:700}.kpi-value{letter-spacing:-.04em;margin-bottom:6px;font-size:2rem;font-weight:800;line-height:1}.kpi-sub{color:var(--text-3);font-size:.72rem;font-weight:500}.badge{letter-spacing:.03em;white-space:nowrap;border:1px solid #0000;border-radius:20px;align-items:center;padding:3px 9px;font-size:.68rem;font-weight:700;display:inline-flex}.badge-ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-border)}.badge-riesgo{background:var(--riesgo-bg);color:var(--riesgo);border-color:var(--riesgo-border)}.badge-critico{background:var(--critico-bg);color:var(--critico);border-color:var(--critico-border)}.badge-frio{color:#6d28d9;background:#ede9fe;border-color:#c4b5fd}.badge-muyfrio{color:#5b21b6;background:#ddd6fe;border-color:#a78bfa}.badge-sinhistorial{background:var(--surface3);color:var(--text-3);border-color:var(--border-md)}.badge-a{color:#713f12;background:#fef9c3;border-color:#fde68a}.badge-b{color:#1e40af;background:#dbeafe;border-color:#93c5fd}.badge-c{background:var(--surface3);color:var(--text-3);border-color:var(--border-md)}.badge-b1{background:var(--brand-light);color:var(--brand-dark);border-color:var(--brand-mid)}.badge-b2{color:#92400e;border-color:var(--riesgo-border);background:#fef3c7}.badge-b3{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.table-wrap{border-radius:var(--radius-sm);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}thead th{text-align:left;text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);border-bottom:1px solid var(--border-md);white-space:nowrap;background:var(--surface2);padding:11px 16px;font-size:.65rem;font-weight:800}thead th:first-child{border-radius:var(--radius-sm) 0 0 0}thead th:last-child{border-radius:0 var(--radius-sm) 0 0}tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#f0faff}tbody td{color:var(--text);vertical-align:middle;padding:12px 16px}.td-code{font-family:var(--mono);color:var(--text-3);font-size:.75rem}.td-name{font-size:.88rem;font-weight:600}.filters-bar{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.search-input{border:1px solid var(--border-md);border-radius:var(--radius-sm);background:var(--surface);min-width:200px;color:var(--text);transition:all var(--transition);font-size:.88rem;font-family:var(--font);outline:none;flex:1;padding:10px 14px 10px 40px}.search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.filter-select{border:1px solid var(--border-md);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;font-size:.85rem;font-family:var(--font);transition:all var(--transition);outline:none;padding:10px 14px}.filter-select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-size:.85rem;font-weight:700;font-family:var(--font);letter-spacing:.01em;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:10px 20px;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";transition:background var(--transition);background:#fff0;position:absolute;inset:0}.btn:hover:after{background:#ffffff14}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg, var(--brand), var(--brand-dark));color:#fff;box-shadow:var(--shadow-brand);border-color:#0000}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #41b6e666}.btn-secondary{background:var(--surface);color:var(--text-2);border-color:var(--border-md);box-shadow:var(--shadow-xs)}.btn-secondary:hover{border-color:var(--brand);color:var(--brand-dark);background:var(--brand-light)}.btn-sm{border-radius:var(--radius-xs);padding:7px 14px;font-size:.78rem}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#0d111799;justify-content:center;align-items:center;padding:20px;animation:.2s overlayIn;display:flex;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:92dvh;box-shadow:var(--shadow-lg);scrollbar-width:thin;border:1px solid var(--border);animation:.22s cubic-bezier(.34,1.56,.64,1) modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;border-radius:var(--radius-lg) var(--radius-lg) 0 0;justify-content:space-between;align-items:flex-start;padding:24px 24px 18px;display:flex;position:sticky;top:0}.modal-title{letter-spacing:-.02em;font-size:1.05rem;font-weight:800}.modal-close{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:30px;height:30px;color:var(--text-3);transition:all var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;display:flex}.modal-close:hover{background:var(--critico-bg);color:var(--critico);border-color:var(--critico-border)}.modal-body{padding:22px 24px}.modal-footer{border-top:1px solid var(--border);background:var(--surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);justify-content:flex-end;gap:10px;padding:16px 24px 20px;display:flex;position:sticky;bottom:0}.form-group{margin-bottom:18px}.form-label{color:var(--text-2);letter-spacing:.02em;text-transform:uppercase;margin-bottom:7px;font-size:.75rem;font-weight:700;display:block}.form-input,.form-select,.form-textarea{border:1px solid var(--border-md);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--surface);transition:all var(--transition);font-size:.88rem;font-family:var(--font);outline:none;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.form-textarea{resize:vertical;min-height:80px;line-height:1.55}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.pagination{color:var(--text-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:16px 0 0;font-size:.8rem;display:flex}.pagination-btns{gap:4px;display:flex}.page-btn{border:1px solid var(--border-md);border-radius:var(--radius-xs);background:var(--surface);cursor:pointer;transition:all var(--transition);color:var(--text-2);font-size:.8rem;font-family:var(--font);padding:6px 12px;font-weight:500}.page-btn:hover:not(:disabled){border-color:var(--brand);color:var(--brand-dark);background:var(--brand-light)}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-btn.active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:var(--shadow-brand);font-weight:700}.progreso-bar{background:var(--surface3);border-radius:99px;height:7px;margin-top:8px;overflow:hidden}.progreso-fill{border-radius:99px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progreso-ok{background:linear-gradient(90deg,#059669,#34d399)}.progreso-warn{background:linear-gradient(90deg,#d97706,#fbbf24)}.progreso-danger{background:linear-gradient(90deg,#dc2626,#f87171)}.alert{border-radius:var(--radius-sm);border:1px solid #0000;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:.85rem;font-weight:500;display:flex}.alert-error{background:var(--critico-bg);border-color:var(--critico-border);color:#991b1b}.alert-success{background:var(--ok-bg);border-color:var(--ok-border);color:#065f46}.alert-warn{background:var(--riesgo-bg);border-color:var(--riesgo-border);color:#92400e}.alert-info{background:var(--brand-light);border-color:var(--brand-mid);color:var(--brand-dark)}.login-screen{background:#0d1117;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.login-screen:before{content:"";pointer-events:none;background:radial-gradient(circle,#41b6e614 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#ffffff08;border:1px solid #ffffff12;border-radius:24px;width:100%;max-width:390px;padding:48px 44px;animation:.4s cubic-bezier(.34,1.2,.64,1) modalIn;position:relative;box-shadow:0 30px 60px #00000080}.login-logo{text-align:center;margin-bottom:36px}.login-sub{text-align:center;color:#ffffff40;letter-spacing:.15em;text-transform:uppercase;margin-bottom:32px;font-size:.8rem;font-weight:600}.login-card .form-label{color:#fff6}.login-card .form-input{color:#fff;background:#ffffff0d;border-color:#ffffff14;border-radius:10px;padding:13px 16px;font-size:.95rem}.login-card .form-input:focus{border-color:var(--brand);background:#ffffff12;box-shadow:0 0 0 3px #41b6e626}.login-card .form-input::placeholder{color:#ffffff2e}.login-card .btn-primary{border-radius:10px;width:100%;margin-top:4px;padding:13px;font-size:.95rem}.spinner{border:2.5px solid var(--border-md);border-top-color:var(--brand);border-radius:50%;width:34px;height:34px;margin:40px auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:200px;display:flex}.empty-state{text-align:center;color:var(--text-3);padding:56px 24px}.empty-state .icon{opacity:.5;margin-bottom:14px;font-size:2.8rem}.empty-state p{font-size:.88rem;font-weight:500;line-height:1.6}.sidebar-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:99;background:#000000a6;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}.text-ok{color:var(--ok)}.text-riesgo{color:var(--riesgo)}.text-critico{color:var(--critico)}.text-muted{color:var(--text-3)}.fw-700{font-weight:700}.fw-800{font-weight:800}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.mono{font-family:var(--mono)}.cola-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-xs);align-items:center;gap:14px;padding:16px 18px;display:flex}.cola-item:hover{border-color:var(--brand-mid);box-shadow:var(--shadow);transform:translateY(-1px)}.cola-prioridad{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.82rem;font-weight:800;display:flex}.cola-nombre{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.cola-meta{color:var(--text-3);flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;font-size:.75rem;display:flex}@media (width<=768px){html{font-size:15px}.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{margin-left:0;padding:0 16px 16px}.topbar{display:flex}.form-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-title{font-size:1.5rem}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92dvh}.modal-overlay{align-items:flex-end;padding:0}.filters-bar{flex-direction:column}.search-input{min-width:0}}@media (width<=480px){html{font-size:16px}.main-content{padding:0 14px 14px}.card{border-radius:var(--radius);padding:16px}.kpi-card{padding:14px 16px}.kpi-value{font-size:1.9rem}.kpi-label{font-size:.7rem}.cola-item{border-radius:var(--radius);padding:14px 16px}.cola-prioridad{border-radius:12px;width:40px;height:40px;font-size:.9rem}.cola-nombre{font-size:.95rem}.modal-header{padding:20px 20px 16px}.modal-body{padding:16px 20px}.modal-footer{padding:14px 20px 32px}.form-input,.form-select,.form-textarea{border-radius:10px;padding:13px 14px;font-size:1rem}.btn{min-height:48px;padding:13px 20px;font-size:.92rem}.btn-sm{min-height:42px;padding:10px 16px;font-size:.85rem}.badge{padding:3px 9px;font-size:.7rem}.nav-item{min-height:46px;padding:12px 14px;font-size:.95rem}.topbar{height:58px}.page-title{font-size:1.4rem}.page-subtitle{font-size:.85rem}.hide-mobile{display:none!important}}@media (width<=430px){.objetivos-grid{grid-template-columns:1fr!important;gap:10px!important}.objetivo-card{align-items:center!important;gap:16px!important;padding:14px 16px!important;display:flex!important}}@media (hover:none) and (pointer:coarse){.btn{min-height:48px}.btn-sm{min-height:42px}.page-btn{min-width:40px;min-height:40px}.nav-item{min-height:46px}.cola-item{min-height:68px}.modal-close{width:36px;height:36px}}@supports (padding-bottom:env(safe-area-inset-bottom)){.modal-footer,.sidebar-footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.topbar{padding-top:env(safe-area-inset-top)}}
