*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f0f2f5;min-height:100vh;font-family:Segoe UI,Arial,sans-serif}:root{--brand-primary:#185fa5;--brand-sidebar:#1e3a5f;--brand-button:#185fa5}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--brand-sidebar);z-index:100;flex-direction:column;width:230px;min-width:230px;height:100vh;display:flex;position:fixed;top:0;left:0;box-shadow:2px 0 12px #0003}.sidebar-logo{background:#fff;border-bottom:1px solid #ffffff12;align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar-logo-icon{background:var(--brand-primary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-logo-text{flex-direction:column;display:flex}.sidebar-logo-name{color:#0d1f3c;font-size:13px;font-weight:800;line-height:1.2}.sidebar-logo-sub{color:#8ba0c2;text-transform:uppercase;letter-spacing:.5px;font-size:10px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section{color:#4a6080;text-transform:uppercase;letter-spacing:1px;margin-top:4px;padding:10px 8px 4px;font-size:10px;font-weight:700}.nav-tab{color:#8ba0c2;cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:all .15s;display:flex}.nav-tab:hover{color:#fff;background:#ffffff12}.nav-tab.active{color:#29b6f6;background:#29b6f626;font-weight:600}.nav-icon{text-align:center;flex-shrink:0;justify-content:center;align-items:center;width:20px;font-size:15px;display:flex}.sidebar-user{border-top:1px solid #ffffff12;padding:12px 14px}.sidebar-user-card{border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.nav-user-avatar{background:linear-gradient(135deg,var(--brand-primary),#29b6f6);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.sidebar-user-role{color:#8ba0c2;font-size:10px}.sidebar-logout{color:#8ba0c2;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;margin-top:4px;padding:8px 10px;font-family:inherit;font-size:12px;text-decoration:none;transition:all .15s;display:flex}.sidebar-logout:hover{color:#e57373;background:#a32d2d33}.main-content{flex:1;max-width:calc(100vw - 230px);margin-left:230px;padding:24px 28px}.topbar{z-index:50;background:#fff;border-bottom:1px solid #dce8f5;align-items:center;gap:12px;margin:-24px -28px 24px;padding:12px 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000a}.topbar-icon{color:#185fa5;align-items:center;display:flex}.topbar-title{color:#0d1f3c;font-size:16px;font-weight:700}.topbar-sub{color:#8ba0c2;margin-top:1px;font-size:11px}.topbar-spacer{flex:1}.page{display:none}.page.active{display:block}.sec-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.sec-title{color:#0d1f3c;font-size:18px;font-weight:700}.sec-sub{color:#888;margin-top:2px;font-size:13px}.card{background:#fff;border:1px solid #dce8f5;border-radius:10px;margin-bottom:18px;padding:22px}.card-header{border-bottom:1px solid #eef2f8;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:10px;display:flex}.card-title{color:#185fa5;text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:700}.card-body{padding:0}.form-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}.form-grid.cols-1{grid-template-columns:1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.form-group{flex-direction:column;gap:4px;display:flex}.form-group label{color:#555;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#f7faff;border:1px solid #dce8f5;border-radius:6px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:border .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#185fa5}.form-group input[readonly]{color:#888;background:#f0f0f0}.form-group textarea{resize:vertical;min-height:80px}.form-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.form-row label{color:#555;width:180px;min-width:180px;font-size:13px;font-weight:600}.form-row input,.form-row select,.form-row textarea{background:#f7faff;border:1px solid #dce8f5;border-radius:6px;outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:13px;transition:border .15s}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{background:#fff;border-color:#185fa5}.form-group input[type=range]{cursor:pointer;accent-color:#185fa5;background:0 0;border:none;padding:0}.range-label{color:#888;justify-content:space-between;align-items:center;margin-top:2px;font-size:11px;display:flex}.range-val{color:#185fa5;font-weight:700}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;line-height:1;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand-button);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-button);filter:brightness(1.1)}.btn-success{color:#fff;background:#3b6d11}.btn-success:hover:not(:disabled){background:#4a8a15}.btn-danger{color:#a32d2d;background:#fcebeb;border:1px solid #f0c0c0}.btn-danger:hover:not(:disabled){background:#f5d0d0}.btn-outline{color:#185fa5;background:#fff;border:1px solid #dce8f5}.btn-outline:hover:not(:disabled){background:#f0f7ff}.btn-dark{color:#fff;background:#0d1f3c}.btn-dark:hover:not(:disabled){background:#17305a}.btn-sm{padding:5px 12px;font-size:12px}.btn-icon{border-radius:6px;padding:5px 8px;font-size:13px}.btn-group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.alert{border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.alert-success{color:#3b6d11;background:#f0f7ee;border-left:3px solid #3b6d11}.alert-error{color:#a32d2d;background:#fcebeb;border-left:3px solid #a32d2d}.alert-info{color:#185fa5;background:#e6f1fb;border-left:3px solid #185fa5}.alert-warning{color:#7a4a00;background:#fff8f0;border-left:3px solid #f5c478}.table-wrap{border:1px solid #dce8f5;border-radius:8px;margin-bottom:0;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead tr{color:#fff;background:#0d1f3c}th{text-align:left;white-space:nowrap;letter-spacing:.3px;padding:10px 12px;font-size:11px;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #f0f4fa;padding:9px 12px;font-size:13px}tr:last-child td{border-bottom:none}tbody tr:hover td{cursor:pointer;background:#f7faff}tbody tr.row-danger td{background:#fff5f5}tbody tr.row-danger:hover td{background:#feecec}.badge{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-ok{color:#3b6d11;background:#f0f7ee}.badge-err{color:#a32d2d;background:#fcebeb}.badge-warn{color:#a16207;background:#fff8f0}.badge-info{color:#185fa5;background:#e6f1fb}.badge-gray{color:#555;background:#f0f0f0}.badge-navy{color:#0d1f3c;background:#e8ecf4}.badge-purple{color:#6d28d9;background:#f3f0ff}.badge-orange{color:#c2410c;background:#fff3ed}.metrics{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.metrics-3{grid-template-columns:repeat(3,1fr)}.met-card{background:#fff;border:1px solid #dce8f5;border-radius:10px;align-items:center;gap:14px;padding:18px 20px;display:flex;position:relative;overflow:hidden}.met-card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.met-card.navy:before{background:#0d1f3c}.met-card.blue:before{background:#185fa5}.met-card.green:before{background:#3b6d11}.met-card.red:before{background:#a32d2d}.met-card.cyan:before{background:#29b6f6}.met-card.purple:before{background:#7c3aed}.met-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.met-icon.navy{color:#0d1f3c;background:#e8ecf4}.met-icon.blue{color:#185fa5;background:#e6f1fb}.met-icon.green{color:#3b6d11;background:#f0f7ee}.met-icon.red{color:#a32d2d;background:#fcebeb}.met-icon.cyan{color:#0288d1;background:#e0f7fd}.met-icon.purple{color:#7c3aed;background:#f3f0ff}.met-body{flex:1;min-width:0}.met-num{margin-bottom:2px;font-size:26px;font-weight:800;line-height:1}.met-num.navy{color:#0d1f3c}.met-num.blue{color:#185fa5}.met-num.green{color:#3b6d11}.met-num.red{color:#a32d2d}.met-num.cyan{color:#29b6f6}.met-num.purple{color:#7c3aed}.met-lbl{color:#888;font-size:12px}.met-sub{color:#aaa;margin-top:1px;font-size:11px}.db-welcome{color:#fff;background:linear-gradient(135deg,#0d1f3c 0%,#185fa5 100%);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding:24px 28px;display:flex}.db-welcome-title{margin-bottom:4px;font-size:22px;font-weight:800}.db-welcome-sub{color:#ffffffb3;font-size:13px}.db-welcome-stats{gap:20px;display:flex}.db-welcome-stat{text-align:center}.db-welcome-stat-num{font-size:22px;font-weight:800;line-height:1}.db-welcome-stat-lbl{color:#fff9;margin-top:2px;font-size:11px}.db-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.db-grid-3{grid-template-columns:2fr 1fr}.db-rank-item{border-bottom:1px solid #f5f5f5;align-items:center;gap:10px;padding:8px 0;display:flex}.db-rank-item:last-child{border-bottom:none}.db-rank-num{text-align:center;color:#185fa5;background:#e6f1fb;border-radius:50%;flex-shrink:0;width:22px;height:22px;font-size:11px;font-weight:700;line-height:22px}.db-rank-bar-wrap{background:#f0f0f0;border-radius:3px;flex:1;height:6px;overflow:hidden}.db-rank-bar{background:#185fa5;border-radius:3px;height:100%}.db-rank-name{color:#555;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:90px;font-size:13px;overflow:hidden}.db-rank-count{color:#888;text-align:right;flex-shrink:0;min-width:28px;font-size:12px;font-weight:700}.level-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:5px;display:inline-block}.level-dot.bajo{background:#3b6d11}.level-dot.medio{background:#b45309}.level-dot.alto{background:#c2410c}.level-dot.critico{background:#a32d2d}.kri-card{cursor:pointer;background:#fff;border:1px solid #dce8f5;border-radius:10px;padding:16px 18px;transition:box-shadow .15s}.kri-card:hover{box-shadow:0 4px 16px #0d1f3c14}.kri-card.alert{background:snow;border-color:#f0c0c0}.kri-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.kri-card-name{color:#0d1f3c;font-size:13px;font-weight:700}.kri-card-cat{color:#888;margin-top:2px;font-size:11px}.kri-prog-wrap{align-items:center;gap:10px;display:flex}.kri-prog-bar{background:#f0f0f0;border-radius:4px;flex:1;height:8px;overflow:hidden}.kri-prog-fill{border-radius:4px;height:100%}.kri-prog-fill.ok{background:#3b6d11}.kri-prog-fill.alert{background:#a32d2d}.kri-prog-val{white-space:nowrap;font-size:12px;font-weight:700}.kri-prog-val.ok{color:#3b6d11}.kri-prog-val.alert{color:#a32d2d}.item-card{background:#fff;border:1px solid #dce8f5;border-radius:10px;padding:16px;transition:box-shadow .15s;position:relative}.item-card:hover{box-shadow:0 4px 16px #0d1f3c14}.item-card-title{color:#0d1f3c;margin-bottom:4px;font-size:14px;font-weight:700}.item-card-sub{color:#888;margin-bottom:10px;font-size:12px}.item-card-actions{flex-wrap:wrap;gap:8px;display:flex}.item-card-badge{position:absolute;top:12px;right:12px}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.filter-bar{background:#fff;border:1px solid #dce8f5;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.filter-bar label{color:#555;font-size:12px;font-weight:600}.filter-bar input,.filter-bar select{background:#f7faff;border:1px solid #dce8f5;border-radius:5px;outline:none;padding:6px 10px;font-family:inherit;font-size:12px}.filter-bar input:focus,.filter-bar select:focus{border-color:#185fa5}.filter-bar-spacer{flex:1}.search-wrap{position:relative}.search-wrap input{width:240px;padding-left:32px}.search-icon{color:#8ba0c2;pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.empty{text-align:center;color:#aaa;padding:48px}.empty-icon{opacity:.4;margin-bottom:12px;font-size:36px}.empty-text{color:#888;font-size:14px;font-weight:600}.empty-sub{color:#aaa;margin-top:4px;font-size:12px}.prog-wrap{background:#f0f0f0;border-radius:20px;height:8px;overflow:hidden}.prog-bar{border-radius:20px;height:100%}.prog-bar.ok{background:#3b6d11}.prog-bar.warn{background:#b45309}.prog-bar.err{background:#a32d2d}.prog-bar.blue{background:#185fa5}.heatmap-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.heatmap-cell{border:1px solid #0000;border-radius:8px;flex-direction:column;min-height:80px;padding:10px;transition:box-shadow .15s;display:flex}.heatmap-cell:hover{box-shadow:0 4px 12px #0000001f}.heatmap-cell.bajo{background:#f0f7ee;border-color:#c0dd97}.heatmap-cell.medio{background:#fff8e6;border-color:#f5d78e}.heatmap-cell.alto{background:#fff3ed;border-color:#f5c098}.heatmap-cell.critico{background:#fff0f0;border-color:#f5a0a0}.heatmap-score{font-size:20px;font-weight:800;line-height:1}.heatmap-score.bajo{color:#3b6d11}.heatmap-score.medio{color:#b45309}.heatmap-score.alto{color:#c2410c}.heatmap-score.critico{color:#a32d2d}.heatmap-chips{flex-wrap:wrap;gap:3px;margin-top:auto;display:flex}.heatmap-chip{color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.heatmap-chip.bajo{background:#3b6d11}.heatmap-chip.medio{background:#b45309}.heatmap-chip.alto{background:#c2410c}.heatmap-chip.critico{background:#a32d2d}.heatmap-axis{color:#8ba0c2;justify-content:space-between;margin-top:4px;padding:0 4px;font-size:11px;display:flex}.ai-badge{color:#fff;vertical-align:middle;background:linear-gradient(135deg,#7c3aed,#4f46e5);border-radius:20px;margin-left:8px;padding:2px 10px;font-size:10px;font-weight:700}.ai-result-section{margin-bottom:16px}.ai-result-label{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.ai-result-list{flex-direction:column;gap:6px;list-style:none;display:flex}.ai-result-list li{align-items:flex-start;gap:8px;font-size:13px;display:flex}.ai-result-list li:before{content:"›";color:#185fa5;flex-shrink:0;margin-top:1px;font-weight:700}.ai-disclaimer{color:#7a4a00;background:#fff8e6;border:1px solid #f5d78e;border-radius:6px;align-items:flex-start;gap:8px;margin-top:16px;padding:10px 14px;font-size:12px;display:flex}.ai-loading{flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:48px;display:flex}.ai-spinner{border:3px solid #e6f1fb;border-top-color:#7c3aed;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tab-bar{background:#fff;border:1px solid #dce8f5;border-radius:8px;gap:4px;margin-bottom:16px;padding:4px;display:flex}.tab-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:flex}.tab-btn.active.blue{color:#185fa5;background:#e6f1fb}.tab-btn.active.purple{color:#7c3aed;background:#f3f0ff}.tab-btn:not(.active):hover{background:#f7faff}.export-card{cursor:pointer;background:#fff;border:2px dashed #dce8f5;border-radius:10px;align-items:center;gap:16px;padding:20px 24px;transition:all .2s;display:flex}.export-card:hover{background:#f7faff;border-color:#185fa5}.export-card.excel:hover{background:#f0f7ee;border-color:#3b6d11}.export-card.pdf:hover{background:#fff5f5;border-color:#a32d2d}.export-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.export-icon.excel{color:#3b6d11;background:#f0f7ee}.export-icon.pdf{color:#a32d2d;background:#fcebeb}.export-body{flex:1}.export-title{color:#0d1f3c;font-size:15px;font-weight:700}.export-desc{color:#888;margin-top:3px;font-size:12px}.export-arrow{color:#8ba0c2}.login-bg{background:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-wrap{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:24px}.login-logo-row{justify-content:center;align-items:center;gap:10px;margin-bottom:8px;display:flex}.login-logo-icon{background:#185fa5;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.login-logo-name{color:#0d1f3c;letter-spacing:-.3px;font-size:22px;font-weight:900}.login-logo-name span{color:#29b6f6}.login-sub{color:#8ba0c2;text-transform:uppercase;letter-spacing:1px;font-size:12px}.login-card{background:#fff;border:1px solid #dce8f5;border-radius:12px;padding:32px;box-shadow:0 4px 24px #0d1f3c14}.login-title{color:#0d1f3c;margin-bottom:20px;font-size:16px;font-weight:700}.login-form-group{margin-bottom:14px}.login-form-group label{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.login-form-group input{background:#f7faff;border:1px solid #dce8f5;border-radius:7px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:border .15s}.login-form-group input:focus{background:#fff;border-color:#185fa5}.btn-login{background:var(--brand-button);color:#fff;cursor:pointer;border:none;border-radius:7px;width:100%;margin-top:8px;padding:12px;font-family:inherit;font-size:15px;font-weight:700;transition:background .15s}.btn-login:hover:not(:disabled){background:var(--brand-button);filter:brightness(1.1)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#a32d2d;background:#fcebeb;border-left:3px solid #a32d2d;border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.login-footer{text-align:center;color:#aaa;margin-top:16px;font-size:11px}.grid-2col{grid-template-columns:360px 1fr;gap:16px;display:grid}.grid-halves{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-thirds{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}@media (width<=1024px){.metrics{grid-template-columns:repeat(2,1fr)}.db-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{width:60px;min-width:60px}.sidebar-logo-text,.nav-tab .nav-label,.nav-section,.sidebar-user-info,.sidebar-logout span{display:none}.main-content{max-width:calc(100vw - 60px);margin-left:60px;padding:16px}.topbar{margin:-16px -16px 16px;padding:10px 16px}.metrics{grid-template-columns:1fr 1fr}}@media (width<=580px){.form-grid,.form-grid.cols-3,.metrics{grid-template-columns:1fr}}
