.db-root{--db-green: #0d4429;--db-green-mid: #1a6b3f;--db-green-light: #2d9b5e;--db-green-bg: #e8f5ed;--db-green-brd: #86efac;--db-blue: #1d4ed8;--db-blue-bg: #eff6ff;--db-blue-brd: #bfdbfe;--db-purple: #6d28d9;--db-purple-bg: #f5f3ff;--db-amber: #92400e;--db-amber-bg: #fffbeb;--db-red: #7f1d1d;--db-red-bg: #fef2f2;--db-gray: #64748b;--db-border: #e2e8f0;--db-bg: #f0f4f8;--db-card: #ffffff;--db-text: #1a202c;--db-text-mid: #4a5568;--db-text-light: #718096;--db-shadow-sm: 0 1px 4px rgba(0,0,0,.07);--db-shadow-md: 0 4px 14px rgba(0,0,0,.09);--db-radius: 12px;--db-radius-sm: 8px;font-family:Inter,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}.db-container{display:flex;flex-direction:column;gap:0;min-height:100%}.db-header{background:var(--db-card);border-bottom:1px solid var(--db-border);padding:20px 28px 0}.db-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:4px;flex-wrap:wrap}.db-title{font-size:22px;font-weight:800;color:var(--db-text);letter-spacing:-.03em}.db-subtitle{font-size:13px;color:var(--db-text-light);margin-top:2px}.db-reload-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--db-border);border-radius:8px;background:var(--db-bg);color:var(--db-text-mid);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;flex-shrink:0}.db-reload-btn:hover{border-color:var(--db-green-light);color:var(--db-green)}.db-reload-btn.spinning svg{animation:db-spin .8s linear infinite}@keyframes db-spin{to{transform:rotate(360deg)}}.db-tabs{display:flex;gap:0;margin-top:16px;overflow-x:auto;scrollbar-width:none}.db-tabs::-webkit-scrollbar{display:none}.db-tab-btn{display:flex;align-items:center;gap:7px;padding:11px 22px;border:none;border-bottom:3px solid transparent;background:none;color:var(--db-text-light);font-size:13.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s}.db-tab-btn:hover{color:var(--db-green)}.db-tab-btn--active{color:var(--db-green);border-bottom-color:var(--db-green)}.dbf-wrap{background:var(--db-card);border-bottom:1px solid var(--db-border);padding:0 28px}.dbf-header{display:flex;align-items:center;justify-content:space-between;padding:12px 0 10px;border-bottom:1px solid var(--db-border);gap:12px}.dbf-header-left{display:flex;align-items:center;gap:8px}.dbf-header-icon{color:var(--db-green)}.dbf-header-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--db-text-mid)}.dbf-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--db-green);color:#fff;border-radius:20px;font-size:11px;font-weight:700}.dbf-clear-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border:1.5px solid var(--db-border);border-radius:20px;background:#fff;color:var(--db-text-light);font-size:11.5px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap}.dbf-clear-btn:hover{border-color:#fca5a5;background:#fef2f2;color:#dc2626}.dbf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px 16px;padding:14px 0;align-items:end}.dbf-group{display:flex;flex-direction:column;gap:5px}.dbf-label{display:flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--db-text-light);transition:color .18s}.dbf-label-icon{flex-shrink:0}.dbf-group--active .dbf-label{color:var(--db-green)}.dbf-select-wrap{position:relative;display:flex;align-items:center}.dbf-select{width:100%;padding:8px 32px 8px 11px;border:1.5px solid var(--db-border);border-radius:var(--db-radius-sm);font-size:13px;color:var(--db-text);background:var(--db-bg);outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:all .18s;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dbf-select:focus{border-color:var(--db-green-light);background-color:#fff;box-shadow:0 0 0 3px #2d9b5e1f}.dbf-select--active{border-color:var(--db-green-light);background-color:#fff;color:var(--db-green);font-weight:600;padding-right:48px}.dbf-group--active .dbf-select-wrap:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--db-green);border-radius:3px 0 0 3px}.dbf-select-clear{position:absolute;right:26px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:none;background:var(--db-green-light);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .15s;flex-shrink:0}.dbf-select-clear:hover{background:var(--db-green)}.db-filter-wrap{background:var(--db-card);border-bottom:1px solid var(--db-border);padding:14px 28px}.db-filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;align-items:end}.db-filter-group{display:flex;flex-direction:column;gap:4px}.db-filter-label{font-size:11px;font-weight:700;color:var(--db-text-light);text-transform:uppercase;letter-spacing:.06em}.db-filter-select{padding:8px 10px;border:1.5px solid var(--db-border);border-radius:var(--db-radius-sm);font-size:13px;color:var(--db-text);background:var(--db-bg);outline:none;cursor:pointer;width:100%;transition:all .18s}.db-filter-select:focus{border-color:var(--db-green-light);background:#fff;box-shadow:0 0 0 3px #2d9b5e1a}.db-filter-actions{display:flex;align-items:flex-end;gap:8px}.db-filter-clear{padding:8px 14px;border:1.5px solid #fca5a5;border-radius:var(--db-radius-sm);background:#fef2f2;color:#dc2626;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s}.db-filter-clear:hover{background:#fee2e2}.db-body{padding:24px 28px;display:flex;flex-direction:column;gap:24px}.db-section{display:flex;flex-direction:column;gap:14px}.db-section-title{font-size:14px;font-weight:700;color:var(--db-text);display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.05em}.db-section-title:after{content:"";flex:1;height:1px;background:var(--db-border)}.db-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.db-kpi-card{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);padding:18px 20px;box-shadow:var(--db-shadow-sm);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:all .2s}.db-kpi-card:hover{box-shadow:var(--db-shadow-md);transform:translateY(-1px)}.db-kpi-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--kpi-color, #0d4429)}.db-kpi-header{display:flex;align-items:center;justify-content:space-between}.db-kpi-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light)}.db-kpi-icon{width:34px;height:34px;border-radius:8px;background:var(--kpi-bg, #e8f5ed);display:flex;align-items:center;justify-content:center;color:var(--kpi-color, #0d4429);flex-shrink:0}.db-kpi-value{font-size:22px;font-weight:800;color:var(--db-text);line-height:1.1;word-break:break-all}.db-kpi-sub{font-size:12px;color:var(--db-text-light)}.db-kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;padding:2px 7px;border-radius:20px}.db-kpi-delta--up{background:#d1fae5;color:#065f46}.db-kpi-delta--down{background:#fee2e2;color:#7f1d1d}.db-kpi-delta--flat{background:#f1f5f9;color:var(--db-text-light)}.db-kpi-bar-bg{height:6px;background:var(--db-bg);border-radius:20px;overflow:hidden;margin-top:4px}.db-kpi-bar{height:100%;border-radius:20px;background:var(--kpi-color, #0d4429);transition:width .8s cubic-bezier(.4,0,.2,1)}.db-chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.db-chart-grid--3{grid-template-columns:2fr 1fr}.db-chart-box{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);padding:20px;box-shadow:var(--db-shadow-sm)}.db-chart-box--full{grid-column:1 / -1}.db-chart-title{font-size:13px;font-weight:700;color:var(--db-text);margin-bottom:14px;display:flex;align-items:center;gap:8px}.db-chart-title svg{color:var(--db-green)}.db-table-wrap{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);overflow:hidden;box-shadow:var(--db-shadow-sm)}.db-table-header{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--db-border);background:var(--db-bg);gap:12px;flex-wrap:wrap}.db-table-title{font-size:13px;font-weight:700;color:var(--db-text)}.db-table-count{font-size:12px;color:var(--db-text-light);background:#fff;border:1px solid var(--db-border);padding:3px 10px;border-radius:20px}.db-table-search{padding:6px 12px;border:1.5px solid var(--db-border);border-radius:var(--db-radius-sm);font-size:13px;outline:none;width:200px;background:#fff;transition:all .18s}.db-table-search:focus{border-color:var(--db-green-light);box-shadow:0 0 0 3px #2d9b5e1a}.db-table-scroll{overflow-x:auto}.db-table{width:100%;border-collapse:collapse;font-size:13px}.db-table th{padding:10px 14px;background:#f8fafc;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light);border-bottom:1px solid var(--db-border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.db-table th:hover{color:var(--db-green)}.db-table td{padding:10px 14px;border-bottom:1px solid #f0f4f8;color:var(--db-text);vertical-align:middle}.db-table tbody tr:last-child td{border-bottom:none}.db-table tbody tr:hover{background:var(--db-green-bg)}.db-table-empty{text-align:center;padding:40px!important;color:var(--db-text-light);font-size:13px}.db-table-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-top:1px solid var(--db-border);font-size:12px;color:var(--db-text-light);background:var(--db-bg);flex-wrap:wrap;gap:8px}.db-table-pag-btns{display:flex;gap:6px}.db-table-pag-btn{padding:4px 10px;border:1.5px solid var(--db-border);border-radius:6px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .18s;color:var(--db-text-mid)}.db-table-pag-btn:hover:not(:disabled){border-color:var(--db-green-light);color:var(--db-green)}.db-table-pag-btn:disabled{opacity:.4;cursor:not-allowed}.db-exec-summary{background:linear-gradient(135deg,#f0fdf4,#eff6ff);border:1px solid var(--db-green-brd);border-radius:var(--db-radius);padding:22px 26px;box-shadow:var(--db-shadow-sm)}.db-exec-summary__header{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:13px;font-weight:700;color:var(--db-green);text-transform:uppercase;letter-spacing:.06em}.db-exec-summary__text{font-size:14.5px;color:var(--db-text);line-height:1.75}.db-exec-summary__text strong{color:var(--db-green)}.db-exec-summary__tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.db-exec-tag{padding:4px 12px;background:#fff;border:1px solid var(--db-green-brd);border-radius:20px;font-size:12px;font-weight:600;color:var(--db-green)}.db-compare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.db-compare-card{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);padding:16px;box-shadow:var(--db-shadow-sm)}.db-compare-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light);margin-bottom:8px}.db-compare-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.db-compare-year{font-size:12px;color:var(--db-text-light)}.db-compare-val{font-size:13.5px;font-weight:700;color:var(--db-text)}.db-compare-val--curr{color:var(--db-green)}.db-compare-bar-bg{height:5px;background:var(--db-bg);border-radius:10px;overflow:hidden;margin-top:6px}.db-compare-bar{height:100%;border-radius:10px;background:var(--db-green-light)}.db-compare-bar--prev{background:#93c5fd}.db-pct-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:700}.pct--high{background:#d1fae5;color:#065f46}.pct--mid{background:#fef3c7;color:#92400e}.pct--low{background:#fee2e2;color:#7f1d1d}.db-sel-wrap{position:relative;z-index:100}.db-sel-bar{display:flex;align-items:center;gap:10px;padding:0 14px;height:48px;background:var(--db-card);border:1.5px solid var(--db-border);border-radius:var(--db-radius);cursor:pointer;box-shadow:var(--db-shadow-sm);transition:all .18s;-webkit-user-select:none;user-select:none}.db-sel-bar:hover{border-color:var(--db-green-light);box-shadow:var(--db-shadow-md)}.db-sel-bar--open{border-color:var(--db-green-light);border-bottom-left-radius:0;border-bottom-right-radius:0;box-shadow:0 2px 8px #0d44291a}.db-sel-bar--has{border-color:var(--db-green-brd)}.db-sel-icon{color:var(--db-text-light);flex-shrink:0}.db-sel-bar--open .db-sel-icon,.db-sel-bar--has .db-sel-icon{color:var(--db-green)}.db-sel-input{flex:1;border:none;outline:none;background:transparent;font-size:14px;color:var(--db-text);min-width:0;cursor:pointer}.db-sel-input::placeholder{color:var(--db-text-light)}.db-sel-bar--open .db-sel-input{cursor:text}.db-sel-count{font-size:11.5px;font-weight:600;color:var(--db-text-light);background:var(--db-bg);padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.db-sel-x{width:20px;height:20px;border-radius:50%;border:none;background:var(--db-border);color:var(--db-text-light);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;transition:all .15s}.db-sel-x:hover{background:#fca5a5;color:#dc2626}.db-sel-chevron{color:var(--db-text-light);flex-shrink:0;transition:transform .2s}.db-sel-chevron--open{transform:rotate(180deg);color:var(--db-green)}.db-sel-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--db-card);border:1.5px solid var(--db-green-light);border-top:none;border-bottom-left-radius:var(--db-radius);border-bottom-right-radius:var(--db-radius);box-shadow:0 8px 24px #0000001f;overflow:hidden}.db-sel-list{max-height:320px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--db-border) transparent}.db-sel-empty{padding:20px;text-align:center;color:var(--db-text-light);font-size:13px}.db-sel-option{display:flex;flex-direction:column;gap:2px;padding:11px 16px;border-bottom:1px solid #f0f4f8;cursor:pointer;transition:background .12s}.db-sel-option:last-child{border-bottom:none}.db-sel-option:hover{background:var(--db-green-bg)}.db-sel-option--active{background:var(--db-green-bg);border-left:3px solid var(--db-green)}.db-sel-opt-code{font-size:11px;font-weight:700;color:var(--db-green);font-family:Courier New,monospace}.db-sel-opt-name{font-size:13px;font-weight:500;color:var(--db-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-sel-opt-sub{font-size:11.5px;color:var(--db-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-master-detail{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}.db-master-panel{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);box-shadow:var(--db-shadow-sm);overflow:hidden;position:sticky;top:80px;max-height:calc(100vh - 180px);display:flex;flex-direction:column}.db-master-search-wrap{padding:12px 14px;border-bottom:1px solid var(--db-border);background:var(--db-bg)}.db-master-search{width:100%;padding:8px 12px 8px 34px;border:1.5px solid var(--db-border);border-radius:var(--db-radius-sm);font-size:13px;outline:none;background:#fff;transition:all .18s}.db-master-search:focus{border-color:var(--db-green-light)}.db-master-search-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:var(--db-text-light);pointer-events:none}.db-master-search-wrap{position:relative}.db-item-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--db-border) transparent}.db-item{padding:12px 14px;border-bottom:1px solid #f0f4f8;cursor:pointer;transition:all .15s}.db-item:hover{background:var(--db-green-bg)}.db-item--selected{background:var(--db-green-bg);border-left:3px solid var(--db-green)}.db-item-code{font-size:11px;font-weight:700;color:var(--db-green);margin-bottom:3px;font-family:Courier New,monospace}.db-item-name{font-size:13px;color:var(--db-text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.db-item-sub{font-size:11px;color:var(--db-text-light);margin-top:3px}.db-master-empty{padding:32px;text-align:center;color:var(--db-text-light);font-size:13px}.db-detail-panel{display:flex;flex-direction:column;gap:18px}.db-detail-empty{background:var(--db-card);border:2px dashed var(--db-border);border-radius:var(--db-radius);padding:60px;text-align:center;color:var(--db-text-light);font-size:14px}.db-detail-empty svg{margin-bottom:12px;color:var(--db-border)}.db-ficha{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);padding:22px;box-shadow:var(--db-shadow-sm)}.db-ficha-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.db-ficha-code{font-family:Courier New,monospace;font-size:12px;font-weight:700;color:var(--db-green);background:var(--db-green-bg);border:1px solid var(--db-green-brd);padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:6px}.db-ficha-title{font-size:17px;font-weight:700;color:var(--db-text);line-height:1.3}.db-ficha-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.db-ficha-field{display:flex;flex-direction:column;gap:3px}.db-ficha-field--full{grid-column:1 / -1}.db-ficha-field-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light)}.db-ficha-field-value{font-size:13.5px;color:var(--db-text);line-height:1.5}.db-source-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;background:var(--db-green-bg);border:1px solid var(--db-green-brd);border-radius:20px;font-size:12px;font-weight:600;color:var(--db-green)}.db-source-tags{display:flex;flex-wrap:wrap;gap:8px}.db-tooltip{background:#1a202c;border-radius:8px;padding:10px 14px;font-size:12.5px;color:#fff;box-shadow:0 8px 24px #00000040}.db-tooltip-label{font-weight:700;margin-bottom:6px;font-size:13px}.db-tooltip-row{display:flex;align-items:center;gap:8px;margin-top:4px}.db-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.db-tooltip-name{color:#ffffffb3}.db-tooltip-val{font-weight:600;margin-left:auto;padding-left:12px}.db-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--db-text-light);font-size:14px}.db-loading-icon{width:52px;height:52px;border:3px solid rgba(13,68,41,.15);border-top-color:#0d4429;border-radius:50%;animation:db-spin .75s linear infinite}.db-error-screen{background:#fef2f2;border:1.5px solid #fca5a5;border-radius:var(--db-radius);padding:36px;text-align:center;color:#7f1d1d;margin:24px 28px}.db-error-screen h3{font-size:17px;font-weight:700;margin-bottom:10px}.db-error-screen pre{background:#fff;border:1px solid #fca5a5;border-radius:8px;padding:12px;font-size:12px;text-align:left;white-space:pre-wrap;color:#991b1b;margin-top:14px;max-height:160px;overflow-y:auto}.db-no-file{background:#fffbeb;border:2px dashed #fde68a;border-radius:var(--db-radius);padding:48px;text-align:center;color:#92400e;margin:24px 28px;display:flex;flex-direction:column;align-items:center;gap:12px}.db-no-file h3{font-size:17px;font-weight:700}.db-no-file code{background:#fef3c7;border:1px solid #fde68a;padding:8px 16px;border-radius:8px;font-size:13.5px;color:#78350f;font-family:Courier New,monospace}.db-no-file ul,.db-no-file ol{text-align:left;font-size:13px;line-height:2}.db-donut-top{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:center;background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);padding:24px;box-shadow:var(--db-shadow-sm)}.db-donut-chart-col{display:flex;flex-direction:column;align-items:center;gap:16px}.db-donut-chart-wrap{position:relative;width:260px;height:260px;flex-shrink:0}.db-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.db-donut-pct{font-size:32px;font-weight:900;color:#0d4429;line-height:1;letter-spacing:-.03em}.db-donut-pct-label{font-size:12px;font-weight:600;color:var(--db-text-light);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.db-donut-legend{display:flex;flex-direction:column;gap:8px;width:100%}.db-donut-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--db-text-mid)}.db-donut-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.db-donut-legend-name{flex:1}.db-donut-legend-pct{font-weight:700;color:var(--db-text);font-size:13px}.db-donut-stats{display:flex;flex-direction:column;gap:22px}.db-donut-stat{display:flex;flex-direction:column;gap:6px}.db-donut-stat-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap}.db-donut-stat-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light)}.db-donut-stat-value{font-size:20px;font-weight:800;color:var(--db-text);letter-spacing:-.02em}.db-donut-stat-bar-bg{height:8px;background:var(--db-bg);border-radius:20px;overflow:hidden}.db-donut-stat-bar{height:100%;border-radius:20px;transition:width .8s cubic-bezier(.4,0,.2,1)}.db-donut-stat-sub{font-size:12px;color:var(--db-text-light);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.db-donut-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}.db-donut-panel{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);overflow:hidden;box-shadow:var(--db-shadow-sm)}.db-donut-panel-label{padding:10px 18px;background:var(--db-bg);border-bottom:1px solid var(--db-border);border-top:3px solid currentColor;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.db-donut-panel-period{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--db-text)}.db-donut-panel-sub{font-size:11px;color:var(--db-text-light);font-weight:500}.db-donut-panel-body{padding:20px;display:flex;gap:20px;align-items:center}.db-donut-thead-group th{border-bottom:1px solid var(--db-border)}.db-donut-th-group{text-align:center!important;padding:8px 14px!important;font-size:11px!important;font-weight:800!important;letter-spacing:.06em!important}.db-donut-th-curr{background:#e8f5ed!important;color:#0d4429!important;border-bottom:2px solid #0d4429!important}.db-donut-th-prev{background:#f5f3ff!important;color:#6d28d9!important;border-bottom:2px solid #6d28d9!important}.db-donut-th-curr-sub{background:#f0fdf4!important;color:#0d4429!important;border-bottom:1px solid var(--db-border)!important}.db-donut-th-prev-sub{background:#faf5ff!important;color:#6d28d9!important;border-bottom:1px solid var(--db-border)!important}.db-dt-prev{background:#fdfcff}.db-donut-table-legend{float:right;font-size:11px;font-weight:600;color:var(--db-text-light);display:flex;align-items:center;gap:6px}.db-donut-table-wrap{background:var(--db-card);border:1px solid var(--db-border);border-radius:var(--db-radius);overflow:hidden;box-shadow:var(--db-shadow-sm)}.db-donut-table-title{padding:12px 18px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light);background:var(--db-bg);border-bottom:1px solid var(--db-border)}.db-donut-table-scroll{overflow-x:auto}.db-donut-table{width:100%;border-collapse:collapse;font-size:13px}.db-donut-table th{padding:10px 16px;background:#f8fafc;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--db-text-light);border-bottom:1px solid var(--db-border);white-space:nowrap}.db-donut-table td{padding:11px 16px;border-bottom:1px solid #f0f4f8;color:var(--db-text);vertical-align:middle}.db-donut-table tbody tr:last-child td{border-bottom:none}.db-donut-table tbody tr:hover{background:var(--db-green-bg)}.db-donut-table tfoot{border-top:2px solid var(--db-border)}.db-donut-total-row td{padding:12px 16px;background:#f8fafc;font-weight:700;color:var(--db-text);font-size:13px;border-bottom:none}.db-dt-right{text-align:right!important}.db-dt-money{font-variant-numeric:tabular-nums;white-space:nowrap}.db-donut-fuente{max-width:260px;font-weight:500}@media (max-width: 1200px){.db-kpi-grid{grid-template-columns:repeat(2,1fr)}.db-chart-grid,.db-chart-grid--3{grid-template-columns:1fr}}@media (max-width: 900px){.db-master-detail{grid-template-columns:1fr}.db-master-panel{position:static;max-height:340px}.db-compare-grid,.db-donut-top,.db-donut-cols{grid-template-columns:1fr}.db-donut-chart-col{flex-direction:row;justify-content:flex-start;align-items:center;gap:24px}.db-donut-chart-wrap{width:200px;height:200px;flex-shrink:0}.db-donut-panel-body{flex-wrap:wrap}}@media (max-width: 768px){.db-body{padding:16px}.db-header{padding:16px 16px 0}.db-filter-wrap{padding:12px 16px}.db-filter-grid{grid-template-columns:1fr 1fr}.dbf-wrap{padding:0 16px}.dbf-grid{grid-template-columns:1fr 1fr}.db-kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.db-ficha-grid{grid-template-columns:1fr}.db-donut-chart-col{flex-direction:column}.db-donut-top{padding:16px;gap:16px}}@media (max-width: 480px){.db-kpi-grid,.db-filter-grid{grid-template-columns:1fr}.db-tab-btn{padding:10px 14px;font-size:12.5px}}:root{--c-primary: #0d4429;--c-primary-dark: #082d1a;--c-primary-mid: #1a6b3f;--c-primary-light: #2d9b5e;--c-primary-bg: #e8f5ed;--c-primary-border: #86efac;--c-white: #ffffff;--c-bg: #f0f4f8;--c-bg-card: #ffffff;--c-text: #1a202c;--c-text-mid: #4a5568;--c-text-light: #718096;--c-border: #e2e8f0;--c-border-focus: #2d9b5e;--c-success: #065f46;--c-success-bg: #d1fae5;--c-warning: #78350f;--c-warning-bg: #fef3c7;--c-danger: #7f1d1d;--c-danger-bg: #fee2e2;--c-info: #1e40af;--c-info-bg: #dbeafe;--sidebar-w: 260px;--sidebar-collapsed: 72px;--topbar-h: 64px;--shadow-xs: 0 1px 2px rgba(0,0,0,.06);--shadow-sm: 0 1px 6px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--shadow-xl: 0 16px 48px rgba(0,0,0,.15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition: all .22s cubic-bezier(.4,0,.2,1);--transition-slow: all .35s ease;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}img{max-width:100%;display:block}code{font-family:Courier New,Courier,monospace;font-size:.85em;background:#f0f4f8;padding:2px 6px;border-radius:4px;color:#0d4429}.spinner{width:36px;height:36px;border:3px solid rgba(13,68,41,.15);border-top-color:var(--c-primary);border-radius:50%;animation:spin .75s linear infinite;display:inline-block}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;display:inline-block;vertical-align:middle;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.lg-page{display:flex;min-height:100vh;overflow:hidden;background:#060f08}.lg-left{flex:1;position:relative;background:#071810;display:flex;flex-direction:column;overflow:hidden;padding:28px 60px 48px}.lg-left:before{content:"";position:absolute;width:220%;height:130%;top:-15%;left:-60%;background:radial-gradient(ellipse 42% 35% at 15% 25%,rgba(34,197,94,.75) 0%,transparent 58%),radial-gradient(ellipse 50% 40% at 60% 15%,rgba(16,185,129,.65) 0%,transparent 62%),radial-gradient(ellipse 38% 32% at 40% 70%,rgba(52,211,153,.6) 0%,transparent 55%),radial-gradient(ellipse 44% 36% at 85% 82%,rgba(34,197,94,.55) 0%,transparent 58%);filter:blur(42px);animation:aurora-a 8s ease-in-out infinite alternate;pointer-events:none;z-index:0;will-change:transform,opacity}.lg-left:after{content:"";position:absolute;width:220%;height:130%;top:-15%;left:-60%;background:radial-gradient(ellipse 48% 38% at 30% 55%,rgba(6,182,212,.5) 0%,transparent 60%),radial-gradient(ellipse 40% 34% at 75% 30%,rgba(74,222,128,.58) 0%,transparent 58%),radial-gradient(ellipse 36% 30% at 55% 85%,rgba(0,180,150,.5) 0%,transparent 55%),radial-gradient(ellipse 42% 36% at 10% 78%,rgba(6,182,212,.42) 0%,transparent 60%);filter:blur(50px);animation:aurora-b 13s ease-in-out infinite alternate-reverse;pointer-events:none;z-index:0;will-change:transform,opacity}.lg-aurora-c{position:absolute;width:220%;height:130%;top:-15%;left:-60%;background:radial-gradient(ellipse 55% 45% at 50% 40%,rgba(20,230,100,.35) 0%,transparent 65%),radial-gradient(ellipse 38% 32% at 20% 75%,rgba(0,210,130,.3) 0%,transparent 58%),radial-gradient(ellipse 42% 38% at 80% 68%,rgba(0,190,160,.28) 0%,transparent 60%);filter:blur(65px);animation:aurora-c 11s ease-in-out infinite alternate;pointer-events:none;z-index:0;will-change:transform,opacity}@keyframes aurora-a{0%{transform:translate(0) skew(-8deg) scaleY(1);opacity:.85}33%{transform:translate(-20%) skew(6deg) scaleY(1.15);opacity:1}66%{transform:translate(15%) skew(-9deg) scaleY(.9);opacity:.88}to{transform:translate(-25%) skew(7deg) scaleY(1.1);opacity:.95}}@keyframes aurora-b{0%{transform:translate(0) skew(7deg) scaleY(1);opacity:.75}33%{transform:translate(22%) skew(-5deg) scaleY(1.18);opacity:.9}66%{transform:translate(-18%) skew(8deg) scaleY(.88);opacity:.8}to{transform:translate(24%) skew(-6deg) scaleY(1.12);opacity:.92}}@keyframes aurora-c{0%{transform:translate(0) scaleX(1) scaleY(1);opacity:.7}50%{transform:translate(18%) scaleX(1.15) scaleY(1.2);opacity:.9}to{transform:translate(-16%) scaleX(.92) scaleY(.88);opacity:.72}}.lg-left-inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;gap:36px;justify-content:center}.lg-brand{display:flex;align-items:center;gap:14px}.lg-brand-icon{flex-shrink:0;display:flex}.lg-brand-name{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em}.lg-brand-sub{font-size:12px;color:#ffffff73;margin-top:2px}.lg-right-logo{display:flex;justify-content:center;align-items:center;margin-bottom:28px}.lg-right-logo-img{height:70px;width:auto;object-fit:contain;display:block}.lg-brand-pill{margin-left:auto;font-size:11px;font-weight:600;color:#fff6;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);padding:3px 10px;border-radius:999px;letter-spacing:.05em}.lg-hero{display:flex;flex-direction:column;gap:18px}.lg-hero-tag{display:inline-flex;align-items:center;gap:9px;color:#fff9;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.lg-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px #22c55e40;flex-shrink:0;animation:pulse-glow 2.2s ease infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 3px #22c55e40}50%{box-shadow:0 0 0 7px #22c55e14}}.lg-headline{font-size:clamp(36px,3.4vw,54px);font-weight:800;line-height:1.12;letter-spacing:-.03em;color:#fff;min-height:1.12em}.lg-phrase{display:block;transition:opacity .35s ease,transform .35s ease}.lg-phrase--in{opacity:1;transform:translateY(0)}.lg-phrase--out{opacity:0;transform:translateY(-10px)}.lg-hero-desc{font-size:15px;color:#ffffff8c;line-height:1.78;max-width:440px}.lg-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.lg-metric{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px 14px 14px;transition:background .2s ease,border-color .2s ease;cursor:default}.lg-metric:hover{background:#ffffff12;border-color:#ffffff24}.lg-metric-num{font-size:24px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:8px;background:linear-gradient(135deg,#fff 30%,#86efac);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lg-metric-label{font-size:12px;font-weight:700;color:#fffc;margin-bottom:2px}.lg-metric-desc{font-size:11px;color:#ffffff59}.lg-img-wrap{position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 2px #ffffff0f inset,0 8px 32px #00000059,0 2px 8px #0003;flex-shrink:0}.lg-img{width:100%;height:200px;object-fit:cover;object-position:center 30%;display:block;filter:brightness(.88) saturate(.85);transition:filter .4s ease}.lg-img-wrap:hover .lg-img{filter:brightness(.95) saturate(.95)}.lg-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0d3d200d,#0d3d2000 35%,#0d3d208c 80%,#0d3d20cc);pointer-events:none}.lg-img-caption{position:absolute;bottom:12px;left:14px;display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:#ffffffd9;letter-spacing:.02em;text-shadow:0 1px 4px rgba(0,0,0,.4)}.lg-img-caption-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;flex-shrink:0;box-shadow:0 0 6px #4ade80b3}.lg-left-footer{position:relative;z-index:2;font-size:11px;color:#ffffff40;padding-top:20px;border-top:1px solid rgba(255,255,255,.07);letter-spacing:.03em}.lg-right{width:510px;flex-shrink:0;background:#eef5f0;background-image:radial-gradient(circle at 1px 1px,rgba(13,68,41,.07) 1px,transparent 0);background-size:22px 22px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 40px 32px;min-height:100vh}.lg-card{width:100%;max-width:410px;background:#fff;border-radius:24px;box-shadow:0 0 0 1px #0d442912,0 2px 4px #00000008,0 12px 32px #0d442917,0 40px 72px #0000000f;overflow:hidden}.lg-card-bar{height:4px;background:linear-gradient(90deg,#0d4429,#22c55e,#1a6b3f,#0d4429);background-size:300%;animation:bar-slide 5s linear infinite}@keyframes bar-slide{0%{background-position:0%}to{background-position:300%}}.lg-card--shake{animation:card-shake .5s cubic-bezier(.36,.07,.19,.97)}@keyframes card-shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.lg-card-header{padding:32px 36px 24px;border-bottom:1px solid #f3f4f6}.lg-card-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#0d4429;background:#e8f5ed;border:1px solid #b6e0c6;padding:4px 12px;border-radius:999px;letter-spacing:.07em;text-transform:uppercase;margin-bottom:18px}.lg-card-title{font-size:30px;font-weight:800;color:#0d1a0f;letter-spacing:-.025em;line-height:1.2;margin-bottom:8px}.lg-card-sub{font-size:14px;color:#6b7280;line-height:1.55}.lg-form{display:flex;flex-direction:column;gap:20px;padding:28px 36px}.lg-error{display:flex;align-items:flex-start;gap:10px;padding:13px 15px;background:#fff5f5;border:1px solid #fecaca;border-left:3px solid #ef4444;border-radius:12px;color:#991b1b;font-size:13px;font-weight:500;line-height:1.5;animation:error-in .2s ease}.lg-error svg{flex-shrink:0;margin-top:1px}@keyframes error-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lg-field{display:flex;flex-direction:column;gap:8px}.lg-label{font-size:11.5px;font-weight:700;color:#374151;letter-spacing:.07em;text-transform:uppercase}.lg-input-wrap{position:relative}.lg-input-ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#c4c9d4;pointer-events:none;display:flex;transition:color .2s ease}.lg-input-wrap:focus-within .lg-input-ico{color:#0d4429}.lg-input{width:100%;padding:14px 15px 14px 46px;border:1.5px solid #e5e7eb;border-radius:12px;font-size:14px;color:#111827;background:#fafafa;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;outline:none}.lg-input::placeholder{color:#d1d5db}.lg-input:hover:not(:focus){border-color:#d1d5db}.lg-input:focus{background:#fff;border-color:#0d4429;box-shadow:0 0 0 4px #0d442914}.lg-input--pass{padding-right:48px}.lg-input--err{border-color:#ef4444!important;background:#fff9f9;box-shadow:0 0 0 4px #ef44440f!important}.lg-eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:#c4c9d4;padding:5px;display:flex;align-items:center;border-radius:6px;transition:color .2s ease,background .2s ease}.lg-eye:hover{color:#0d4429;background:#f0fdf4}.lg-submit{width:100%;padding:15px 20px;background:linear-gradient(135deg,#082d1a,#0d4429 40%,#1a6b3f);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;letter-spacing:.025em;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #0d442952,0 1px 3px #0000001a;position:relative;overflow:hidden}.lg-submit:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 60%);opacity:0;transition:opacity .2s ease}.lg-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #0d44296b,0 2px 6px #0000001f}.lg-submit:hover:not(:disabled):after{opacity:1}.lg-submit:active:not(:disabled){transform:translateY(0)}.lg-submit:disabled{opacity:.62;cursor:not-allowed;transform:none}.lg-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.lg-notice{display:flex;align-items:flex-start;gap:9px;padding:0 36px 28px;font-size:11.5px;color:#b0b8c4;line-height:1.65}.lg-notice svg{flex-shrink:0;margin-top:2px;color:#c8d0da}.lg-right-footer{position:relative;z-index:1;margin-top:24px;display:flex;align-items:center;gap:14px;font-size:11.5px;color:#a8b4be}.lg-dot-sep{width:4px;height:4px;border-radius:50%;background:#c8d0da;flex-shrink:0}@media (max-width: 960px){.lg-left{display:none}.lg-right{width:100%;background:#fff;background-image:none}}@media (max-width: 540px){.lg-right{padding:24px 16px}.lg-card{border-radius:18px}.lg-card-header{padding:24px 24px 20px}.lg-form{padding:20px 24px}.lg-notice{padding:0 24px 24px}}.layout{display:flex;min-height:100vh;background:var(--c-bg)}.layout__overlay{display:none}.layout__main{flex:1;min-width:0;display:flex;flex-direction:column;margin-left:var(--sidebar-w);transition:margin-left .25s ease}.layout--collapsed .layout__main{margin-left:var(--sidebar-collapsed)}.layout__content{flex:1;padding:0;min-height:calc(100vh - var(--topbar-h) - 48px)}.layout__footer{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;font-size:12px;color:var(--c-text-light);background:var(--c-white);border-top:1px solid var(--c-border);flex-wrap:wrap}.layout__footer-sep{opacity:.4}.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-w);background:var(--c-primary);display:flex;flex-direction:column;transition:width .25s ease;z-index:100;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--topbar-h);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar__logo-wrap{display:flex;align-items:center;gap:12px;overflow:hidden}.sidebar__logo-icon{flex-shrink:0}.sidebar__logo-text{overflow:hidden}.sidebar__logo-title{font-size:14px;font-weight:800;color:#fff;white-space:nowrap;letter-spacing:-.01em}.sidebar__logo-sub{font-size:11px;color:#ffffff8c;white-space:nowrap}.sidebar__toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fffc;border-radius:var(--radius-sm);padding:6px;display:flex;align-items:center;flex-shrink:0;transition:var(--transition)}.sidebar__toggle:hover{background:#ffffff2e;color:#fff}.sidebar__profile{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar__avatar{width:36px;height:36px;border-radius:50%;background:#ffffff26;border:2px solid rgba(255,255,255,.25);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar__profile-info{overflow:hidden;min-width:0}.sidebar__profile-name{display:block;font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__profile-role{display:block;font-size:11px;color:#ffffff8c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.sidebar__nav-label{display:block;font-size:10px;font-weight:700;letter-spacing:.1em;color:#fff6;padding:8px 18px 4px;white-space:nowrap}.sidebar__menu{list-style:none}.sidebar__menu-item{margin:2px 8px}.sidebar__link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-md);color:#ffffffb3;font-size:14px;font-weight:500;transition:var(--transition);white-space:nowrap;overflow:hidden;position:relative}.sidebar__link:hover{background:#ffffff1a;color:#fff}.sidebar__link--active{background:#ffffff26;color:#fff;font-weight:600}.sidebar__link--active:before{content:"";position:absolute;left:0;top:20%;height:60%;width:3px;background:#4ade80;border-radius:0 3px 3px 0}.sidebar__link-icon{flex-shrink:0;display:flex;align-items:center}.sidebar__link-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar__link-badge{font-size:10px;padding:2px 7px;background:#ffa50033;border:1px solid rgba(255,165,0,.3);border-radius:var(--radius-full);color:#fbbf24;font-weight:600;flex-shrink:0}.sidebar__footer{padding:12px 8px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar__logout{display:flex;align-items:center;gap:12px;padding:11px 14px;width:100%;border-radius:var(--radius-md);background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ff9696e6;font-size:14px;font-weight:500;transition:var(--transition);overflow:hidden;white-space:nowrap}.sidebar__logout:hover{background:#ef444433;color:#fca5a5;border-color:#ef444459}.topbar{position:sticky;top:0;z-index:50;height:var(--topbar-h);background:var(--c-white);border-bottom:1px solid var(--c-border);display:flex;align-items:center;padding:0 24px;gap:16px;box-shadow:var(--shadow-xs)}.topbar__menu-btn{display:none;background:none;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text-mid);padding:7px;align-items:center;transition:var(--transition)}.topbar__menu-btn:hover{background:var(--c-bg);border-color:var(--c-primary-light)}.topbar__greeting{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.topbar__greeting-text{font-size:14px;color:var(--c-text-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar__greeting-text strong{color:var(--c-text)}.topbar__sep{color:var(--c-border);font-size:16px}.topbar__dep{font-size:13px;color:var(--c-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.topbar__icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1.5px solid var(--c-border);border-radius:var(--radius-md);color:var(--c-text-mid);position:relative;transition:var(--transition)}.topbar__icon-btn:hover{background:var(--c-bg);border-color:var(--c-primary-light);color:var(--c-primary)}.topbar__notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:#ef4444;border-radius:50%;border:2px solid white}.topbar__user{display:flex;align-items:center;gap:10px;padding:6px 12px;background:var(--c-bg);border:1.5px solid var(--c-border);border-radius:var(--radius-md)}.topbar__avatar{width:30px;height:30px;border-radius:50%;background:var(--c-primary);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar__user-info{display:flex;flex-direction:column;gap:2px}.topbar__user-name{font-size:13px;font-weight:600;color:var(--c-text);white-space:nowrap}.topbar__logout-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:none;border:1.5px solid #fca5a5;border-radius:var(--radius-md);color:#dc2626;font-size:13px;font-weight:600;transition:var(--transition)}.topbar__logout-btn:hover{background:#fef2f2;border-color:#ef4444}.page-container{padding:28px 32px;display:flex;flex-direction:column;gap:28px;max-width:1400px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-title{font-size:26px;font-weight:800;color:var(--c-text);letter-spacing:-.03em;line-height:1.2}.page-subtitle{font-size:14px;color:var(--c-text-light);margin-top:4px;line-height:1.5}.page-header__badge{flex-shrink:0;padding-top:4px}.section{display:flex;flex-direction:column;gap:16px}.section__title{font-size:17px;font-weight:700;color:var(--c-text);display:flex;align-items:center;gap:10px}.section__title:after{content:"";flex:1;height:1px;background:var(--c-border)}.card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.stat-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:22px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--card-color);border-radius:0 2px 2px 0}.stat-card--clickable{cursor:pointer}.stat-card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--card-border)}.stat-card__icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);display:flex;align-items:center;justify-content:center;color:var(--card-color);flex-shrink:0}.stat-card__body{flex:1;min-width:0}.stat-card__value{font-size:28px;font-weight:800;color:var(--c-text);line-height:1}.stat-card__label{font-size:13px;font-weight:600;color:var(--c-text-mid);margin-top:4px}.stat-card__sub{font-size:11px;color:var(--c-text-light);margin-top:2px}.stat-card__arrow{color:var(--c-text-light);transition:var(--transition)}.stat-card--clickable:hover .stat-card__arrow{color:var(--card-color);transform:translate(3px)}.welcome-banner{background:linear-gradient(135deg,var(--c-white) 0%,#f0fdf4 100%);border:1px solid var(--c-primary-border);border-radius:var(--radius-lg);padding:28px 32px;box-shadow:var(--shadow-sm)}.welcome-banner__left{display:flex;align-items:flex-start;gap:20px}.welcome-banner__icon{flex-shrink:0}.welcome-banner__title{font-size:18px;font-weight:700;color:var(--c-primary);margin-bottom:8px}.welcome-banner__text{font-size:14px;color:var(--c-text-mid);line-height:1.7;max-width:700px}.welcome-banner__meta{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:13px;color:var(--c-text-light);flex-wrap:wrap}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.module-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;flex-direction:column;gap:10px}.module-card--clickable{cursor:pointer}.module-card--clickable:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--module-color, var(--c-primary))}.module-card--disabled{opacity:.6}.module-card__icon{font-size:28px;line-height:1}.module-card__title{font-size:16px;font-weight:700;color:var(--c-text)}.module-card__desc{font-size:13px;color:var(--c-text-light);line-height:1.5;flex:1}.module-card__arrow{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--module-color, var(--c-primary));margin-top:4px}.module-card__badge{display:inline-block;padding:4px 10px;background:#fff3e0;color:#e65100;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;width:fit-content}.role-dist{display:flex;flex-direction:column;gap:14px}.role-dist__item{display:flex;flex-direction:column;gap:6px}.role-dist__header{display:flex;justify-content:space-between;align-items:center}.role-dist__name{font-size:13px;font-weight:600;color:var(--c-text-mid)}.role-dist__count{font-size:12px;color:var(--c-text-light)}.role-dist__bar-bg{height:8px;background:var(--c-bg);border-radius:var(--radius-full);overflow:hidden}.role-dist__bar{height:100%;border-radius:var(--radius-full);transition:width .8s cubic-bezier(.4,0,.2,1);min-width:4px}.powerbi-placeholder{background:linear-gradient(135deg,#f8fafc,#f0f9ff);border:2px dashed var(--c-border);border-radius:var(--radius-lg);padding:60px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.powerbi-placeholder__icon{width:72px;height:72px;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--c-primary);box-shadow:var(--shadow-sm);margin-bottom:8px}.powerbi-placeholder h3{font-size:18px;font-weight:700;color:var(--c-text)}.powerbi-placeholder p{font-size:14px;color:var(--c-text-light);max-width:520px;line-height:1.6}.powerbi-placeholder__tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:8px}.powerbi-placeholder__tags span{padding:4px 12px;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-full);font-size:12px;color:var(--c-text-light)}.users-stats-row{display:flex;gap:12px;flex-wrap:wrap}.users-stat{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:14px 20px;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:100px;box-shadow:var(--shadow-xs)}.users-stat--active{border-color:#86efac;background:#f0fdf4}.users-stat--inactive{border-color:#fca5a5;background:#fef2f2}.users-stat__value{font-size:24px;font-weight:800;color:var(--c-text);line-height:1}.users-stat__label{font-size:11px;color:var(--c-text-light);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.user-table-wrap{display:flex;flex-direction:column}.filter-bar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--c-border);flex-wrap:wrap}.filter-bar__search{position:relative;flex:1;min-width:240px}.filter-bar__search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--c-text-light);pointer-events:none;display:flex}.filter-bar__input{width:100%;padding:9px 36px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);font-size:13px;color:var(--c-text);background:var(--c-bg);outline:none;transition:var(--transition)}.filter-bar__input:focus{border-color:var(--c-primary-light);background:var(--c-white);box-shadow:0 0 0 3px #2d9b5e1a}.filter-bar__clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--c-text-light);font-size:14px;padding:2px 4px;cursor:pointer}.filter-bar__filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filter-bar__select{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);font-size:13px;color:var(--c-text);background:var(--c-bg);outline:none;cursor:pointer;transition:var(--transition);min-width:150px}.filter-bar__select:focus{border-color:var(--c-primary-light);background:var(--c-white)}.table-meta{padding:8px 20px;font-size:12px;color:var(--c-text-light);background:var(--c-bg);border-bottom:1px solid var(--c-border)}.table-meta__count strong{color:var(--c-text)}.table-container{overflow-x:auto;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table th{padding:11px 16px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-light);background:var(--c-bg);border-bottom:1px solid var(--c-border);white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{color:var(--c-primary)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--c-border);color:var(--c-text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--c-primary-bg)}.row--inactive td{opacity:.6}.text-center{text-align:center!important}.text-muted{color:var(--c-text-light);font-size:12.5px}.table-empty{text-align:center!important;padding:48px 24px!important;color:var(--c-text-light)}.table-empty__icon{font-size:32px;margin-bottom:10px}.user-cell{display:flex;align-items:center;gap:10px}.user-cell__avatar{width:34px;height:34px;border-radius:50%;background:var(--c-primary-bg);border:1.5px solid var(--c-primary-border);color:var(--c-primary);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-cell__name{font-weight:600;font-size:13.5px;line-height:1.3}.user-cell__cargo{font-size:11.5px;color:var(--c-text-light)}.code-tag{font-family:Courier New,monospace;font-size:12px;background:var(--c-bg);color:var(--c-primary-mid);padding:3px 8px;border-radius:4px;border:1px solid var(--c-border)}.action-btns{display:flex;align-items:center;justify-content:center;gap:6px}.action-btn{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid transparent;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.action-btn--edit{color:var(--c-info);background:#eff6ff;border-color:#bfdbfe}.action-btn--edit:hover{background:#dbeafe;border-color:#93c5fd}.action-btn--toggle-off{color:#d97706;background:#fffbeb;border-color:#fde68a}.action-btn--toggle-off:hover{background:#fef3c7}.action-btn--toggle-on{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.action-btn--toggle-on:hover{background:#a7f3d0}.action-btn--delete{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.action-btn--delete:hover{background:#fee2e2;border-color:#ef4444}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f19288c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--c-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}.modal--sm{max-width:440px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px 20px;border-bottom:1px solid var(--c-border);gap:16px}.modal__title{font-size:19px;font-weight:700;color:var(--c-text)}.modal__subtitle{font-size:13px;color:var(--c-text-light);margin-top:3px}.modal__close{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text-light);padding:6px;display:flex;align-items:center;flex-shrink:0;transition:var(--transition)}.modal__close:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.modal__body{padding:24px 28px}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding-top:20px;margin-top:8px;border-top:1px solid var(--c-border)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group--full{grid-column:1 / -1}.form-label{font-size:13px;font-weight:600;color:var(--c-text-mid)}.form-required{color:#ef4444}.form-input{width:100%;padding:10px 14px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);font-size:14px;color:var(--c-text);background:var(--c-white);outline:none;transition:var(--transition)}.form-input:focus{border-color:var(--c-primary-light);box-shadow:0 0 0 3px #2d9b5e1a}.form-input--error{border-color:#ef4444}.form-select{cursor:pointer}.form-error{font-size:12px;color:#dc2626;display:flex;align-items:center;gap:4px}.input-password-wrap{position:relative}.input-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--c-text-light);padding:4px;display:flex;align-items:center;transition:var(--transition)}.input-password-toggle:hover{color:var(--c-primary)}.form-api-error{display:flex;align-items:flex-start;gap:8px;margin-top:8px;padding:11px 14px;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#b91c1c;font-size:13px;font-weight:500;line-height:1.45}.form-note{margin-top:8px;padding:10px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);font-size:12px;color:#78350f;line-height:1.5}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--radius-md);font-size:13.5px;font-weight:600;border:none;transition:var(--transition);cursor:pointer;white-space:nowrap}.btn--sm{padding:8px 14px;font-size:13px}.btn--primary{background:linear-gradient(135deg,var(--c-primary) 0%,var(--c-primary-mid) 100%);color:#fff;box-shadow:0 2px 8px #0d442940}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--c-primary-dark) 0%,var(--c-primary) 100%);box-shadow:0 4px 12px #0d442959;transform:translateY(-1px)}.btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn--secondary{background:var(--c-bg);color:var(--c-text-mid);border:1.5px solid var(--c-border)}.btn--secondary:hover{background:var(--c-border);color:var(--c-text)}.btn--danger{background:#dc2626;color:#fff;box-shadow:0 2px 8px #dc262633}.btn--danger:hover{background:#b91c1c}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.role-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:var(--transition);border-top:3px solid var(--role-color)}.role-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.role-card__header{display:flex;align-items:center;gap:12px}.role-card__icon{font-size:28px;width:46px;height:46px;background:var(--role-bg);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.role-card__name{font-size:15px;font-weight:700;color:var(--c-text)}.role-card__level{font-size:11px;color:var(--role-color);font-weight:600;background:var(--role-bg);padding:2px 8px;border-radius:var(--radius-full);display:inline-block;margin-top:2px}.role-card__desc{font-size:13px;color:var(--c-text-light);line-height:1.6}.role-card__id code{font-size:12px;color:var(--role-color);background:var(--role-bg);padding:3px 10px}.permissions-table th,.permissions-table td{padding:12px 16px}.perm-th{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px}.perm-name{font-size:13px!important;color:var(--c-text-mid)!important}.perm-check{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#d1fae5;border-radius:50%;color:#065f46}.perm-x{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fee2e2;border-radius:50%;color:#dc2626}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.note-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-xs)}.note-card h4{font-size:14px;font-weight:700;color:var(--c-text);margin-bottom:8px}.note-card p{font-size:13px;color:var(--c-text-light);line-height:1.6}.info-banner{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--c-info-bg);border:1px solid #bfdbfe;border-radius:var(--radius-md);font-size:13.5px;color:var(--c-info);line-height:1.5}.info-banner strong{font-weight:700}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.topbar__dep{display:none}.topbar__user-name{max-width:100px;overflow:hidden;text-overflow:ellipsis}}@media (max-width: 768px){.sidebar{transform:translate(-100%);box-shadow:var(--shadow-xl)}.layout--collapsed .sidebar{transform:translate(0)!important;width:var(--sidebar-w)!important}.layout__main{margin-left:0!important}.layout__overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.topbar__menu-btn{display:flex}.topbar__greeting,.topbar__user-name{display:none}.page-container{padding:20px 16px;gap:20px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-card{padding:16px}.stat-card__value{font-size:22px}.login-page{flex-direction:column}.login-left{min-height:auto;padding:32px 24px}.login-left__pillars{grid-template-columns:1fr 1fr}.login-right{width:100%;padding:32px 20px;min-height:auto;box-shadow:none}.login-card{max-width:100%}.form-grid{grid-template-columns:1fr}.modal{max-width:100%;margin:0 4px;border-radius:var(--radius-lg)}.modal__header{padding:18px 20px 16px}.modal__body{padding:18px 20px}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar__search{min-width:auto}.filter-bar__filters{justify-content:space-between}.filter-bar__select{flex:1}.users-stats-row{gap:8px}.users-stat{padding:10px 14px}.users-stat__value{font-size:20px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.welcome-banner__left{flex-direction:column}.module-grid,.roles-grid,.notes-grid{grid-template-columns:1fr}.login-left__phrases{gap:12px}.login-left__headline{font-size:24px}.login-left__pillars{grid-template-columns:1fr}.topbar__actions{gap:8px}.topbar__logout-btn span{display:none}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px 10px}}
