:root {
    --primary: #0F172A;
    --secondary: #2563EB;
    --genz-bg: #eef2f8;
    --genz-surface: #ffffff;
    --genz-text: #0f172a;
    --genz-muted: #475569;
    --genz-border: #d8e2ef;
    --genz-mint: #00c9a7;
    --genz-blue: #3b82f6;
}

body {
    font-family: 'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
    color: var(--genz-text);
    line-height: 1.6;
}

.text-secondary-custom { color: var(--secondary) !important; }

.btn-secondary-custom {
    background-color: var(--secondary);
    border-color: var(--secondary);
    color: #fff;
}
.btn-secondary-custom:hover {
    background-color: #1d4ed8;
    border-color: #1d4ed8;
    color: #fff;
}

.site-nav {
    background: rgba(255, 255, 255, .88) !important;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(59, 130, 246, .14);
    box-shadow: 0 1px 0 rgba(59, 130, 246, .06), 0 8px 28px rgba(15, 23, 42, .07);
    padding: .65rem 0;
    min-height: 64px;
}
.site-nav .navbar-brand { padding: 0; margin-right: 1rem; }
.site-nav .nav-link {
    color: var(--genz-text) !important;
    font-weight: 600;
    font-size: .95rem;
    padding: .5rem .85rem !important;
    border-radius: 999px;
}
.site-nav .nav-link:hover {
    background: #f1f5f9;
    color: var(--genz-blue) !important;
}
.site-nav .navbar-toggler-icon { filter: invert(1) brightness(.2); }

.btn-genz-primary {
    background: linear-gradient(135deg, var(--genz-mint), #10b981);
    border: none;
    color: #fff;
    font-weight: 700;
    box-shadow: 0 4px 14px rgba(0, 201, 167, .35);
}
.btn-genz-primary:hover {
    background: linear-gradient(135deg, #00b894, #059669);
    color: #fff;
}

.site-logo { height: auto; display: block; object-fit: contain; }
.site-logo-nav {
    height: 56px;
    width: 240px;
    max-width: 260px;
    object-fit: contain;
    display: block;
}
@media (min-width: 992px) {
    .site-logo-nav { height: 62px; max-width: 300px; }
}
@media (max-width: 575px) {
    .site-logo-nav { height: 44px; width: 180px; max-width: 200px; }
}

.genz-section { padding: 2rem 0 4rem; background: var(--genz-bg); }
.genz-footer { background: var(--genz-text); color: #fff; }

.loan-calc-page { max-width: 1100px; margin: 0 auto; }
.loan-calc-hero { display: flex; align-items: center; gap: 1rem; }
.loan-calc-hero-icon {
    width: 52px; height: 52px; border-radius: 14px;
    background: linear-gradient(135deg, #d97706, #f59e0b);
    color: #fff; display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; flex-shrink: 0;
}
.loan-calc-hero-title { font-size: 1.35rem; font-weight: 800; color: #0f172a; }
.loan-calc-hero-sub { font-size: .9rem; color: #475569; margin-top: .15rem; }
.loan-stat-primary { background: linear-gradient(135deg, #1d4ed8, #2563eb); color: #fff; }
.loan-stat-primary .fs-3 { line-height: 1.2; }
.loan-schedule-table th, .loan-schedule-table td { font-size: .85rem; white-space: nowrap; }
.loan-money-input { font-variant-numeric: tabular-nums; }
#resMonthly, #resInterest, #resTotal, #resPrincipal { font-variant-numeric: tabular-nums; }
.loan-calc-public-section { padding-top: 2rem; padding-bottom: 4rem; min-height: 60vh; }
.loan-register-cta-inner {
    display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
    gap: 1rem; padding: 1.25rem 1.5rem; border-radius: 16px;
    background: linear-gradient(135deg, #1e3a8a, #2563eb); color: #fff;
}
.loan-sticky-cta {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 1040;
    padding: .75rem 0 calc(.75rem + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(135deg, #0f172a, #1e293b);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, .15);
}

.sr-only-focusable:not(:focus):not(:focus-within) {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
