:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--bg:#f8f9fa;--bg-card:#fff;--bg-secondary:#f1f3f5;--text:#1a1a2e;--text-secondary:#6c757d;--border:#dee2e6;--accent:#4361ee;--accent-hover:#3a56d4;--green:#2dc653;--red:#e63946;--amber:#f4a261;--blue:#4cc9f0;--purple:#7b2d8b;--orange:#f77f00;--navbar-bg:#fff;--shadow:0 2px 8px #00000014}[data-theme=dark]{--bg:#0f0f1a;--bg-card:#1a1a2e;--bg-secondary:#16213e;--text:#e8e8f0;--text-secondary:#8892a4;--border:#2a2a4a;--accent:#4361ee;--navbar-bg:#1a1a2e;--shadow:0 2px 8px #0006}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,sans-serif;transition:background .2s,color .2s}.app{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--navbar-bg);border-bottom:1px solid var(--border);height:56px;box-shadow:var(--shadow);z-index:100;align-items:center;gap:8px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:8px;margin-right:24px;font-size:18px;font-weight:700;display:flex}.brand-icon{font-size:20px}.navbar-links{flex:1;gap:4px;display:flex}.nav-link{color:var(--text-secondary);border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:14px;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{background:var(--bg-secondary);color:var(--text)}.nav-link.active{background:var(--accent);color:#fff}.theme-toggle{border:1px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:8px;align-items:center;padding:6px 8px;display:flex}.main-content{width:100%;max-width:1400px;margin:0 auto;padding:24px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{font-size:24px;font-weight:600}.filters{gap:8px;display:flex}.filters select{border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;border-radius:8px;padding:6px 12px;font-size:14px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:20px}.kpi-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.kpi-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.kpi-icon{font-size:20px}.kpi-value{margin-bottom:4px;font-size:24px;font-weight:700}.kpi-subtitle{color:var(--text-secondary);font-size:12px}.kpi-green .kpi-value{color:var(--green)}.kpi-red .kpi-value{color:var(--red)}.kpi-blue .kpi-value{color:var(--blue)}.kpi-amber .kpi-value{color:var(--amber)}.kpi-purple .kpi-value{color:var(--purple)}.kpi-orange .kpi-value{color:var(--orange)}.chart-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:24px}.chart-card h2{margin-bottom:16px;font-size:16px}.totals-bar{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:8px;flex-wrap:wrap;gap:24px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.totals-bar strong{color:var(--text)}.table-container{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:10px 14px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);padding:10px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-secondary)}.num{text-align:right;font-variant-numeric:tabular-nums}.mono{font-family:monospace;font-size:12px}.concepto-cell{white-space:nowrap;text-overflow:ellipsis;max-width:250px;overflow:hidden}.empty-row{text-align:center;color:var(--text-secondary);padding:32px}.badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.badge-green{color:#155724;background:#d4edda}.badge-blue{color:#0c5460;background:#d1ecf1}.badge-amber{color:#856404;background:#fff3cd}.badge-red{color:#721c24;background:#f8d7da}.badge-gray{background:var(--bg-secondary);color:var(--text-secondary)}[data-theme=dark] .badge-green{color:#4caf50;background:#1a3a2a}[data-theme=dark] .badge-blue{color:#4cc9f0;background:#1a2a3a}[data-theme=dark] .badge-amber{color:#f4a261;background:#3a2a1a}[data-theme=dark] .badge-red{color:#e63946;background:#3a1a1a}.modelos-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;display:grid}.modelo-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.modelo-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:16px 20px;display:flex}.modelo-header h2{flex:1;font-size:16px}.modelo-periodo{color:var(--text-secondary);font-size:12px}.modelo-badge{background:var(--accent);color:#fff;border-radius:6px;padding:4px 10px;font-size:14px;font-weight:700}.modelo-badge-blue{background:#0ea5e9}.casillas{padding:8px 0}.casilla{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 20px;display:flex}.casilla:last-child{border-bottom:none}.casilla-total{background:var(--bg-secondary)}.casilla-num{background:var(--accent);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.casilla-label{flex:1;font-size:13px}.casilla-valor{font-variant-numeric:tabular-nums;font-size:15px;font-weight:600}.casilla-seccion{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-top:1px solid var(--border);margin-top:.25rem;padding:.75rem 0 .25rem;font-size:.7rem;font-weight:700}.casilla-seccion:first-child{border-top:none;padding-top:0}.text-red{color:var(--red)}.text-green{color:var(--green)}.loading,.empty{text-align:center;color:var(--text-secondary);padding:48px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);border-radius:16px;padding:40px}.login-brand{justify-content:center;align-items:center;gap:8px;margin-bottom:24px;font-size:22px;font-weight:700;display:flex}.login-title{text-align:center;color:var(--text-secondary);margin-bottom:24px;font-size:18px;font-weight:600}.login-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);font-size:13px;font-weight:500}.form-group input{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text);border-radius:8px;outline:none;padding:10px 14px;font-size:15px;transition:border-color .15s}.form-group input:focus{border-color:var(--accent)}.login-error{color:#721c24;background:#f8d7da;border-radius:8px;padding:10px 14px;font-size:13px}[data-theme=dark] .login-error{color:#e63946;background:#3a1a1a}.login-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:12px;font-size:15px;font-weight:500;transition:background .15s}.login-btn:hover{background:var(--accent-hover)}.login-btn:disabled{opacity:.6;cursor:not-allowed}
