/**
 * 贷前专业版 · 国际金融风控向界面（结果页 / demo 共用）
 */
:root {
    --fi-bg0: #dce3ee;
    --fi-bg1: #eef2f8;
    --fi-surface: #ffffff;
    --fi-surface-muted: #f4f6fa;
    --fi-ink: #0f172a;
    --fi-ink-soft: #334155;
    --fi-muted: #64748b;
    --fi-border: rgba(15, 23, 42, 0.085);
    --fi-navy: #0f172a;
    --fi-navy-mid: #1e293b;
    --fi-accent: #1e3a8a;
    --fi-accent-hover: #1d4ed8;
    --fi-line: #0ea5e9;
    --fi-positive: #0f766e;
    --fi-negative: #9f1239;
    --fi-warn: #b45309;
    --fi-gold: rgba(199, 168, 90, 0.65);
    --fi-radius: 10px;
    --fi-radius-sm: 6px;
    --fi-shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 8px 24px rgba(15, 23, 42, 0.06);
    --fi-font: system-ui, -apple-system, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
    --fi-mono: ui-monospace, "Cascadia Code", "SF Mono", Menlo, monospace;
}

body.preloan-report--fi {
    font-family: var(--fi-font);
    color: var(--fi-ink);
    letter-spacing: 0.015em;
    background: linear-gradient(165deg, var(--fi-bg0) 0%, var(--fi-bg1) 42%, #f8fafc 100%);
    min-height: 100vh;
}

body.preloan-report--fi .container.mt-4 {
    max-width: 1080px;
}

/* —— 顶栏 —— */
.navbar.navbar-preloan {
    background: linear-gradient(102deg, #0b1220 0%, var(--fi-navy-mid) 52%, #172554 100%) !important;
    border-bottom: 2px solid var(--fi-gold);
    box-shadow: 0 4px 30px rgba(2, 6, 23, 0.45);
    padding-top: 0.55rem;
    padding-bottom: 0.55rem;
}

.navbar.navbar-preloan .navbar-brand {
    color: #f8fafc !important;
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.06em;
}

.navbar.navbar-preloan .navbar-brand i {
    color: var(--fi-line);
    margin-right: 0.4rem;
    opacity: 0.95;
}

.navbar.navbar-preloan .btn-outline-light {
    border-color: rgba(248, 250, 252, 0.35);
    color: #e2e8f0;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.35rem 0.85rem;
    border-radius: var(--fi-radius-sm);
}

.navbar.navbar-preloan .btn-outline-light:hover {
    background: rgba(255, 255, 255, 0.09);
    border-color: rgba(248, 250, 252, 0.55);
    color: #fff;
}

/* —— 目录锚点 —— */
.preloan-report--fi .sticky-top-custom {
    position: sticky;
    top: 56px;
    z-index: 1019;
    background: rgba(252, 253, 255, 0.88);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid var(--fi-border);
    border-radius: var(--fi-radius);
    padding: 10px 12px 12px;
    margin-bottom: 1.25rem;
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.05);
}

.preloan-report--fi .nav-tabs-custom {
    border-bottom: none;
    gap: 6px;
    justify-content: flex-start;
}

.preloan-report--fi .nav-tabs-custom .nav-link {
    border: 1px solid transparent;
    border-radius: var(--fi-radius-sm);
    padding: 6px 12px;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--fi-muted);
    background: transparent;
}

.preloan-report--fi .nav-tabs-custom .nav-link:hover {
    color: var(--fi-accent);
    background: rgba(30, 58, 138, 0.07);
    border-color: rgba(30, 58, 138, 0.12);
}

.preloan-report--fi .nav-tabs-custom .nav-link.active {
    background: linear-gradient(135deg, var(--fi-accent) 0%, #2563eb 100%);
    color: #fff !important;
    border-color: rgba(56, 189, 248, 0.35);
    box-shadow: 0 3px 12px rgba(30, 58, 138, 0.28);
}

/* —— 卡片 —— */
.preloan-report--fi .report-card {
    background: var(--fi-surface);
    border: 1px solid var(--fi-border);
    border-radius: var(--fi-radius);
    box-shadow: var(--fi-shadow);
    padding: 1.35rem 1.45rem;
    margin-bottom: 1.15rem;
    scroll-margin-top: 92px;
}

.preloan-report--fi .report-card > h5:first-child {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--fi-accent);
    margin-bottom: 1.1rem;
    padding-bottom: 0.65rem;
    border-bottom: 1px solid var(--fi-border);
}

.preloan-report--fi .report-card .text-muted,
.preloan-report--fi .report-card small.text-muted {
    color: var(--fi-muted) !important;
}

/* —— 评分环 —— */
.preloan-report--fi .risk-score {
    width: 104px;
    height: 104px;
    border-radius: 50%;
    border: none;
    box-shadow: inset 0 0 0 1px var(--fi-border);
}

.preloan-report--fi .risk-score span {
    font-family: var(--fi-mono);
    font-weight: 700;
    font-size: 1.65rem;
    color: var(--fi-ink);
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}

/* —— 命中状态 —— */
.preloan-report--fi .hit-yes {
    color: var(--fi-negative) !important;
    font-weight: 700;
}

.preloan-report--fi .hit-no {
    color: var(--fi-positive) !important;
    font-weight: 700;
}

.preloan-report--fi .hit-medium {
    color: var(--fi-warn) !important;
    font-weight: 700;
}

