*{box-sizing:border-box}:root{color-scheme:light;--bg: #f3f5f9;--surface: #ffffff;--surface-muted: #f8fafc;--text: #0f172a;--muted: #6b7280;--border: #e5e7eb;--accent: #2563eb;--accent-strong: #1d4ed8;--accent-soft: rgba(37, 99, 235, .12);--success: #16a34a;--success-soft: rgba(22, 163, 74, .15);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .18);--info: #2563eb;--info-soft: rgba(37, 99, 235, .15);--shadow: 0 12px 30px rgba(15, 23, 42, .08);--shadow-soft: 0 6px 18px rgba(15, 23, 42, .08);--radius: 16px;--sidebar-bg: linear-gradient(180deg, #0f172a, #1e293b);--sidebar-text: #f8fafc;--sidebar-muted: #94a3b8;--sidebar-active: rgba(37, 99, 235, .18);--table-head-bg: #f1f5f9;--table-row-alt: #fbfdff;--table-row-hover: #f1f5f9;--input-bg: #ffffff;--button-shadow: 0 10px 20px rgba(37, 99, 235, .2)}[data-theme=dark]{color-scheme:dark;--bg: #0b1120;--surface: #111827;--surface-muted: #0f172a;--text: #e5e7eb;--muted: #9ca3af;--border: rgba(148, 163, 184, .2);--accent: #60a5fa;--accent-strong: #3b82f6;--accent-soft: rgba(96, 165, 250, .2);--success: #22c55e;--success-soft: rgba(34, 197, 94, .2);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .22);--info: #60a5fa;--info-soft: rgba(96, 165, 250, .22);--shadow: 0 12px 30px rgba(0, 0, 0, .4);--shadow-soft: 0 6px 18px rgba(0, 0, 0, .35);--sidebar-bg: linear-gradient(180deg, #0b1120, #111827);--sidebar-text: #e5e7eb;--sidebar-muted: #94a3b8;--sidebar-active: rgba(96, 165, 250, .2);--table-head-bg: #0f172a;--table-row-alt: #0b1220;--table-row-hover: #111827;--input-bg: #0f172a;--button-shadow: 0 10px 20px rgba(59, 130, 246, .3)}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.page{max-width:1200px;margin:0 auto;padding:24px 24px 36px}.header{margin-bottom:20px;display:flex;flex-direction:column;gap:4px}.header h1{margin:0;font-size:24px;letter-spacing:-.01em}.header p{margin:0;color:var(--muted);font-size:13px}.section-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.header-actions{display:flex;justify-content:flex-end;margin-top:8px}.card{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px;transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.card h3{margin:0 0 8px;font-size:18px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.card-header h3{margin:0}.card-value{font-size:28px;font-weight:700}.card-subtitle{color:#6b7280}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh;background:var(--surface-muted)}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);padding:24px 16px;display:flex;flex-direction:column;gap:24px;border-right:1px solid rgba(148,163,184,.2);position:sticky;top:0;height:100vh}.brand h2{margin:0}.brand span{font-size:14px;color:var(--sidebar-muted)}.nav{display:flex;flex-direction:column;gap:8px}.nav a{color:var(--sidebar-text);text-decoration:none;padding:8px 12px;border-radius:8px;display:flex;align-items:center;gap:8px;transition:all .2s ease}.nav a span{flex:1}.nav a:hover{background:#94a3b81f;color:var(--sidebar-text)}.nav a.active{background:var(--sidebar-active);color:var(--sidebar-text);font-weight:600;box-shadow:inset 0 0 0 1px #60a5fa59}.nav-icon{width:16px;height:16px;opacity:.9}.nav a.active .nav-icon{opacity:1}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px}.user-meta span{display:block;font-size:13px}.user-meta small{color:#94a3b8}.content{padding:0 24px;background:var(--surface-muted)}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.form{display:grid;gap:16px}.form.two-columns{grid-template-columns:1fr 1fr;gap:.75rem .875rem}@media (max-width: 768px){.form.two-columns{grid-template-columns:1fr}}label{display:grid;gap:6px;font-size:13px;color:#374151;font-weight:600;min-width:0}input{padding:8px 10px;border-radius:6px;border:1px solid var(--border);font-size:13px;background:var(--input-bg);transition:border-color .2s ease,box-shadow .2s ease;width:100%;min-width:0}select{padding:8px 28px 8px 10px;border-radius:6px;border:1px solid var(--border);font-size:13px;background:var(--input-bg);transition:border-color .2s ease,box-shadow .2s ease;width:100%;max-width:100%;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}input:focus,select:focus,textarea:focus{outline:none;border-color:#2563eb99;box-shadow:0 0 0 3px #2563eb26}button{padding:9px 14px;border-radius:6px;border:none;background:var(--accent);color:#fff;font-weight:600;font-size:13px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:var(--button-shadow)}button.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:none}button:hover:not(:disabled){transform:translateY(-1px);background:var(--accent-strong)}button.secondary:hover:not(:disabled){background:#f8fafc;transform:translateY(-1px)}button:disabled{opacity:.7;cursor:not-allowed;box-shadow:none}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-spinner{display:inline-block;width:.75rem;height:.75rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite;vertical-align:middle;margin-right:.4rem}.error-message{display:block;min-height:.5rem;font-size:.75rem;color:#dc2626;margin-top:.125rem;line-height:.75rem}.error-message:empty{visibility:hidden}.message-container{min-height:2rem;margin-top:.5rem;display:flex;align-items:center}.message-container:empty{visibility:hidden}.success{color:#166534;padding:.5rem .75rem;background-color:#16a34a1a;border-radius:.375rem;border-left:3px solid var(--success)}.error{color:#b91c1c;padding:.5rem .75rem;background-color:#dc26261a;border-radius:.375rem;border-left:3px solid #dc2626}code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px}.table{width:100%;overflow-x:auto;border:1px solid var(--border);border-radius:14px;background:var(--surface)}table{width:100%;border-collapse:separate;border-spacing:0}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);font-size:14px}th{background:var(--table-head-bg);color:var(--text);font-weight:700}tbody tr:nth-child(2n){background:var(--table-row-alt)}tbody tr:hover{background:var(--table-row-hover)}.note{color:var(--muted);font-size:13px}.inline-actions{display:flex;gap:8px;flex-wrap:wrap}.link{color:var(--accent);text-decoration:none;font-weight:600}.link:hover{text-decoration:underline}.sparkline{width:120px;height:36px;flex-shrink:0}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize;border:1px solid transparent}.status-pill--neutral{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.status-pill--success{background:#dcfce7;color:#166534;border-color:#bbf7d0}.status-pill--warning{background:#fef3c7;color:#92400e;border-color:#fde68a}.status-pill--danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.status-pill--info{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.auth-page{max-width:520px;margin:0 auto;padding-top:96px}.auth-page .header{text-align:center}.theme-toggle{font-size:13px;padding:8px 12px;border-radius:999px}.dashboard-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--surface);border-radius:12px;padding:4px;box-shadow:var(--shadow-soft);border:1px solid var(--border)}.dashboard-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:10px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .25s ease}.dashboard-tab:hover{color:var(--text);background:var(--accent-soft)}.dashboard-tab--active{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;box-shadow:0 4px 12px #2563eb4d}[data-theme=dark] .dashboard-tab--active{box-shadow:0 4px 12px #60a5fa4d}.dashboard-content{animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-section-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}@media (max-width: 900px){.dashboard-section-row{grid-template-columns:1fr}}.dashboard-panel{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border)}.dashboard-panel h3{margin:0 0 12px;font-size:15px;font-weight:600;color:var(--text)}.dashboard-panel--wide{grid-column:1 / -1}.chart-container{width:100%;position:relative}.chart-container--pie{height:300px}.chart-container--bar{height:280px}.chart-container--line{height:320px}.nivo-tooltip{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;box-shadow:var(--shadow-soft)}.ledger-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;margin-bottom:16px}.ledger-badge--up{background:#16a34a1f;color:#16a34a;border:1px solid rgba(22,163,74,.25)}.ledger-badge--down{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.ledger-badge-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.ledger-badge--up .ledger-badge-dot{background:#16a34a;box-shadow:0 0 6px #16a34a80}.ledger-badge--down .ledger-badge-dot{background:#ef4444;box-shadow:0 0 6px #ef444480}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.quick-action-btn{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.quick-action-btn:hover{background:linear-gradient(135deg,var(--accent-soft),transparent);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb1f}.quick-action-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.activity-feed{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto}.activity-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--surface-muted);border:1px solid var(--border);transition:background .15s ease}.activity-item:hover{background:var(--accent-soft)}.activity-type-badge{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.activity-type-badge--payment{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}.activity-type-badge--audit{background:linear-gradient(135deg,#2563eb,#60a5fa);color:#fff}.activity-detail{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.activity-summary{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:11px;color:var(--muted)}.activity-amount{font-size:13px;font-weight:700;color:var(--success);white-space:nowrap}.muted-text{color:var(--muted);font-size:13px}.error-text{color:#ef4444;font-size:13px;grid-column:1 / -1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius);padding:24px;width:90%;max-width:520px;box-shadow:0 20px 60px #0003;border:1px solid var(--border);animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h2{margin:0;font-size:18px}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:0 4px;line-height:1}.modal-close:hover{color:var(--text)}.modal-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.loan-summary{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px}.loan-summary-header{margin-bottom:1.25rem}.loan-summary-borrower-row{display:flex;align-items:center;gap:.75rem;margin:.4rem 0 .15rem;flex-wrap:wrap}.loan-summary-borrower{font-size:.95rem;font-weight:500;color:var(--text)}.loan-summary-cedula{font-size:.8rem;font-weight:600;color:var(--muted);background:var(--surface-muted);border:1px solid var(--border);border-radius:6px;padding:.15rem .5rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.loan-summary-id{margin:0;font-size:.75rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;color:var(--muted)}.loan-summary-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding-top:1.25rem;border-top:1px solid var(--border)}.loan-summary-metric{display:flex;flex-direction:column;gap:.15rem}.loan-summary-metric-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.loan-summary-metric-value{font-size:1.35rem;font-weight:700;color:var(--text)}.loan-summary-metric-sub{font-size:.75rem;color:var(--muted)}.loan-summary-progress{display:flex;align-items:center;gap:.75rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.loan-summary-progress-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.loan-summary-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.loan-summary-progress-label{font-size:.78rem;font-weight:600;color:var(--muted);white-space:nowrap}@media (max-width: 768px){.loan-summary-metrics{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.loan-summary-metrics{grid-template-columns:1fr}}.ledger-banner{position:sticky;top:0;z-index:1000;background:#dc2626;color:#fff;text-align:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600}
