:root {
    --tenant-primary: #2B145A;
    --tenant-primary-dark: #240f4d;
    --tenant-accent: #0FA36B;
    --tenant-accent-dark: #0c8a5c;
    --tenant-bg: #f5f7fa;
    --tenant-surface: #ffffff;
    --tenant-border: #d8dee8;
    --tenant-text: #1f2937;
    --tenant-muted: #6b7280;
    --tenant-success: #047857;
    --tenant-warning: #b45309;
    --tenant-danger: #be123c;
}

* { box-sizing: border-box; font-family: 'Poppins', sans-serif; }
body { margin: 0; background: var(--tenant-bg); color: var(--tenant-text); }
.auth-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at top left, rgba(15,163,107,0.16), transparent 26%),
        radial-gradient(circle at bottom right, rgba(43,20,90,0.14), transparent 30%),
        linear-gradient(135deg, #fbfbfc 0%, #eef2f5 100%);
}
.page-shell { display: flex; min-height: 100vh; }
.sidebar-link {
    display: flex; align-items: center; gap: .75rem; border-radius: 1rem; padding: .85rem 1rem;
    color: rgba(255,255,255,.82); font-size: .95rem; transition: .2s ease;
    text-decoration: none;
}
.sidebar-link:hover, .sidebar-link.active { background: rgba(255,255,255,.08); color: #fff; }
.topbar {
    position: sticky; top: 0; z-index: 20; border-bottom: 1px solid var(--tenant-border);
    background: rgba(255,255,255,.92); backdrop-filter: blur(10px);
}
.stat-card, .panel, .metric-card {
    background: var(--tenant-surface); border: 1px solid var(--tenant-border);
    box-shadow: 0 12px 32px rgba(22, 31, 45, 0.06);
}
.stat-card, .metric-card { border-radius: 1.5rem; padding: 1.25rem; }
.panel { border-radius: 1.5rem; }
.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; min-width: 760px; }
.data-table thead th {
    padding-bottom: .9rem; text-align: left; font-size: .85rem; font-weight: 600;
    color: var(--tenant-muted); border-bottom: 1px solid var(--tenant-border);
}
.data-table tbody td {
    padding: 1rem 0; font-size: .92rem; color: var(--tenant-text);
    border-bottom: 1px solid #edf2f7; vertical-align: top;
}
.badge { display: inline-flex; align-items: center; border-radius: 999px; padding: .35rem .75rem; font-size: .75rem; font-weight: 600; }
.badge-success { background: #ecfdf5; color: #047857; }
.badge-warning { background: #fff4df; color: #b45309; }
.badge-info { background: #f3ecff; color: var(--tenant-primary); }
.badge-danger { background: #fff1f2; color: #be123c; }
.badge-slate { background: #f1f5f9; color: #334155; }
.btn-primary, .btn-secondary, .btn-soft {
    display: inline-flex; align-items: center; justify-content: center; border-radius: 1rem;
    padding: .85rem 1.1rem; font-size: .92rem; font-weight: 600; transition: .2s ease;
    text-decoration: none; border: 0; cursor: pointer;
}
.btn-primary { background: var(--tenant-accent); color: white; }
.btn-primary:hover { background: var(--tenant-accent-dark); }
.btn-secondary { background: var(--tenant-surface); color: var(--tenant-text); border: 1px solid var(--tenant-border); }
.btn-secondary:hover { background: #f8fafc; }
.btn-soft { background: rgba(43,20,90,0.08); color: var(--tenant-primary); }
.btn-soft:hover { background: rgba(43,20,90,0.14); }
.form-input, .form-select, .form-textarea {
    width: 100%; border-radius: 1rem; border: 1px solid var(--tenant-border); background: #fff;
    padding: .9rem 1rem; outline: none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    border-color: var(--tenant-accent); box-shadow: 0 0 0 4px rgba(15,163,107,0.12);
}
.kpi-bar span { display: block; border-radius: 999px; height: .65rem; background: linear-gradient(90deg, var(--tenant-accent) 0%, var(--tenant-primary) 100%); }
.brand-logo { width: auto; object-fit: contain; }
.tenant-hero {
    background: linear-gradient(135deg, rgba(43,20,90,0.98) 0%, rgba(36,15,77,0.96) 58%, rgba(15,163,107,0.94) 100%);
    color: white; border-radius: 2rem; overflow: hidden;
}
.tenant-hero::after {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(circle at top right, rgba(255,255,255,0.12), transparent 28%), radial-gradient(circle at bottom left, rgba(255,255,255,0.08), transparent 30%);
    pointer-events: none;
}
.chart-bars { display: grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: .6rem; align-items: end; height: 180px; }
.chart-bars span { display: block; border-radius: .9rem .9rem .3rem .3rem; background: linear-gradient(180deg, rgba(15,163,107,0.95), rgba(43,20,90,0.95)); }
.workflow-step { border: 1px solid var(--tenant-border); border-radius: 1.25rem; padding: 1rem; background: #fff; }
.risk-dot { width: .6rem; height: .6rem; border-radius: 999px; display: inline-block; }
.progress-track { height: .55rem; border-radius: 999px; overflow: hidden; background: #ecf0f4; }
.progress-track > span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--tenant-accent), var(--tenant-primary)); }
.info-list { display: grid; gap: 1rem; }
.info-row { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; padding-bottom:1rem; border-bottom:1px solid #edf2f7; }
.info-row:last-child { border-bottom:0; padding-bottom:0; }
.section-title { color: var(--tenant-primary); font-weight: 700; font-size: 1.05rem; }
.page-grid { display:grid; gap:1.5rem; }
@media (min-width:1280px){ .page-grid-2{grid-template-columns:1.2fr .8fr;} .page-grid-3{grid-template-columns:1.1fr 1.1fr .8fr;} }

.sidebar-icon { width: 1.1rem; height: 1.1rem; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 1.1rem; }
.sidebar-icon svg { width: 100%; height: 100%; }


.step-chip { display:flex; align-items:center; gap:.75rem; border-radius:999px; padding:.7rem 1rem; border:1px solid var(--tenant-border); background:#fff; }
.step-chip span { display:inline-flex; width:2rem; height:2rem; align-items:center; justify-content:center; border-radius:999px; font-size:.8rem; font-weight:700; background:#eef2f7; color:var(--tenant-primary); }
.step-chip strong { font-size:.9rem; }
.step-chip.current { border-color: rgba(15,163,107,0.35); background: rgba(15,163,107,0.08); }
.step-chip.current span { background: var(--tenant-accent); color:#fff; }
.step-chip.complete { border-color: rgba(15,163,107,0.3); background:#ecfdf5; }
.step-chip.complete span { background: var(--tenant-success); color:#fff; }
.upload-card, .review-item { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; padding:1rem 1.1rem; border:1px solid var(--tenant-border); border-radius:1.25rem; background:#fff; }
.journey-card { display:flex; gap:1rem; padding:1rem 1.1rem; border-radius:1.25rem; background: rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); }
.journey-card span { width:2rem; height:2rem; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; font-size:.8rem; font-weight:700; background: rgba(255,255,255,0.14); }
.journey-card strong { display:block; }
.journey-card p { margin:.2rem 0 0; font-size:.92rem; color: rgba(255,255,255,0.72); }
.journey-card.current { background: rgba(255,255,255,0.14); }

:root {
    --borrower-primary: #2B145A;
    --borrower-primary-dark: #240f4d;
    --borrower-accent: #0FA36B;
    --borrower-accent-dark: #0c8a5c;
    --borrower-bg: #f5f7fa;
    --borrower-surface: #ffffff;
    --borrower-border: #d8dee8;
    --borrower-text: #1f2937;
    --borrower-muted: #6b7280;
    --borrower-success: #047857;
    --borrower-warning: #b45309;
    --borrower-danger: #be123c;
    --borrower-info: #4338ca;
}
* { box-sizing: border-box; font-family: 'Poppins', sans-serif; }
body { margin: 0; background: var(--borrower-bg); color: var(--borrower-text); }
a { color: inherit; }
.auth-shell {
    min-height: 100vh;
    background:
      radial-gradient(circle at top left, rgba(15,163,107,0.16), transparent 26%),
      radial-gradient(circle at bottom right, rgba(43,20,90,0.14), transparent 30%),
      linear-gradient(135deg, #fbfbfc 0%, #eef2f5 100%);
}
.page-shell { display:flex; min-height:100vh; }
.borrower-sidebar {
    width: 288px; min-height:100vh; background: var(--borrower-primary); color:white;
}
.sidebar-link { display:flex; align-items:center; gap:.75rem; border-radius:1rem; padding:.85rem 1rem; color:rgba(255,255,255,.82); text-decoration:none; transition:.2s ease; }
.sidebar-link:hover, .sidebar-link.active { background: rgba(255,255,255,.08); color:#fff; }
.sidebar-icon { width:1.1rem; height:1.1rem; display:inline-flex; }
.sidebar-icon svg { width:100%; height:100%; }
.topbar { position:sticky; top:0; z-index:20; border-bottom:1px solid var(--borrower-border); background:rgba(255,255,255,.92); backdrop-filter:blur(10px); }
.panel, .metric-card, .info-card { background:var(--borrower-surface); border:1px solid var(--borrower-border); box-shadow:0 12px 32px rgba(22,31,45,.06); border-radius:1.5rem; }
.panel { padding:1.5rem; }
.metric-card, .info-card { padding:1.25rem; }
.hero-card {
    background: linear-gradient(135deg, rgba(43,20,90,0.98) 0%, rgba(36,15,77,0.96) 56%, rgba(15,163,107,0.94) 100%);
    color:#fff; border-radius:2rem; overflow:hidden; position:relative;
}
.hero-card::after { content:''; position:absolute; inset:0; background:radial-gradient(circle at top right, rgba(255,255,255,0.12), transparent 28%); pointer-events:none; }
.btn-primary, .btn-secondary, .btn-soft, .btn-danger {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem; border-radius:1rem; padding:.85rem 1.1rem; font-size:.92rem; font-weight:600; text-decoration:none; border:0; cursor:pointer; transition:.2s ease;
}
.btn-primary { background:var(--borrower-accent); color:#fff; }
.btn-primary:hover { background:var(--borrower-accent-dark); }
.btn-secondary { background:#fff; color:var(--borrower-text); border:1px solid var(--borrower-border); }
.btn-soft { background:rgba(43,20,90,0.08); color:var(--borrower-primary); }
.btn-danger { background:#fff1f2; color:var(--borrower-danger); border:1px solid #fecdd3; }
.badge { display:inline-flex; align-items:center; border-radius:999px; padding:.35rem .75rem; font-size:.75rem; font-weight:600; }
.badge-success { background:#ecfdf5; color:#047857; }
.badge-warning { background:#fff4df; color:#b45309; }
.badge-info { background:#f3ecff; color:var(--borrower-primary); }
.badge-danger { background:#fff1f2; color:#be123c; }
.form-input,.form-select,.form-textarea,.form-file { width:100%; border-radius:1rem; border:1px solid var(--borrower-border); background:#fff; padding:.9rem 1rem; outline:none; }
.form-file { padding:.8rem 1rem; }
.form-input:focus,.form-select:focus,.form-textarea:focus,.form-file:focus { border-color:var(--borrower-accent); box-shadow:0 0 0 4px rgba(15,163,107,0.12); }
.form-label { display:block; font-size:.85rem; font-weight:600; color:var(--borrower-text); margin-bottom:.45rem; }
.data-table { width:100%; border-collapse:collapse; min-width:760px; }
.data-table thead th { padding-bottom:.9rem; text-align:left; font-size:.85rem; font-weight:600; color:var(--borrower-muted); border-bottom:1px solid var(--borrower-border); }
.data-table tbody td { padding:1rem 0; font-size:.92rem; color:var(--borrower-text); border-bottom:1px solid #edf2f7; vertical-align:top; }
.progress-track { height:.55rem; border-radius:999px; overflow:hidden; background:#ecf0f4; }
.progress-track > span { display:block; height:100%; border-radius:inherit; background:linear-gradient(90deg,var(--borrower-accent),var(--borrower-primary)); }
.section-title { color: var(--borrower-primary); font-weight:700; font-size:1.05rem; }
.auth-card { width:min(520px,100%); background:#fff; border:1px solid var(--borrower-border); box-shadow:0 18px 48px rgba(22,31,45,.08); border-radius:2rem; padding:2rem; }
.kpi-grid { display:grid; gap:1rem; }
.onboarding-step { display:flex; align-items:flex-start; gap:1rem; }
.step-dot { width:2.25rem; height:2.25rem; display:flex; align-items:center; justify-content:center; border-radius:999px; font-weight:700; }
.step-dot.active { background:var(--borrower-accent); color:#fff; }
.step-dot.done { background:rgba(15,163,107,.16); color:var(--borrower-success); }
.step-dot.todo { background:#e5e7eb; color:#6b7280; }
.status-card { border-left:4px solid var(--borrower-accent); }
.small-muted { font-size:.82rem; color:var(--borrower-muted); }
@media (max-width: 1024px) {
  .borrower-sidebar { display:none; }
}
.alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;border:1px solid transparent;font-weight:600;box-shadow:0 12px 30px rgba(15,23,42,.08)}
.alert-success{background:#ecfdf3;color:#027a48;border-color:#abefc6}
.alert-danger{background:#fef3f2;color:#b42318;border-color:#fecdca}
.alert-warning{background:#fffaeb;color:#b54708;border-color:#fedf89}
.alert-info{background:#eff8ff;color:#175cd3;border-color:#b2ddff}