.preloan-report--fi .stat-number {
    font-family: var(--fi-mono);
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    color: var(--fi-ink);
}

/* —— 区块标题 —— */
.preloan-report--fi .stats-group {
    background: var(--fi-surface-muted);
    border: 1px solid var(--fi-border);
    border-radius: var(--fi-radius-sm);
    padding: 14px 16px;
    margin-bottom: 14px;
}

.preloan-report--fi .stats-title {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--fi-ink-soft);
    border-left: 3px solid var(--fi-line);
    padding-left: 10px;
    margin-bottom: 12px;
}

.preloan-report--fi .progress-bar-custom {
    height: 6px;
    background: #e2e8f0;
    border-radius: 3px;
}

.preloan-report--fi .progress-fill {
    background: linear-gradient(90deg, var(--fi-accent), var(--fi-line));
    border-radius: 3px;
}

.preloan-report--fi .case-item {
    border-left: 3px solid var(--fi-accent);
    padding-left: 14px;
}

.preloan-report--fi .detail-toggle {
    color: var(--fi-accent-hover);
    font-weight: 600;
    font-size: 0.8rem;
}

.preloan-report--fi .detail-content {
    background: #fff;
    border: 1px solid var(--fi-border);
    border-radius: var(--fi-radius-sm);
}

.preloan-report--fi .danger-box {
    background: rgba(159, 18, 57, 0.06);
    border-left: 3px solid var(--fi-negative);
    border-radius: var(--fi-radius-sm);
    color: var(--fi-ink-soft);
}

.preloan-report--fi .warning-box {
    background: rgba(180, 83, 9, 0.07);
    border-left: 3px solid var(--fi-warn);
    border-radius: var(--fi-radius-sm);
    color: var(--fi-ink-soft);
}

/* —— Bootstrap 组件在金融主题下的柔化 —— */
.preloan-report--fi .alert {
    border-radius: var(--fi-radius-sm);
    border: 1px solid var(--fi-border);
    font-size: 0.8125rem;
}

.preloan-report--fi .alert-secondary {
    background: var(--fi-surface-muted);
    color: var(--fi-ink-soft);
}

.preloan-report--fi .alert-success {
    background: rgba(15, 118, 110, 0.08);
    border-color: rgba(15, 118, 110, 0.22);
    color: #115e59;
}

.preloan-report--fi .alert-danger {
    background: rgba(159, 18, 57, 0.06);
    border-color: rgba(159, 18, 57, 0.22);
    color: #881337;
}

.preloan-report--fi .alert-warning {
    background: rgba(180, 83, 9, 0.07);
    border-color: rgba(180, 83, 9, 0.22);
    color: #92400e;
}

.preloan-report--fi .alert-info {
    background: rgba(14, 165, 233, 0.08);
    border-color: rgba(14, 165, 233, 0.2);
    color: var(--fi-navy-mid);
}

.preloan-report--fi .alert-light {
    background: #fafbfc;
    color: var(--fi-muted);
}

.preloan-report--fi .badge.bg-secondary {
    background: #475569 !important;
    font-weight: 600;
}

.preloan-report--fi .badge.bg-info {
    background: #0e7490 !important;
}

.preloan-report--fi .list-group-item {
    border-color: var(--fi-border);
}

/* —— 表格（数据中心感） —— */
.preloan-report--fi .report-card .table {
    font-size: 0.8125rem;
    margin-bottom: 0;
}

.preloan-report--fi .report-card .table thead th {
    background: var(--fi-navy-mid);
    color: #f1f5f9;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    border: none;
    padding: 0.55rem 0.65rem;
    white-space: nowrap;
}

.preloan-report--fi .report-card .table tbody td {
    font-variant-numeric: tabular-nums;
    vertical-align: middle;
    border-color: var(--fi-border);
    padding: 0.5rem 0.65rem;
}

.preloan-report--fi .report-card .table-bordered {
    border: 1px solid var(--fi-border);
}

.preloan-report--fi .report-card .table tbody tr:nth-child(even) {
    background: rgba(248, 250, 252, 0.85);
}

.preloan-report--fi .report-card code {
    font-family: var(--fi-mono);
    font-size: 0.76em;
    color: var(--fi-accent);
    background: rgba(30, 58, 138, 0.06);
    padding: 0.1rem 0.35rem;
    border-radius: 4px;
}

/* —— Demo 顶部说明 —— */
.preloan-report--fi .preloan-disclaimer {
    background: rgba(30, 58, 138, 0.06);
    border: 1px solid rgba(30, 58, 138, 0.14);
    border-radius: var(--fi-radius-sm);
    color: var(--fi-ink-soft);
    font-size: 0.8rem;
}

/* —— 页脚 —— */
.preloan-report--fi footer.footer {
    background: var(--fi-navy) !important;
    color: #94a3b8 !important;
    border-top: 1px solid rgba(248, 250, 252, 0.08) !important;
    font-size: 0.75rem;
    letter-spacing: 0.04em;
}

.preloan-report--fi .table-warning {
    --bs-table-bg: rgba(217, 119, 6, 0.12);
    color: var(--fi-ink-soft);
}

@media (max-width: 768px) {
    .preloan-report--fi .risk-score {
        width: 82px;
        height: 82px;
    }
    .preloan-report--fi .risk-score span {
        width: 64px;
        height: 64px;
        font-size: 1.25rem;
    }
    .preloan-report--fi .nav-tabs-custom .nav-link {
        padding: 5px 9px;
        font-size: 0.62rem;
    }
}
