/* ==================================================================
   cashflow-pages.css — Page-Level Styles
   Consolidated: cashflow-suite + cashflow-hub-modern
================================================================== */

/* ── cashflow-suite.css ── */
/* ============================================================================
   DRM CashFlow Suite - final cockpit layer
   Loaded after older cash-flow styles to align the module with the target UI.
   ============================================================================ */

:root {
    --cfs-bg: #f6f9fe;
    --cfs-surface: #ffffff;
    --cfs-soft: #f8fbff;
    --cfs-border: #dfe8f5;
    --cfs-border-strong: #c7d7ee;
    --cfs-text: #10213f;
    --cfs-muted: #64748b;
    --cfs-blue: #1268f3;
    --cfs-blue-2: #0ea5e9;
    --cfs-cyan: #06b6d4;
    --cfs-green: #10b981;
    --cfs-red: #ef4444;
    --cfs-amber: #f59e0b;
    --cfs-purple: #7c3aed;
    --cfs-shadow: 0 10px 28px rgba(15, 35, 70, 0.08);
    --cfs-shadow-sm: 0 4px 14px rgba(15, 35, 70, 0.06);
}

.cf-hub,
.cf-page,
.cf-exec-dashboard,
.cf-forecast-page,
.cf-liquidity-page,
.cf-accuracy-page,
.cf-wc-page,
.cf-memo-page,
.cf-alert-page,
.cf-rule-page,
.cf-pooling-page,
.cf-recon-page,
.cf-audit-page,
.cp-root,
.bcr-page,
.studio-container {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(246, 249, 254, 0.96)),
        radial-gradient(circle at 82% 4%, rgba(18, 104, 243, 0.10), transparent 32%),
        var(--cfs-bg) !important;
    color: var(--cfs-text) !important;
    font-family: Inter, "Segoe UI", system-ui, sans-serif !important;
    padding: clamp(14px, 1.45vw, 22px) !important;
    min-height: calc(100vh - 64px) !important;
}

.cf-page-header,
.cp-header,
.bcr-header,
.studio-header {
    background: rgba(255, 255, 255, 0.92) !important;
    border: 1px solid var(--cfs-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--cfs-shadow-sm) !important;
    color: var(--cfs-text) !important;
    padding: 14px 16px !important;
    margin-bottom: 14px !important;
}

.cf-page-header::after,
.studio-header::after,
.cfm-header::after {
    display: none !important;
}

.cf-page-header h1,
.cf-brand-text h1,
.cp-title,
.bcr-title h1,
.studio-title {
    color: var(--cfs-text) !important;
    font-size: clamp(1.08rem, 1.45vw, 1.45rem) !important;
    line-height: 1.18 !important;
    letter-spacing: 0 !important;
}

.cf-brand-text p,
.cp-subtitle,
.bcr-title p,
.studio-subtitle,
.cf-page-subtitle {
    color: var(--cfs-muted) !important;
    opacity: 1 !important;
    font-size: 0.82rem !important;
}

.cf-brand-icon,
.cp-kpi-icon,
.bcr-icon,
.kpi-icon,
.cf-kpi-icon-circle {
    background: linear-gradient(135deg, var(--cfs-blue), var(--cfs-cyan)) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px rgba(18, 104, 243, 0.22) !important;
}

.cf-filter-bar,
.bcr-filters,
.cf-card,
.cf-panel,
.cp-section,
.bcr-section,
.bcr-chart-card,
.chart-card,
.cards-section {
    background: rgba(255, 255, 255, 0.94) !important;
    border: 1px solid var(--cfs-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--cfs-shadow-sm) !important;
}

.cf-filter-bar,
.bcr-filters {
    padding: 12px 14px !important;
    gap: 10px !important;
}

.cf-filter-group label,
.bcr-fg label {
    color: #52647d !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.035em !important;
}

.cfm-btn,
.cf-btn,
.cp-refresh-btn,
.bcr-btn,
.btn-studio-action,
.btn-new-scenario {
    border-radius: 8px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    min-height: 34px !important;
}

.cfm-btn-primary,
.cf-btn-primary,
.cp-refresh-btn,
.bcr-btn.primary,
.btn-new-scenario {
    background: linear-gradient(135deg, var(--cfs-blue), #0758d8) !important;
    border-color: transparent !important;
    color: #ffffff !important;
    box-shadow: 0 8px 18px rgba(18, 104, 243, 0.22) !important;
}

.cfm-btn-ghost,
.cf-btn-secondary,
.bcr-btn.ghost,
.btn-studio-action {
    background: #ffffff !important;
    border: 1px solid var(--cfs-border) !important;
    color: #334155 !important;
}

.cfm-btn:hover,
.cf-btn:hover,
.cp-refresh-btn:hover,
.bcr-btn:hover,
.btn-studio-action:hover,
.btn-new-scenario:hover {
    transform: translateY(-1px) !important;
    box-shadow: var(--cfs-shadow-sm) !important;
}

.cf-kpi-grid,
.studio-kpi-row,
.bcr-kpis,
.cp-kpi-grid,
.cf-pool-overview {
    gap: 10px !important;
    margin-bottom: 14px !important;
}

.cf-kpi-card,
.studio-kpi-card,
.bcr-kpi,
.cp-kpi-card,
.cf-pool-kpi,
.cf-stat-card {
    background: var(--cfs-surface) !important;
    border: 1px solid var(--cfs-border) !important;
    border-radius: 12px !important;
    box-shadow: var(--cfs-shadow-sm) !important;
    min-height: 92px !important;
}

.cf-kpi-card:hover,
.studio-kpi-card:hover,
.bcr-kpi:hover,
.cp-kpi-card:hover,
.cf-pool-kpi:hover,
.cf-stat-card:hover {
    transform: translateY(-1px) !important;
    box-shadow: var(--cfs-shadow) !important;
}

.cf-kpi-label,
.kpi-label,
.bcr-kpi .lbl,
.cp-kpi-label,
.cf-pool-kpi-label,
.cf-stat-label {
    color: #60738d !important;
    font-size: 0.70rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.035em !important;
}

.cf-kpi-value,
.kpi-value,
.kpi-value-sm,
.bcr-kpi .val,
.cp-kpi-value,
.cf-pool-kpi-value,
.cf-stat-value {
    color: var(--cfs-text) !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
}

.cf-positive,
.pos,
.cp-positive,
.text-success,
.cf-text-success {
    color: var(--cfs-green) !important;
}

.cf-negative,
.neg,
.cp-negative,
.text-danger,
.cf-text-danger {
    color: var(--cfs-red) !important;
}

.cf-panel-header,
.cf-card-header,
.chart-header,
.section-header {
    background: transparent !important;
    border-bottom: 1px solid #edf2fa !important;
    padding-bottom: 10px !important;
    margin-bottom: 12px !important;
}

.cf-panel-header h3,
.cf-card-title,
.cp-section-title,
.bcr-section h2,
.chart-header h3,
.section-header h3 {
    color: #17335f !important;
    font-size: 0.96rem !important;
    font-weight: 850 !important;
}

.cf-two-col,
.cf-grid-2,
.cp-flows-grid,
.bcr-charts {
    display: grid !important;
    grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.75fr) !important;
    gap: 12px !important;
}

.cf-three-col,
.cf-command-deck {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.cf-table,
.bcr-matrix,
.comparison-table {
    font-size: 0.78rem !important;
}

.cf-table thead th,
.bcr-matrix th,
.comparison-table th,
.e-grid .e-headercell {
    background: #f3f7fd !important;
    color: #52647d !important;
    font-size: 0.68rem !important;
    font-weight: 850 !important;
    letter-spacing: 0.03em !important;
}

.cf-chart-area,
.chart-card [id$="chart"],
.cf-card-body > [id$="Chart"],
.bcr-chart-card .echarts-for-react,
.bcr-chart-card > div:not(.bcr-chart-title) {
    min-width: 0 !important;
}

.cf-hub .cf-header {
    background: linear-gradient(125deg, #0b6ff3 0%, #08bde8 68%, #67e8f9 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.44) !important;
    border-radius: 12px !important;
    min-height: 116px !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: 0 16px 32px rgba(18, 104, 243, 0.16) !important;
}

.cf-hub .cf-header::before {
    content: "";
    position: absolute;
    right: 4%;
    bottom: -16px;
    width: 230px;
    height: 126px;
    background:
        linear-gradient(90deg, rgba(255,255,255,0.20) 1px, transparent 1px) 0 0 / 28px 100%,
        linear-gradient(180deg, rgba(255,255,255,0.22) 1px, transparent 1px) 0 0 / 100% 18px,
        rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.24);
    border-radius: 8px 8px 0 0;
    transform: skewX(-10deg);
    pointer-events: none;
}

.cf-hub .cf-title-block h1,
.cf-hub .cf-title-block p,
.cf-hub .cf-kpi .lbl,
.cf-hub .cf-kpi .val {
    color: #ffffff !important;
}

.cf-hub .cf-kpi {
    background: rgba(255,255,255,0.18) !important;
    border-color: rgba(255,255,255,0.28) !important;
    backdrop-filter: blur(10px);
}

.cf-hub .cf-body {
    grid-template-columns: minmax(0, 1fr) 330px !important;
    gap: 12px !important;
}

.cf-hub .cf-group,
.cf-hub .cf-card {
    border-radius: 12px !important;
    box-shadow: var(--cfs-shadow-sm) !important;
}

.cf-hub .cf-tiles {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
}

.cf-hub .cf-tile {
    background: #ffffff !important;
    border: 1px solid var(--cfs-border) !important;
    border-radius: 10px !important;
    min-height: 74px !important;
}

.cf-hub .cf-tile:hover {
    border-color: #9dc2ff !important;
    box-shadow: 0 10px 24px rgba(18,104,243,.12) !important;
}

.cf-alert-item,
.cf-priority-card,
.cp-flow-item,
.cp-memo-item,
.month-card,
.cf-risk-item,
.cf-focus-item {
    border-radius: 10px !important;
    border: 1px solid #e7eef8 !important;
    background: #ffffff !important;
}

.cf-badge,
.cf-status-badge,
.cp-badge,
.bcr-code,
.cf-probability {
    border-radius: 999px !important;
    font-weight: 800 !important;
}

.cf-badge-success,
.cf-badge.success,
.cf-status.success,
.cp-badge-success {
    background: #dcfce7 !important;
    color: #047857 !important;
}

.cf-badge-danger,
.cf-badge.danger,
.cf-status.danger,
.cp-badge-danger {
    background: #fee2e2 !important;
    color: #dc2626 !important;
}

.cf-badge-warning,
.cf-badge.warning,
.cf-status.warning {
    background: #fef3c7 !important;
    color: #b45309 !important;
}

.cf-badge-info,
.cf-badge.info,
.cf-status.info {
    background: #dbeafe !important;
    color: #1d4ed8 !important;
}

@media (max-width: 1180px) {
    .cf-two-col,
    .cf-grid-2,
    .cp-flows-grid,
    .bcr-charts,
    .cf-three-col,
    .cf-command-deck,
    .cf-hub .cf-body {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 720px) {
    .cf-page-header,
    .cp-header,
    .bcr-header,
    .studio-header {
        align-items: stretch !important;
    }

    .cf-header-actions,
    .cp-header-right,
    .bcr-actions,
    .header-actions {
        width: 100% !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        padding-bottom: 2px !important;
    }

    .cf-hub .cf-header::before {
        opacity: 0.35 !important;
        right: -18% !important;
    }
}

/* Cash Flow content-structure upgrades. These rules intentionally avoid the
   app shell, sidebar, nav menu, and page background colors. */
.cf-pooling-page .cf-filter-bar {
    margin-bottom: 14px !important;
}

.cf-pooling-page .cf-pool-overview {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.cf-pooling-page .cf-pool-kpi {
    text-align: left !important;
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    grid-template-areas: "icon value" "icon label" !important;
    align-items: center !important;
    gap: 2px 12px !important;
}

.cf-pool-kpi-icon {
    grid-area: icon;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    box-shadow: 0 10px 20px rgba(15, 35, 70, 0.12);
}

.cf-pooling-page .cf-pool-kpi-value {
    grid-area: value;
    min-width: 0;
}

.cf-pooling-page .cf-pool-kpi-label {
    grid-area: label;
}

.cf-bg-blue { background: linear-gradient(135deg, #0ea5e9, #2563eb); }
.cf-bg-indigo { background: linear-gradient(135deg, #6366f1, #1d4ed8); }
.cf-bg-green { background: linear-gradient(135deg, #10b981, #047857); }
.cf-bg-red { background: linear-gradient(135deg, #ef4444, #b91c1c); }
.cf-bg-teal { background: linear-gradient(135deg, #14b8a6, #0f766e); }

.cf-currency-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin: 0 0 14px;
}

.cf-currency-summary-card {
    background: #ffffff;
    border: 1px solid var(--cfs-border);
    border-radius: 12px;
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: var(--cfs-shadow-sm);
}

.cf-currency-flag {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #eff6ff;
    color: #1d4ed8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 850;
    font-size: 1.05rem;
}

.cf-currency-summary-card strong,
.cf-currency-summary-card span,
.cf-currency-summary-card small {
    display: block;
}

.cf-currency-summary-card strong {
    color: var(--cfs-text);
    font-size: 0.78rem;
}

.cf-currency-summary-card span {
    color: var(--cfs-text);
    font-weight: 850;
    font-size: 1rem;
}

.cf-currency-summary-card small {
    color: var(--cfs-muted);
    font-size: 0.72rem;
}

.cf-pooling-command-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
    gap: 14px;
    align-items: start;
}

.cf-pooling-command-grid main,
.cf-pooling-side {
    min-width: 0;
}

.cf-pooling-side {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.cf-smart-panel .cf-panel-header {
    align-items: center !important;
}

.cf-smart-total {
    border: 1px solid #dbeafe;
    background: #f8fbff;
    border-radius: 10px;
    padding: 12px;
    margin-bottom: 10px;
}

.cf-smart-total span,
.cf-optimization-card span,
.cf-efficiency span {
    display: block;
    color: var(--cfs-muted);
    font-size: 0.74rem;
}

.cf-smart-total strong,
.cf-optimization-card strong,
.cf-efficiency strong {
    display: block;
    color: var(--cfs-green);
    font-size: 1.12rem;
    margin-top: 3px;
}

.cf-transfer-list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: transfer;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cf-transfer-list li {
    counter-increment: transfer;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 8px 10px;
    align-items: center;
    border-bottom: 1px dashed #e2e8f0;
    padding-bottom: 8px;
}

.cf-transfer-list li::before {
    content: counter(transfer);
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #dbeafe;
    color: #1d4ed8;
    font-weight: 850;
    font-size: 0.76rem;
}

.cf-transfer-list span,
.cf-transfer-list strong {
    min-width: 0;
}

.cf-transfer-list span {
    color: #334155;
    font-weight: 700;
    font-size: 0.8rem;
}

.cf-transfer-list strong {
    grid-column: 2;
    color: var(--cfs-muted);
    font-size: 0.76rem;
}

.cf-optimization-card {
    border: 1px solid #dbeafe;
    border-radius: 12px;
    padding: 14px;
    background: #ffffff;
}

.cf-mini-wave {
    display: flex;
    align-items: end;
    gap: 5px;
    height: 34px;
    margin-top: 14px;
}

.cf-mini-wave i {
    flex: 1;
    border-radius: 999px 999px 0 0;
    background: linear-gradient(180deg, #22c55e, #bfdbfe);
}

.cf-mini-wave i:nth-child(1) { height: 38%; }
.cf-mini-wave i:nth-child(2) { height: 58%; }
.cf-mini-wave i:nth-child(3) { height: 44%; }
.cf-mini-wave i:nth-child(4) { height: 70%; }
.cf-mini-wave i:nth-child(5) { height: 88%; }

.cf-efficiency {
    display: flex;
    align-items: center;
    gap: 14px;
}

.cf-efficiency-ring {
    width: 82px;
    height: 82px;
    border-radius: 50%;
    background: conic-gradient(#10b981 0 84%, #e2e8f0 84% 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.cf-efficiency-ring span {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--cfs-text);
    font-size: 1rem;
    font-weight: 850;
}

@media (max-width: 1180px) {
    .cf-pooling-page .cf-pool-overview,
    .cf-currency-strip,
    .cf-pooling-command-grid {
        grid-template-columns: 1fr 1fr !important;
    }

    .cf-pooling-command-grid main,
    .cf-pooling-side {
        grid-column: 1 / -1;
    }
}

@media (max-width: 720px) {
    .cf-pooling-page .cf-pool-overview,
    .cf-currency-strip,
    .cf-pooling-command-grid {
        grid-template-columns: 1fr !important;
    }
}

.cf-report-command-grid {
    display: grid;
    grid-template-columns: minmax(260px, 0.9fr) minmax(360px, 1.25fr) minmax(280px, 1fr) minmax(220px, 0.72fr);
    gap: 14px;
    margin-top: 14px;
    align-items: stretch;
}

/* Executive Cash Flow Report */
.cf-executive-report {
    margin-top: 0.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.58rem;
    color: #172033;
    background: #f3f5f9;
    border: 1px solid #e4e9f2;
    border-radius: 12px;
    padding: 0.58rem;
}

.cf-exec-context-row,
.cf-exec-filter-strip,
.cf-exec-panel,
.cf-exec-kpi,
.cf-exec-bottom-kpi {
    background: #fff;
    border: 1px solid #dfe6f2;
    box-shadow: 0 8px 22px rgba(28, 47, 84, 0.07);
}

.cf-exec-context-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-radius: 10px;
    padding: 0.75rem 0.95rem;
}

.cf-exec-context-row h2 {
    margin: 0;
    font-size: 1.96rem;
    font-weight: 800;
    letter-spacing: 0;
    color: #0f1b3d;
}

.cf-exec-context-row span,
.cf-exec-panel header span,
.cf-exec-filter-strip span {
    font-size: 0.72rem;
    color: #64748b;
}

.cf-exec-context-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.cf-exec-context-actions .cf-btn {
    min-height: 33px !important;
    padding: 0.36rem 0.72rem !important;
    font-size: 0.74rem !important;
}

.cf-exec-filter-strip {
    display: grid;
    grid-template-columns: 1.35fr repeat(6, minmax(120px, 1fr));
    gap: 0.55rem;
    border-radius: 10px;
    padding: 0.52rem;
}

.cf-exec-filter-strip div {
    min-width: 0;
    border: 1px solid #e5ebf5;
    border-radius: 6px;
    padding: 0.45rem 0.58rem;
    background: #fbfdff;
}

.cf-exec-filter-strip strong {
    display: block;
    margin-top: 0.15rem;
    font-size: 0.78rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #111827;
}

.cf-exec-kpi-ribbon {
    display: grid;
    grid-template-columns: repeat(8, minmax(160px, 1fr));
    gap: 0.55rem;
}

.cf-exec-kpi {
    min-height: 108px;
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    grid-template-rows: auto 32px;
    gap: 0.45rem 0.55rem;
    border-radius: 10px;
    padding: 0.65rem;
    overflow: hidden;
}

.cf-exec-kpi-icon {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 7px;
    color: #fff;
    background: #2563eb;
}

.cf-exec-kpi.green .cf-exec-kpi-icon { background: #149365; }
.cf-exec-kpi.red .cf-exec-kpi-icon { background: #ef4444; }
.cf-exec-kpi.teal .cf-exec-kpi-icon { background: #0f9f9f; }
.cf-exec-kpi.purple .cf-exec-kpi-icon { background: #7c3aed; }
.cf-exec-kpi.amber .cf-exec-kpi-icon { background: #f59e0b; }

.cf-exec-kpi-body {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
}

.cf-exec-kpi-body span {
    font-size: 0.72rem;
    color: #475569;
    font-weight: 700;
}

.cf-exec-kpi-body strong {
    font-size: 1rem;
    color: #111827;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cf-exec-kpi-body small,
.cf-exec-table .positive,
.cf-exec-bottom-kpi small.positive,
.cf-aging-list .positive,
.cf-exec-kpi-body .positive { color: #0f8f5d; }
.cf-exec-kpi-body .negative,
.cf-exec-table .negative { color: #dc2626; }

.cf-kpi-badge {
    margin-top: 0.1rem;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: 999px;
    padding: 0.12rem 0.42rem;
    font-size: 0.64rem;
    font-style: normal;
    font-weight: 800;
    color: #166534;
    background: #dcfce7;
    border: 1px solid #86efac;
}

.cf-exec-sparkline {
    grid-column: 1 / -1;
    display: flex;
    align-items: end;
    gap: 3px;
    height: 32px;
}

.cf-exec-sparkline i {
    flex: 1;
    display: block;
    min-width: 2px;
    border-radius: 4px 4px 0 0;
    background: rgba(37, 99, 235, 0.22);
}

.cf-exec-sparkline.green i { background: rgba(20, 147, 101, 0.24); }
.cf-exec-sparkline.red i { background: rgba(239, 68, 68, 0.24); }
.cf-exec-sparkline.teal i { background: rgba(15, 159, 159, 0.24); }
.cf-exec-sparkline.purple i { background: rgba(124, 58, 237, 0.22); }
.cf-exec-sparkline.amber i { background: rgba(245, 158, 11, 0.24); }

.cf-exec-top-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.95fr);
    gap: 0.7rem;
}

.cf-exec-main-grid {
    display: grid;
    grid-template-columns: 1.05fr 1.35fr 0.95fr;
    gap: 0.7rem;
}

.cf-exec-panel {
    border-radius: 10px;
    min-width: 0;
    overflow: hidden;
}

.cf-exec-panel header {
    min-height: 43px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.7rem;
    padding: 0.7rem 0.85rem 0.3rem;
}

.cf-exec-panel header h3 {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 800;
    color: #172033;
}

.cf-exec-segment {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.18rem;
    border-radius: 6px;
    background: #eef4ff;
    font-size: 0.7rem;
}

.cf-exec-segment b,
.cf-exec-segment span {
    padding: 0.25rem 0.45rem;
    border-radius: 5px;
}

.cf-exec-segment b {
    background: #2563eb;
    color: #fff;
}

.cf-exec-chart {
    height: 224px;
    width: 100%;
}

.cf-exec-chart-lg { height: 328px; }
.cf-exec-chart-sm { height: 154px; }

.cf-ai-panel {
    display: flex;
    flex-direction: column;
}

.cf-ai-list,
.cf-alert-list {
    padding: 0.35rem 0.7rem 0.7rem;
    display: flex;
    flex-direction: column;
    gap: 0.42rem;
}

.cf-ai-item,
.cf-alert-row {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.5rem;
    padding: 0.58rem 0.65rem;
    border-radius: 7px;
    background: #f8fbff;
    border: 1px solid #e6edf8;
    font-size: 0.78rem;
}

.cf-ai-item { grid-template-columns: 28px minmax(0, 1fr); }
.cf-ai-item i,
.cf-alert-row i { font-size: 1rem; text-align: center; }
.cf-ai-item.danger i,
.cf-alert-row.danger i { color: #ef4444; }
.cf-ai-item.warning i,
.cf-alert-row.warning i { color: #f59e0b; }
.cf-ai-item.info i,
.cf-alert-row.info i { color: #2563eb; }
.cf-ai-item.success i { color: #149365; }

.cf-exec-link-button {
    align-self: flex-end;
    margin: auto 0.7rem 0.7rem;
    border: 1px solid #8bb5ff;
    background: #eef5ff;
    color: #1d4ed8;
    border-radius: 6px;
    padding: 0.45rem 0.7rem;
    font-size: 0.76rem;
    font-weight: 800;
}

.cf-hotel-panel { grid-column: span 1; }

.cf-exec-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.73rem;
}

.cf-exec-table th,
.cf-exec-table td {
    padding: 0.55rem 0.65rem;
    border-top: 1px solid #e8eef7;
    vertical-align: middle;
}

.cf-exec-table th {
    color: #64748b;
    font-weight: 800;
    background: #f8fbff;
}

.cf-exec-table tfoot td {
    font-weight: 800;
    background: #fbfdff;
}

.cf-exec-table.compact td,
.cf-exec-table.compact th {
    padding: 0.45rem 0.55rem;
}

.cf-risk-pill,
.cf-priority-pill {
    display: inline-flex;
    align-items: center;
    min-width: 48px;
    justify-content: center;
    border-radius: 999px;
    padding: 0.15rem 0.45rem;
    font-size: 0.68rem;
    font-weight: 800;
}

.cf-risk-pill.low,
.cf-priority-pill.low { background: #e8f8ef; color: #0f8f5d; }
.cf-risk-pill.medium,
.cf-priority-pill.medium { background: #fff7e6; color: #b45309; }
.cf-priority-pill.high { background: #feecec; color: #dc2626; }

.cf-aging-list {
    list-style: none;
    margin: 0;
    padding: 0 0.85rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.42rem;
}

.cf-aging-list li {
    display: grid;
    grid-template-columns: 10px 1fr auto 42px;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
}

.cf-aging-list i {
    width: 9px;
    height: 9px;
    border-radius: 2px;
}

.cf-aging-list i.blue { background: #2563eb; }
.cf-aging-list i.green { background: #22a06b; }
.cf-aging-list i.amber { background: #f59e0b; }
.cf-aging-list i.red { background: #ef4444; }

.cf-aging-mini-kpis {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
    padding: 0 0.85rem 0.8rem;
}

.cf-aging-mini-card {
    border: 1px solid #e6edf8;
    background: #fbfdff;
    border-radius: 8px;
    padding: 0.45rem 0.5rem;
}

.cf-aging-mini-card span,
.cf-aging-mini-card strong,
.cf-aging-mini-card small {
    display: block;
}

.cf-aging-mini-card span {
    color: #64748b;
    font-size: 0.65rem;
    font-weight: 700;
}

.cf-aging-mini-card strong {
    margin-top: 0.16rem;
    color: #16a34a;
    font-size: 0.9rem;
    font-weight: 800;
}

.cf-aging-mini-card small {
    margin-top: 0.08rem;
    color: #64748b;
    font-size: 0.66rem;
}

.cf-share-cell {
    display: grid;
    grid-template-columns: minmax(48px, 1fr) auto;
    align-items: center;
    gap: 0.35rem;
}

.cf-share-cell i {
    height: 6px;
    border-radius: 999px;
    display: block;
    background: linear-gradient(90deg, #2563eb, #60a5fa);
}

.cf-share-cell span {
    color: #64748b;
    font-size: 0.67rem;
    font-weight: 700;
}

.cf-overview-empty-note {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0.7rem 0 0.95rem;
    padding: 0.55rem 0.7rem;
    border-radius: 8px;
    border: 1px solid #fde68a;
    background: #fffbeb;
    color: #92400e;
    font-size: 0.72rem;
    font-weight: 600;
}

.cf-alert-row span {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.cf-alert-row small {
    color: #64748b;
}

.cf-alert-row time {
    font-size: 0.68rem;
    color: #94a3b8;
}

.cf-exec-bottom-kpis {
    display: grid;
    grid-template-columns: repeat(5, minmax(170px, 1fr));
    gap: 0.7rem;
}

.cf-exec-bottom-kpi {
    display: grid;
    grid-template-columns: 36px 1fr auto;
    align-items: center;
    gap: 0.55rem;
    border-radius: 10px;
    padding: 0.75rem 0.85rem;
}

.cf-exec-bottom-kpi i {
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border-radius: 7px;
    background: #eef5ff;
    color: #2563eb;
}

.cf-exec-bottom-kpi span {
    font-size: 0.72rem;
    color: #475569;
    font-weight: 800;
}

.cf-exec-bottom-kpi strong {
    font-size: 0.95rem;
    color: #111827;
}

@media (max-width: 1500px) {
    .cf-exec-kpi-ribbon { grid-template-columns: repeat(4, minmax(180px, 1fr)); }
    .cf-exec-filter-strip { grid-template-columns: repeat(4, minmax(150px, 1fr)); }
    .cf-exec-main-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1100px) {
    .cf-exec-top-grid,
    .cf-exec-main-grid { grid-template-columns: 1fr; }
    .cf-exec-bottom-kpis { grid-template-columns: repeat(2, minmax(170px, 1fr)); }
}

@media (max-width: 720px) {
    .cf-exec-context-row { align-items: stretch; flex-direction: column; }
    .cf-exec-context-actions { width: 100%; }
    .cf-exec-context-actions .cf-btn { flex: 1 1 auto; justify-content: center; }
    .cf-exec-filter-strip,
    .cf-exec-kpi-ribbon,
    .cf-exec-bottom-kpis { grid-template-columns: 1fr; }
    .cf-exec-table { min-width: 680px; }
    .cf-hotel-panel,
    .cf-exec-panel { overflow-x: auto; }
}

.cf-report-command-grid .cf-card {
    margin-top: 0 !important;
    min-width: 0;
}

.cf-report-template-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cf-report-template {
    width: 100%;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    border-radius: 10px;
    padding: 10px 12px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    text-align: left;
    color: var(--cfs-text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cf-report-template:hover,
.cf-report-template.active {
    border-color: #60a5fa;
    box-shadow: 0 8px 18px rgba(18, 104, 243, 0.08);
}

.cf-report-template i {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #eff6ff;
    color: #1d4ed8;
    flex: 0 0 auto;
}

.cf-report-template strong,
.cf-report-template small {
    display: block;
}

.cf-report-template strong {
    font-size: 0.8rem;
    color: var(--cfs-text);
}

.cf-report-template small {
    color: var(--cfs-muted);
    font-size: 0.72rem;
    margin-top: 2px;
}

.cf-report-preview {
    min-height: 210px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 14px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
}

.cf-report-preview strong,
.cf-report-preview span,
.cf-report-preview small {
    display: block;
}

.cf-report-preview strong {
    color: var(--cfs-text);
    font-size: 1rem;
}

.cf-report-preview span,
.cf-report-preview small {
    color: var(--cfs-muted);
    font-size: 0.76rem;
    margin-top: 3px;
}

.cf-report-preview-bars {
    display: flex;
    align-items: end;
    gap: 12px;
    height: 110px;
    margin-top: 18px;
    padding: 0 8px 8px;
    border-bottom: 1px solid #dbeafe;
}

.cf-report-preview-bars i {
    flex: 1;
    min-width: 18px;
    border-radius: 8px 8px 0 0;
    background: linear-gradient(180deg, #10b981, #86efac);
}

.cf-report-preview-bars i:nth-child(even) {
    background: linear-gradient(180deg, #ef4444, #fecaca);
}

.cf-recent-report-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cf-recent-report-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px dashed #e2e8f0;
    padding: 8px 0;
}

.cf-recent-report-list span {
    flex: 1;
    min-width: 0;
    color: #334155;
    font-size: 0.78rem;
    font-weight: 700;
}

.cf-recent-report-list b {
    color: #047857;
    background: #dcfce7;
    border-radius: 999px;
    padding: 3px 8px;
    font-size: 0.68rem;
}

.cf-report-info-panel dl {
    display: flex;
    flex-direction: column;
    gap: 9px;
    margin: 0;
}

.cf-report-info-panel dl div {
    border-bottom: 1px dashed #e2e8f0;
    padding-bottom: 8px;
}

.cf-report-info-panel dt {
    color: var(--cfs-muted);
    font-size: 0.72rem;
    font-weight: 800;
}

.cf-report-info-panel dd {
    margin: 2px 0 0;
    color: var(--cfs-text);
    font-weight: 800;
    font-size: 0.8rem;
}

@media (max-width: 1500px) {
    .cf-report-command-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .cf-report-command-grid {
        grid-template-columns: 1fr;
    }
}

.data-entry-shell .entry-command-deck {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 0 0 16px;
}

.entry-command-panel {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 4px 14px rgba(15, 35, 70, 0.05);
    min-width: 0;
}

.entry-command-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.entry-command-header h3 {
    margin: 0;
    color: var(--cfs-text);
    font-size: 0.96rem;
    font-weight: 850;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.entry-command-header span {
    color: #1d4ed8;
    background: #eff6ff;
    border-radius: 999px;
    padding: 3px 9px;
    font-size: 0.72rem;
    font-weight: 850;
}

.entry-command-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.entry-command-metrics div {
    border: 1px solid #edf2fa;
    border-radius: 10px;
    padding: 9px;
    background: #f8fbff;
}

.entry-command-metrics span,
.entry-warning-list span,
.entry-workflow-steps span {
    display: block;
    color: var(--cfs-muted);
    font-size: 0.72rem;
}

.entry-command-metrics strong {
    display: block;
    color: var(--cfs-text);
    font-size: 1.06rem;
    margin-top: 2px;
}

.entry-command-metrics strong.positive { color: var(--cfs-green); }
.entry-command-metrics strong.warning { color: var(--cfs-amber); }

.entry-health-bar {
    height: 8px;
    border-radius: 999px;
    background: #e2e8f0;
    overflow: hidden;
    margin-top: 12px;
}

.entry-health-bar i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #10b981, #22c55e);
}

.entry-warning-list,
.entry-workflow-steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.entry-warning-list li {
    display: flex;
    align-items: center;
    gap: 9px;
    border-bottom: 1px dashed #e2e8f0;
    padding-bottom: 8px;
}

.entry-warning-list i {
    color: #0ea5e9;
}

.entry-workflow-steps li {
    border-left: 3px solid #cbd5e1;
    padding-left: 10px;
}

.entry-workflow-steps li.done { border-left-color: var(--cfs-green); }
.entry-workflow-steps li.current { border-left-color: var(--cfs-amber); }

.entry-workflow-steps b {
    display: block;
    color: var(--cfs-text);
    font-size: 0.8rem;
}

.cf-analytics-switchboard {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    background: #ffffff;
    border: 1px solid var(--cfs-border);
    border-radius: 12px;
    padding: 10px;
    margin: 0 0 14px;
    box-shadow: var(--cfs-shadow-sm);
}

.cf-analytics-tabs,
.cf-analytics-chips {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.cf-analytics-tabs button {
    border: 1px solid #e2e8f0;
    background: #ffffff;
    color: #334155;
    border-radius: 8px;
    padding: 8px 12px;
    font-weight: 850;
    font-size: 0.78rem;
}

.cf-analytics-tabs button.active {
    background: #1268f3;
    color: #ffffff;
    border-color: transparent;
}

.cf-analytics-tabs button.cf-tab-disabled,
.cf-analytics-tabs button[disabled] {
    opacity: 0.55;
    cursor: not-allowed;
    background: #f1f5f9;
    color: #64748b;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.cf-analytics-tabs .cf-tab-badge {
    background: #f59e0b;
    color: #ffffff;
    font-size: 0.6rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-left: 4px;
}

/* Trend direction badges (used by ForecastAccuracy and similar) */
.cf-trend {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-weight: 700;
}

.cf-trend-up {
    color: #15803d;
}

.cf-trend-down {
    color: #b91c1c;
}

.cf-trend-flat {
    color: #64748b;
}

.cf-analytics-chips span {
    border: 1px solid #dbeafe;
    background: #f8fbff;
    color: var(--cfs-muted);
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 0.76rem;
}

.cf-analytics-chips b {
    color: #1d4ed8;
}

.cf-analytics-action-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.65fr);
    gap: 14px;
}

.cf-analytics-recommendations {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.cf-analytics-recommendations > div {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 12px;
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    background: #ffffff;
}

.cf-rec-icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
}

.cf-rec-icon.green { background: linear-gradient(135deg, #10b981, #047857); }
.cf-rec-icon.amber { background: linear-gradient(135deg, #f59e0b, #d97706); }
.cf-rec-icon.blue { background: linear-gradient(135deg, #0ea5e9, #1d4ed8); }

.cf-analytics-recommendations strong,
.cf-analytics-recommendations p {
    display: block;
    margin: 0;
}

.cf-analytics-recommendations strong {
    color: var(--cfs-text);
    font-size: 0.82rem;
}

.cf-analytics-recommendations p {
    color: var(--cfs-muted);
    font-size: 0.74rem;
    margin-top: 3px;
}

.cf-analytics-recommendations b {
    border-radius: 999px;
    background: #fef3c7;
    color: #b45309;
    padding: 3px 8px;
    font-size: 0.66rem;
}

.cf-analytics-mini-table {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cf-analytics-mini-table div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-bottom: 1px dashed #e2e8f0;
    padding-bottom: 9px;
}

.cf-analytics-mini-table span {
    color: var(--cfs-muted);
    font-size: 0.78rem;
}

.cf-analytics-mini-table strong {
    color: var(--cfs-text);
    font-size: 0.82rem;
}

@media (max-width: 1180px) {
    .data-entry-shell .entry-command-deck,
    .cf-analytics-action-grid,
    .cf-analytics-recommendations {
        grid-template-columns: 1fr !important;
    }

    .cf-analytics-switchboard {
        align-items: stretch;
        flex-direction: column;
    }
}
/* ============================================================
   CFX — Cash Flow Statement & Report Center (rich layout)
   ============================================================ */
.cfx-statement { padding: 18px 22px 28px; background:#f4f6fa; min-height:100vh; }

.cfx-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.cfx-header-brand { display:flex; align-items:center; gap:14px; }
.cfx-brand-icon { width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:20px; }
.cfx-brand-text h1 { font-size:1.45rem; margin:0; color:#0f172a; font-weight:700; }
.cfx-brand-text p { margin:2px 0 0; font-size:0.82rem; color:#64748b; }
.cfx-header-actions { display:flex; gap:8px; align-items:center; }
.cfx-icon-btn { position:relative; width:36px;height:36px;border-radius:10px;border:1px solid #e2e8f0; background:#fff; color:#475569; display:inline-flex;align-items:center;justify-content:center; cursor:pointer; transition:all .15s; }
.cfx-icon-btn:hover { background:#f1f5f9; color:#1e293b; }
.cfx-icon-badge { position:absolute; top:-4px; right:-4px; min-width:18px;height:18px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700; display:flex;align-items:center;justify-content:center;padding:0 4px; }
.cfx-method-toggle { display:inline-flex; background:#fff; border:1px solid #e2e8f0; border-radius:10px; padding:3px; gap:2px; }
.cfx-method-toggle button { padding:6px 14px; border:none; background:transparent; border-radius:8px; font-size:.82rem; font-weight:600; color:#64748b; cursor:pointer; }
.cfx-method-toggle button.is-active { background:linear-gradient(135deg,#3b82f6,#6366f1); color:#fff; }

/* Filter bar */
.cfx-filterbar { display:flex; align-items:flex-end; justify-content:space-between; gap:14px; background:#fff; padding:12px 16px; border-radius:12px; box-shadow:0 1px 3px rgba(15,23,42,.05); margin-bottom:14px; flex-wrap:wrap; }
.cfx-filterbar-left { display:flex; gap:14px; flex-wrap:wrap; align-items:flex-end; }
.cfx-filterbar-right { display:flex; gap:8px; flex-wrap:wrap; }
.cfx-field { display:flex; flex-direction:column; gap:4px; }
.cfx-field label { font-size:.7rem; font-weight:700; color:#94a3b8; letter-spacing:.04em; text-transform:uppercase; }
.cfx-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 14px; border-radius:8px; border:1px solid transparent; font-size:.82rem; font-weight:600; cursor:pointer; transition:all .15s; }
.cfx-btn:disabled { opacity:.5; cursor:not-allowed; }
.cfx-btn-primary { background:#3b82f6; color:#fff; }
.cfx-btn-primary:hover:not(:disabled) { background:#2563eb; }
.cfx-btn-success { background:#10b981; color:#fff; }
.cfx-btn-success:hover:not(:disabled) { background:#059669; }
.cfx-btn-info { background:#8b5cf6; color:#fff; }
.cfx-btn-info:hover:not(:disabled) { background:#7c3aed; }
.cfx-btn-ghost { background:#fff; color:#475569; border-color:#e2e8f0; }
.cfx-btn-ghost:hover:not(:disabled) { background:#f1f5f9; }

/* KPI row */
.cfx-kpi-row { display:grid; grid-template-columns:repeat(6, minmax(0,1fr)); gap:12px; margin-bottom:14px; }
.cfx-kpi-card { background:#fff; border-radius:14px; padding:14px; box-shadow:0 1px 3px rgba(15,23,42,.05); border-left:3px solid transparent; display:flex; flex-direction:column; gap:6px; min-height:130px; position:relative; overflow:hidden; }
.cfx-kpi-card.cfx-kpi-green   { border-left-color:#10b981; }
.cfx-kpi-card.cfx-kpi-orange  { border-left-color:#f59e0b; }
.cfx-kpi-card.cfx-kpi-blue    { border-left-color:#3b82f6; }
.cfx-kpi-card.cfx-kpi-red     { border-left-color:#ef4444; }
.cfx-kpi-card.cfx-kpi-red-accent { border-left-color:#ef4444; }
.cfx-kpi-card.cfx-kpi-slate   { border-left-color:#64748b; }
.cfx-kpi-card.cfx-kpi-teal    { border-left-color:#14b8a6; }
.cfx-kpi-head { display:flex; align-items:center; gap:10px; }
.cfx-kpi-icon { width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px; background:#f1f5f9; color:#475569; }
.cfx-kpi-card.cfx-kpi-green .cfx-kpi-icon { background:#d1fae5; color:#065f46; }
.cfx-kpi-card.cfx-kpi-orange .cfx-kpi-icon { background:#fef3c7; color:#92400e; }
.cfx-kpi-card.cfx-kpi-blue .cfx-kpi-icon { background:#dbeafe; color:#1e40af; }
.cfx-kpi-card.cfx-kpi-red .cfx-kpi-icon, .cfx-kpi-card.cfx-kpi-red-accent .cfx-kpi-icon { background:#fee2e2; color:#991b1b; }
.cfx-kpi-card.cfx-kpi-slate .cfx-kpi-icon { background:#e2e8f0; color:#334155; }
.cfx-kpi-card.cfx-kpi-teal .cfx-kpi-icon { background:#ccfbf1; color:#115e59; }
.cfx-kpi-meta { display:flex; flex-direction:column; line-height:1.1; }
.cfx-kpi-label { font-size:.7rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.04em; }
.cfx-kpi-sub { font-size:.7rem; color:#94a3b8; margin-top:2px; }
.cfx-kpi-value { font-size:1.35rem; font-weight:700; color:#0f172a; line-height:1.1; }
.cfx-kpi-change { font-size:.72rem; font-weight:600; display:inline-flex; gap:4px; align-items:center; }
.cfx-kpi-change.is-up { color:#059669; }
.cfx-kpi-change.is-down { color:#dc2626; }
.cfx-kpi-spark { height:36px; margin-top:auto; }

/* Tabs */
.cfx-tabs { display:flex; gap:4px; background:#fff; padding:6px; border-radius:12px; margin-bottom:14px; box-shadow:0 1px 3px rgba(15,23,42,.04); overflow-x:auto; }
.cfx-tab { display:inline-flex; gap:6px; align-items:center; border:none; background:transparent; padding:9px 16px; border-radius:8px; font-size:.82rem; font-weight:600; color:#64748b; cursor:pointer; white-space:nowrap; transition:all .15s; }
.cfx-tab:hover { background:#f1f5f9; color:#1e293b; }
.cfx-tab.is-active { background:#3b82f6; color:#fff; }

/* Main grid */
.cfx-main-grid { display:grid; grid-template-columns: 1fr 380px; gap:14px; margin-bottom:14px; }
.cfx-main { min-width:0; }
.cfx-side { display:flex; flex-direction:column; gap:14px; }

.cfx-panel { background:#fff; border-radius:12px; box-shadow:0 1px 3px rgba(15,23,42,.05); padding:14px 16px; }
.cfx-panel-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; gap:8px; }
.cfx-panel-header h3 { font-size:.85rem; margin:0; color:#0f172a; font-weight:700; letter-spacing:.02em; }
.cfx-panel-toggle { display:inline-flex; gap:4px; background:#f1f5f9; padding:3px; border-radius:8px; }
.cfx-panel-toggle button { padding:5px 12px; border-radius:6px; border:none; background:transparent; font-size:.74rem; font-weight:600; color:#64748b; cursor:pointer; }
.cfx-panel-toggle button.is-active { background:#3b82f6; color:#fff; }
.cfx-panel-toggle .cfx-icon-only { padding:5px 8px; }
.cfx-panel-foot { font-size:.72rem; color:#94a3b8; margin-top:8px; }
.cfx-pill-soft { font-size:.72rem; color:#3b82f6; font-weight:600; }

/* Statement TreeGrid polish */
.cfx-panel .e-treegrid,
.cfx-panel .e-grid { border:1px solid #e2e8f0; border-radius:10px; overflow:hidden; box-shadow:none; }
.cfx-panel .e-gridheader { border-bottom:1px solid #cbd5e1; background:#f8fafc; }
.cfx-panel .e-headercell { background:#f8fafc; color:#475569; font-size:.68rem; font-weight:800; letter-spacing:.04em; text-transform:uppercase; border-color:#e2e8f0; padding:9px 10px; }
.cfx-panel .e-rowcell { border-color:#edf2f7; color:#1f2937; font-size:.78rem; padding:8px 10px; font-variant-numeric:tabular-nums; }
.cfx-panel .e-altrow .e-rowcell { background:#fbfdff; }
.cfx-panel .e-row:hover .e-rowcell { background:#eef6ff !important; }
.cfx-panel .e-treecell { color:#0f172a; }
.cfx-panel .e-rowcell:first-child,
.cfx-panel .e-headercell:first-child { box-shadow:1px 0 0 rgba(148,163,184,.18); }
.cfx-panel .e-gridcontent::-webkit-scrollbar { width:8px; height:8px; }
.cfx-panel .e-gridcontent::-webkit-scrollbar-thumb { background:#cbd5e1; border-radius:8px; }
.cfx-panel .e-gridcontent::-webkit-scrollbar-track { background:#f8fafc; }

/* Table */
.cfx-table { width:100%; border-collapse:separate; border-spacing:0; font-size:.82rem; }
.cfx-table th { text-align:left; padding:8px 10px; font-size:.7rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.04em; background:#f8fafc; border-bottom:1px solid #e2e8f0; }
.cfx-table td { padding:8px 10px; border-bottom:1px solid #f1f5f9; color:#1f2937; }
.cfx-table tr:hover td { background:#f9fafb; }
.cfx-table .t-right { text-align:right; }
.cfx-tr-total td { background:#f1f5f9; font-weight:700; }
.cfx-tr-bold td { font-weight:700; background:#f8fafc; }
.cfx-empty-row { text-align:center; color:#94a3b8; padding:18px; font-size:.85rem; }

.cfx-pos { color:#059669; font-weight:600; }
.cfx-neg { color:#dc2626; font-weight:600; }
.cfx-mute { color:#94a3b8; }

.cfx-pill { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.7rem; font-weight:600; }
.cfx-pill-green  { background:#d1fae5; color:#065f46; }
.cfx-pill-orange { background:#fef3c7; color:#92400e; }
.cfx-pill-blue   { background:#dbeafe; color:#1e40af; }
.cfx-pill-slate  { background:#e2e8f0; color:#334155; }

/* Branch consolidation cards */
.cfx-branch-card { padding:10px 12px; border:1px solid #e2e8f0; border-radius:10px; margin-bottom:10px; }
.cfx-branch-card:last-child { margin-bottom:0; }
.cfx-branch-head { display:flex; justify-content:space-between; margin-bottom:8px; }
.cfx-branch-code { font-size:.7rem; color:#94a3b8; font-weight:700; letter-spacing:.04em; }
.cfx-branch-name { font-size:.92rem; font-weight:700; color:#0f172a; }
.cfx-branch-rows { display:flex; flex-direction:column; gap:4px; font-size:.78rem; }
.cfx-branch-rows > div { display:flex; justify-content:space-between; }
.cfx-branch-rows span { color:#64748b; }
.cfx-branch-spark { height:42px; margin-top:6px; }

/* Bottom 4-grid */
.cfx-bottom-grid { display:grid; grid-template-columns: 1.1fr 1.3fr 1.3fr 1fr; gap:14px; }
.cfx-template-list { display:flex; flex-direction:column; gap:6px; }
.cfx-template-item { display:flex; gap:10px; align-items:flex-start; padding:10px 12px; border:1px solid #e2e8f0; border-radius:10px; background:#fff; cursor:pointer; text-align:left; transition:all .15s; }
.cfx-template-item:hover { background:#f8fafc; border-color:#cbd5e1; }
.cfx-template-item.is-active { background:#eff6ff; border-color:#3b82f6; }
.cfx-template-item i { color:#3b82f6; margin-top:2px; }
.cfx-tpl-name { font-size:.82rem; font-weight:700; color:#0f172a; }
.cfx-tpl-desc { font-size:.72rem; color:#64748b; margin-top:2px; }
.cfx-template-new { background:#fafbfc; border-style:dashed; }

.cfx-preview-meta { font-size:.78rem; color:#475569; margin-bottom:8px; line-height:1.5; }

.cfx-recent-list { display:flex; flex-direction:column; gap:8px; }
.cfx-recent-item { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:8px; background:#f8fafc; }
.cfx-recent-item i { color:#3b82f6; font-size:.7rem; }
.cfx-recent-text { flex:1; min-width:0; }
.cfx-recent-name { font-size:.8rem; font-weight:600; color:#0f172a; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cfx-recent-time { font-size:.7rem; color:#94a3b8; }
.cfx-recent-fmt { font-size:.7rem; font-weight:700; padding:2px 8px; border-radius:6px; }
.cfx-recent-fmt-excel { background:#d1fae5; color:#065f46; }
.cfx-recent-fmt-pdf   { background:#fee2e2; color:#991b1b; }
.cfx-recent-fmt-success { background:#d1fae5; color:#065f46; }
.cfx-recent-fmt-failed { background:#fee2e2; color:#991b1b; }
.cfx-recent-fmt-running { background:#dbeafe; color:#1e40af; }
.cfx-recent-fmt-pending { background:#fef3c7; color:#92400e; }
.cfx-recent-more { display:block; text-align:center; margin-top:10px; font-size:.78rem; color:#3b82f6; font-weight:600; text-decoration:none; }

.cfx-info-list { display:flex; flex-direction:column; gap:10px; font-size:.78rem; }
.cfx-info-list > div { display:grid; grid-template-columns: 24px 1fr auto; gap:8px; align-items:center; padding:8px 0; border-bottom:1px dashed #e2e8f0; }
.cfx-info-list > div:last-child { border-bottom:none; }
.cfx-info-list i { color:#3b82f6; }
.cfx-info-list span { color:#64748b; }
.cfx-info-list strong { color:#0f172a; font-weight:600; }

@media (max-width: 1380px) {
    .cfx-kpi-row { grid-template-columns: repeat(3, 1fr); }
    .cfx-bottom-grid { grid-template-columns: 1fr 1fr; }
    .cfx-main-grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
    .cfx-statement { padding:12px; }
    .cfx-header { align-items:flex-start; flex-direction:column; gap:12px; }
    .cfx-header-actions { width:100%; flex-wrap:wrap; }
    .cfx-filterbar { align-items:stretch; }
    .cfx-filterbar-left,
    .cfx-filterbar-right { width:100%; }
    .cfx-field { flex:1 1 140px; }
    .cfx-kpi-row { grid-template-columns: repeat(2, 1fr); }
    .cfx-bottom-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
    .cfx-kpi-row { grid-template-columns: 1fr; }
    .cfx-btn { flex:1 1 130px; justify-content:center; }
}

@media print {
    .cfx-statement { background:#fff; padding:0; }
    .cfx-header-actions,
    .cfx-filterbar,
    .cfx-tabs,
    .cfx-side,
    .cfx-bottom-grid,
    .cfx-panel-toggle,
    .cfx-panel-foot { display:none !important; }
    .cfx-header { margin-bottom:10px; padding-bottom:10px; border-bottom:1px solid #cbd5e1; }
    .cfx-main-grid { display:block; margin:0; }
    .cfx-panel { box-shadow:none; border:0; padding:0; }
    .cfx-panel-header h3 { font-size:12px; }
    .cfx-kpi-row { grid-template-columns:repeat(3, 1fr); gap:8px; }
    .cfx-kpi-card { box-shadow:none; border:1px solid #e2e8f0; min-height:auto; break-inside:avoid; }
}

/* ════════════════════════════════════════════════════════════════════
   CONSOLIDATED REPORT TAB
   ════════════════════════════════════════════════════════════════════ */
.cfx-cons-layout { display:grid; grid-template-columns:1fr 340px; gap:14px; align-items:start; }
@media(max-width:1100px) { .cfx-cons-layout { grid-template-columns:1fr; } }
.cfx-cons-table-wrap { overflow-x:auto; }
.cfx-cons-table { width:100%; border-collapse:collapse; font-size:0.78rem; }
.cfx-cons-table th { background:#f8fafc; font-weight:600; color:#475569; padding:8px 10px; border-bottom:2px solid #e2e8f0; white-space:nowrap; }
.cfx-cons-table td { padding:6px 10px; border-bottom:1px solid #f1f5f9; vertical-align:middle; }
.cfx-cons-section-row td { background:#1e293b; color:#fff; font-weight:700; font-size:0.76rem; padding:8px 12px; letter-spacing:.03em; }
.cfx-cons-section-row .cfx-expand-icon { margin-right:6px; font-size:0.7rem; opacity:.7; }
.cfx-cons-sub-row td { padding-left:22px; color:#334155; font-size:0.77rem; }
.cfx-cons-net-row td { background:#f0fdf4; font-weight:600; border-top:1px solid #bbf7d0; }
.cfx-cons-total-row td { background:#fffbeb; font-weight:700; font-size:0.82rem; border-top:2px solid #fbbf24; border-bottom:2px solid #fbbf24; }
.cfx-cons-balance-row td { background:#eff6ff; font-size:0.8rem; }
.cfx-cons-kalem { min-width:200px; }
.cfx-cons-branch { min-width:90px; }
.cfx-cons-elim { min-width:120px; color:#64748b; }
.cfx-cons-total { min-width:120px; background:#f0f9ff !important; }
.cfx-cons-indent { padding-left:28px !important; }
.cfx-expand-icon-sm { font-size:0.6rem; margin-right:4px; opacity:.5; }
.cfx-table-note { font-size:0.71rem; color:#94a3b8; font-weight:400; }
.cfx-cons-bottom-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cfx-cons-notes ul.cfx-notes-list { list-style:none; padding:0; margin:0; }
.cfx-cons-notes ul.cfx-notes-list li { padding:6px 0; border-bottom:1px dashed #e2e8f0; font-size:0.77rem; color:#475569; }
.cfx-cons-notes ul.cfx-notes-list li:last-child { border:0; }
.cfx-cons-total-label { text-align:center; font-weight:700; font-size:0.85rem; color:#1e293b; padding:10px 0 0; }

/* Branch contribution donuts */
.cfx-branch-donut-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(100px,1fr)); gap:10px; padding:4px 0; }
.cfx-branch-donut-card { display:flex; flex-direction:column; align-items:center; gap:4px; }
.cfx-branch-donut-name { font-size:0.72rem; font-weight:600; color:#334155; text-align:center; }
.cfx-branch-donut-val { font-size:0.8rem; font-weight:700; text-align:center; }
.cfx-branch-donut-pct { font-size:0.7rem; font-weight:600; }
.cfx-branch-donut-legend { display:flex; flex-direction:column; gap:2px; width:100%; }
.cfx-branch-donut-legend span { font-size:0.65rem; color:#475569; display:flex; justify-content:space-between; }
.cfx-legend-pos { color:#10b981 !important; }
.cfx-legend-neg { color:#ef4444 !important; }

/* Quick info list */
.cfx-info-list { display:flex; flex-direction:column; gap:8px; }
.cfx-info-list > div { display:flex; align-items:center; gap:8px; font-size:0.79rem; }
.cfx-info-list i { width:16px; color:#64748b; }
.cfx-info-list span { flex:1; color:#64748b; }
.cfx-info-list strong { font-weight:700; color:#1e293b; }

/* ════════════════════════════════════════════════════════════════════
   TREND ANALYSIS TAB
   ════════════════════════════════════════════════════════════════════ */
.cfx-trend-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cfx-trend-half {} /* no extra styles needed */
.cfx-trend-main-chart { flex:1; }
.cfx-trend-insights-panel {}

/* Heatmap */
.cfx-heatmap-wrap { overflow-x:auto; }
.cfx-heatmap { border-collapse:collapse; font-size:0.71rem; width:100%; }
.cfx-heatmap th { padding:4px 5px; background:#f8fafc; color:#64748b; font-weight:600; border-bottom:1px solid #e2e8f0; white-space:nowrap; }
.cfx-hm-col { text-align:center; min-width:36px; }
.cfx-hm-label { padding-right:12px; font-weight:600; color:#1e293b; white-space:nowrap; }
.cfx-hm-cell { text-align:center; padding:4px 3px; border:1px solid rgba(255,255,255,.4); border-radius:2px; cursor:default; white-space:nowrap; }

/* YTD comparison */
.cfx-ytd-row { display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px solid #f1f5f9; font-size:0.8rem; }
.cfx-ytd-varians { background:#f0fdf4; border-radius:6px; padding:6px 8px; margin:4px 0; }
.cfx-divider { border:0; border-top:1px dashed #e2e8f0; margin:10px 0; }
.cfx-insight-item { display:flex; gap:12px; align-items:flex-start; padding:10px; border-radius:8px; margin:6px 0; }
.cfx-insight-item i { margin-top:2px; width:20px; text-align:center; }
.cfx-insight-item > div strong { display:block; font-size:0.8rem; font-weight:700; color:#1e293b; }
.cfx-insight-item > div p { margin:2px 0 0; font-size:0.75rem; color:#64748b; }
.cfx-insight-positive { background:#f0fdf4; color:#10b981; }
.cfx-insight-positive i { color:#10b981; }
.cfx-insight-warning { background:#fffbeb; color:#f59e0b; }
.cfx-insight-warning i { color:#f59e0b; }
.cfx-insight-info { background:#eff6ff; color:#3b82f6; }
.cfx-insight-info i { color:#3b82f6; }

/* Monthly trend table */
.cfx-monthly-table-wrap { overflow-x:auto; }
.cfx-monthly-table { border-collapse:collapse; font-size:0.74rem; width:100%; }
.cfx-monthly-table th { padding:6px 8px; background:#f8fafc; color:#475569; font-weight:600; border-bottom:2px solid #e2e8f0; white-space:nowrap; }
.cfx-monthly-table td { padding:6px 8px; border-bottom:1px solid #f1f5f9; white-space:nowrap; }

/* ════════════════════════════════════════════════════════════════════
   CATEGORY DISTRIBUTION TAB
   ════════════════════════════════════════════════════════════════════ */
.cfx-cat-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:0; }
.cfx-cat-donut-panel {} .cfx-cat-bar-panel {} .cfx-cat-monthly-panel {} .cfx-cat-detail-panel {} .cfx-cat-pie-panel {}

/* Share bar in category table */
.cfx-share-bar { display:flex; align-items:center; gap:6px; }
.cfx-share-fill { height:8px; background:#3b82f6; border-radius:4px; min-width:2px; transition:width .3s; }
.cfx-share-bar span { font-size:0.75rem; color:#475569; white-space:nowrap; }

/* ════════════════════════════════════════════════════════════════════
   DETAIL REPORT TAB
   ════════════════════════════════════════════════════════════════════ */
.cfx-detail-layout { display:grid; grid-template-columns:1fr 240px; gap:14px; align-items:start; }
@media(max-width:1200px) { .cfx-detail-layout { grid-template-columns:1fr; } }
.cfx-detail-main { display:flex; flex-direction:column; gap:14px; min-width:0; }

/* Detail data grid */
.cfx-detail-table-wrap { overflow-x:auto; max-height:600px; overflow-y:auto; }
.cfx-detail-grid { width:100%; border-collapse:collapse; font-size:0.76rem; }
.cfx-detail-grid th { padding:8px 10px; background:#f8fafc; font-weight:600; color:#475569; border-bottom:2px solid #e2e8f0; white-space:nowrap; position:sticky; top:0; z-index:2; }
.cfx-detail-grid td { padding:5px 10px; border-bottom:1px solid #f1f5f9; vertical-align:middle; }
.cfx-detail-section-row td { background:#1e293b; color:#fff; font-weight:700; padding:7px 12px; font-size:0.76rem; }
.cfx-detail-subgroup-row td { background:#f8fafc; color:#334155; font-weight:600; padding:5px 12px; }
.cfx-detail-subgroup-label { padding-left:20px !important; }
.cfx-detail-entry-row:hover td { background:#f0f9ff; }
.cfx-detail-grandtotal-row td { background:#fffbeb; font-weight:700; border-top:2px solid #fbbf24; font-size:0.8rem; }
.cfx-doc-no { font-family:monospace; font-size:0.72rem; color:#64748b; }
.cfx-desc-cell { max-width:160px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cfx-row-num { color:#94a3b8; font-size:0.7rem; text-align:right; width:24px; }

/* Status badges */
.cfx-status-badge { display:inline-block; padding:2px 8px; border-radius:999px; font-size:0.68rem; font-weight:600; white-space:nowrap; }
.cfx-status-approved { background:#dcfce7; color:#16a34a; }
.cfx-status-pending  { background:#fef3c7; color:#b45309; }
.cfx-status-draft    { background:#f1f5f9; color:#64748b; }

/* Pagination */
.cfx-pagination { display:flex; align-items:center; gap:6px; padding:10px 12px 4px; flex-wrap:wrap; font-size:0.77rem; color:#64748b; }
.cfx-page-btn { padding:4px 10px; border:1px solid #e2e8f0; border-radius:6px; background:#fff; cursor:pointer; font-size:0.77rem; }
.cfx-page-btn.is-active { background:#3b82f6; color:#fff; border-color:#3b82f6; font-weight:700; }
.cfx-page-btn:disabled { opacity:.4; cursor:not-allowed; }
.cfx-page-ellipsis { color:#94a3b8; }
.cfx-page-info { margin-left:auto; }
.cfx-page-size-sel { border:1px solid #e2e8f0; border-radius:5px; padding:2px 6px; font-size:0.76rem; background:#fff; }

/* Panel actions row */
.cfx-panel-actions { display:flex; gap:6px; align-items:center; }
.cfx-icon-btn { display:flex; align-items:center; gap:5px; padding:5px 10px; border:1px solid #e2e8f0; border-radius:7px; background:#fff; cursor:pointer; font-size:0.76rem; color:#475569; transition:background .15s; }
.cfx-icon-btn:hover { background:#f0f9ff; border-color:#93c5fd; }

/* Report summary layout */
.cfx-rapor-ozeti-content { display:flex; gap:20px; align-items:center; }
.cfx-rapor-ozeti-content > div:first-child { flex:1; display:flex; flex-direction:column; gap:8px; }
.cfx-rapor-ozeti-content > div:first-child > div { display:flex; align-items:center; gap:8px; font-size:0.8rem; }
.cfx-rapor-ozeti-content > div:first-child i { width:16px; color:#64748b; }
.cfx-rapor-ozeti-content > div:first-child span { flex:1; color:#64748b; }
.cfx-rapor-ozeti-content > div:first-child strong { font-weight:700; }
.cfx-donut-mini { display:flex; flex-direction:column; align-items:center; gap:8px; }
.cfx-donut-legend { display:flex; flex-direction:column; gap:3px; }
.cfx-donut-legend span { font-size:0.72rem; color:#475569; display:flex; align-items:center; gap:4px; }
.cfx-legend-green { color:#10b981; }
.cfx-legend-red { color:#ef4444; }
.cfx-legend-blue { color:#3b82f6; }

/* Exception records */
.cfx-success-row { display:flex; align-items:center; gap:8px; padding:10px; color:#16a34a; background:#f0fdf4; border-radius:6px; font-size:0.8rem; }
.cfx-table-sm { font-size:0.75rem; }

/* Activity list */
.cfx-activity-list { display:flex; flex-direction:column; }
.cfx-activity-item { display:flex; gap:10px; padding:7px 0; border-bottom:1px dashed #f1f5f9; font-size:0.77rem; align-items:center; }
.cfx-activity-item:last-child { border:0; }
.cfx-activity-time { color:#94a3b8; white-space:nowrap; width:120px; flex-shrink:0; }
.cfx-activity-action { flex:1; color:#334155; font-weight:500; }
.cfx-activity-user { color:#64748b; white-space:nowrap; font-size:0.72rem; }

/* Applied filters sidebar */
.cfx-applied-filters {}
.cfx-filter-list { display:flex; flex-direction:column; gap:6px; }
.cfx-filter-item { display:flex; flex-wrap:wrap; gap:4px; align-items:center; font-size:0.77rem; padding:5px 0; border-bottom:1px dashed #f1f5f9; }
.cfx-filter-item:last-child { border:0; }
.cfx-filter-item i { width:14px; color:#94a3b8; flex-shrink:0; }
.cfx-filter-item span { color:#64748b; flex:1; min-width:80px; }
.cfx-filter-item strong { color:#1e293b; }
.cfx-filters-export-btn { width:100%; margin-top:10px; justify-content:center; }

/* Misc shared helpers */
.cfx-empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:40px; color:#94a3b8; }
.cfx-empty-state i { font-size:2rem; }
.cfx-btn-icon { background:none; border:none; color:#64748b; cursor:pointer; padding:4px 6px; }
.cfx-btn-icon:hover { color:#3b82f6; }
.cfx-link-sm { font-size:0.74rem; color:#3b82f6; text-decoration:none; cursor:pointer; }
.cfx-link-sm:hover { text-decoration:underline; }
.cfx-pill-soft { background:#f0f9ff; color:#0369a1; border-radius:999px; padding:2px 8px; font-size:0.7rem; font-weight:600; white-space:nowrap; }
.cfx-pill { border-radius:999px; padding:2px 9px; font-size:0.7rem; font-weight:700; }
.cfx-pill-orange { background:#fef3c7; color:#b45309; }
.cfx-detail-bottom { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media(max-width:900px){ .cfx-detail-bottom { grid-template-columns:1fr; } .cfx-trend-row { grid-template-columns:1fr; } .cfx-cat-row { grid-template-columns:1fr; } .cfx-cons-bottom-row { grid-template-columns:1fr; } }

/* ── cashflow-hub-modern.css ── */
/* ============================================================
   Cash Flow Hub — Modern Layout (mockup #3 reference)
   Scope: only .cfh-* classes
   ============================================================ */

.cfh {
    --cfh-bg: #f4f7fb;
    --cfh-card: #ffffff;
    --cfh-border: #e5e9f2;
    --cfh-border-strong: #d6dbe7;
    --cfh-text: #0f172a;
    --cfh-muted: #64748b;
    --cfh-muted-2: #94a3b8;
    --cfh-blue: #2563eb;
    --cfh-blue-strong: #1d4ed8;
    --cfh-blue-soft: #eff6ff;
    --cfh-green: #16a34a;
    --cfh-green-soft: #dcfce7;
    --cfh-amber: #f59e0b;
    --cfh-amber-soft: #fef3c7;
    --cfh-red: #dc2626;
    --cfh-red-soft: #fee2e2;
    --cfh-purple: #7c3aed;
    --cfh-purple-soft: #ede9fe;
    --cfh-shadow-sm: 0 1px 2px rgba(15,23,42,.05);
    --cfh-shadow: 0 4px 14px -8px rgba(15,23,42,.10), 0 2px 6px -2px rgba(15,23,42,.06);
    --cfh-shadow-lg: 0 18px 42px -22px rgba(37,99,235,.45);
    --cfh-radius: 14px;
    --cfh-radius-sm: 10px;
    background: var(--cfh-bg);
    padding: 1.25rem 1.5rem 2.25rem;
    color: var(--cfh-text);
    font-feature-settings: "tnum" 1;
}

/* ---- HERO ------------------------------------------------ */
.cfh-hero {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    padding: 1.6rem 1.85rem;
    background: linear-gradient(120deg, #1e3a8a 0%, #2563eb 45%, #38bdf8 100%);
    color: #fff;
    box-shadow: var(--cfh-shadow-lg);
    margin-bottom: 1.1rem;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
}

    .cfh-hero::before {
        content: "";
        position: absolute;
        inset: 0;
        background: radial-gradient(900px 380px at 110% -20%, rgba(255,255,255,.18), transparent 60%), radial-gradient(600px 320px at -20% 140%, rgba(56,189,248,.35), transparent 70%);
        pointer-events: none;
    }

.cfh-hero-content {
    position: relative;
    z-index: 1;
    max-width: 720px;
}

    .cfh-hero-content h1 {
        margin: 0;
        font-size: 1.85rem;
        font-weight: 700;
        letter-spacing: -.01em;
    }

    .cfh-hero-content p {
        margin: .35rem 0 .9rem;
        font-size: .95rem;
        opacity: .92;
    }

.cfh-hero-status {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.28);
    padding: .35rem .75rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 500;
    backdrop-filter: blur(4px);
}

.cfh-pulse {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 0 rgba(74,222,128,.7);
    animation: cfh-pulse 1.6s infinite;
}

@keyframes cfh-pulse {
    0% { box-shadow: 0 0 0 0 rgba(74,222,128,.7); }
    70% { box-shadow: 0 0 0 8px rgba(74,222,128,0); }
    100% { box-shadow: 0 0 0 0 rgba(74,222,128,0); }
}

.cfh-hero-actions {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .5rem;
}

.cfh-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border: none;
    border-radius: 10px;
    padding: .65rem 1.05rem;
    font-weight: 600;
    font-size: .9rem;
    cursor: pointer;
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.cfh-btn-primary {
    background: var(--cfh-blue);
    color: #fff;
}

    .cfh-btn-primary:hover {
        background: var(--cfh-blue-strong);
        transform: translateY(-1px);
    }

.cfh-btn-light {
    background: rgba(255,255,255,.95);
    color: var(--cfh-blue-strong);
}

    .cfh-btn-light:hover {
        background: #fff;
        transform: translateY(-1px);
        box-shadow: 0 6px 18px -8px rgba(0,0,0,.25);
    }

/* ---- KPI STRIP ------------------------------------------- */
.cfh-kpi-row {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: .75rem;
    margin-bottom: 1.1rem;
}

@media (max-width: 1500px) {
    .cfh-kpi-row { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 760px) {
    .cfh-kpi-row { grid-template-columns: repeat(2, 1fr); }
}

.cfh-kpi {
    background: var(--cfh-card);
    border: 1px solid var(--cfh-border);
    border-radius: var(--cfh-radius);
    padding: .85rem .9rem .8rem;
    display: flex;
    flex-direction: column;
    gap: .35rem;
    box-shadow: var(--cfh-shadow-sm);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

    .cfh-kpi:hover {
        transform: translateY(-2px);
        border-color: var(--cfh-border-strong);
        box-shadow: var(--cfh-shadow);
    }

.cfh-kpi-head {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.cfh-kpi-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: .85rem;
    flex-shrink: 0;
}

.cfh-i-blue { background: linear-gradient(135deg,#3b82f6,#1d4ed8); }
.cfh-i-green { background: linear-gradient(135deg,#22c55e,#15803d); }
.cfh-i-amber { background: linear-gradient(135deg,#f59e0b,#b45309); }
.cfh-i-red { background: linear-gradient(135deg,#ef4444,#b91c1c); }
.cfh-i-purple { background: linear-gradient(135deg,#a855f7,#6d28d9); }
.cfh-i-cyan { background: linear-gradient(135deg,#22d3ee,#0e7490); }
.cfh-i-slate { background: linear-gradient(135deg,#94a3b8,#475569); }
.cfh-i-pink { background: linear-gradient(135deg,#ec4899,#9d174d); }

.cfh-kpi-label {
    font-size: .72rem;
    font-weight: 600;
    color: var(--cfh-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    line-height: 1.1;
}

.cfh-kpi-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--cfh-text);
    line-height: 1.1;
}

    .cfh-kpi-value.pos { color: var(--cfh-green); }
    .cfh-kpi-value.neg { color: var(--cfh-red); }

.cfh-kpi-foot {
    font-size: .72rem;
    color: var(--cfh-muted);
    display: flex;
    align-items: center;
    gap: .3rem;
}

    .cfh-kpi-foot.pos { color: var(--cfh-green); }
    .cfh-kpi-foot.neg { color: var(--cfh-red); }
    .cfh-kpi-foot.warn { color: var(--cfh-amber); }

/* ---- SPOTLIGHT ------------------------------------------- */
.cfh-spotlight {
    display: grid;
    grid-template-columns: 1.4fr repeat(4, 1fr) 1.2fr;
    gap: .75rem;
    margin-bottom: 1.25rem;
}

@media (max-width: 1400px) {
    .cfh-spotlight { grid-template-columns: 1fr 1fr 1fr; }
}

@media (max-width: 760px) {
    .cfh-spotlight { grid-template-columns: 1fr; }
}

.cfh-spot {
    background: var(--cfh-card);
    border: 1px solid var(--cfh-border);
    border-radius: var(--cfh-radius);
    padding: .9rem 1rem;
    box-shadow: var(--cfh-shadow-sm);
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

    .cfh-spot.feature {
        background: linear-gradient(135deg,#0f172a 0%,#1e293b 100%);
        color: #fff;
        border: none;
    }

        .cfh-spot.feature .cfh-spot-label,
        .cfh-spot.feature .cfh-spot-sub {
            color: rgba(255,255,255,.75);
        }

.cfh-spot-label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--cfh-muted-2);
}

.cfh-spot-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: inherit;
}

.cfh-spot-value {
    font-size: 1.4rem;
    font-weight: 700;
    color: inherit;
}

    .cfh-spot-value.pos { color: var(--cfh-green); }
    .cfh-spot-value.neg { color: var(--cfh-red); }

.cfh-spot-sub {
    font-size: .76rem;
    color: var(--cfh-muted);
}

.cfh-chev {
    margin-left: auto;
    color: var(--cfh-muted-2);
}

/* ---- MAIN GRID ------------------------------------------- */
.cfh-main {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 1.1rem;
}

@media (max-width: 1180px) {
    .cfh-main { grid-template-columns: 1fr; }
}

.cfh-content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* ---- SECTION GROUPS -------------------------------------- */
.cfh-section {
    background: transparent;
}

.cfh-section-head {
    display: flex;
    align-items: center;
    gap: .65rem;
    margin: .25rem .15rem .55rem;
}

.cfh-section-eyebrow {
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--cfh-blue);
    flex: 1;
}

.cfh-section-link {
    font-size: .78rem;
    color: var(--cfh-blue);
    text-decoration: none;
    font-weight: 600;
}

    .cfh-section-link:hover { text-decoration: underline; }

.cfh-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(245px,1fr));
    gap: .7rem;
}

.cfh-tile {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto auto;
    grid-template-areas: "icon title arrow" "icon meta arrow";
    column-gap: .85rem;
    row-gap: .15rem;
    padding: .85rem .95rem;
    background: var(--cfh-card);
    border: 1px solid var(--cfh-border);
    border-radius: var(--cfh-radius);
    text-decoration: none;
    color: inherit;
    box-shadow: var(--cfh-shadow-sm);
    transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

    .cfh-tile:hover {
        transform: translateY(-2px);
        border-color: var(--cfh-blue);
        box-shadow: var(--cfh-shadow);
    }

.cfh-tile-icon {
    grid-area: icon;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1rem;
    align-self: center;
}

.cfh-tile-title {
    grid-area: title;
    font-size: .92rem;
    font-weight: 600;
    color: var(--cfh-text);
    line-height: 1.2;
}

.cfh-tile-meta {
    grid-area: meta;
    font-size: .76rem;
    color: var(--cfh-muted);
    line-height: 1.3;
    display: flex;
    align-items: center;
    gap: .35rem;
}

    .cfh-tile-meta .v {
        color: var(--cfh-text);
        font-weight: 600;
    }

        .cfh-tile-meta .v.pos { color: var(--cfh-green); }
        .cfh-tile-meta .v.neg { color: var(--cfh-red); }
        .cfh-tile-meta .v.warn { color: var(--cfh-amber); }

.cfh-tile-arrow {
    grid-area: arrow;
    align-self: center;
    color: var(--cfh-muted-2);
    font-size: .8rem;
    transition: transform .15s ease, color .15s ease;
}

.cfh-tile:hover .cfh-tile-arrow {
    color: var(--cfh-blue);
    transform: translateX(3px);
}

/* ---- SIDEBAR --------------------------------------------- */
.cfh-side {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.cfh-card {
    background: var(--cfh-card);
    border: 1px solid var(--cfh-border);
    border-radius: var(--cfh-radius);
    padding: 1rem 1.1rem;
    box-shadow: var(--cfh-shadow-sm);
}

.cfh-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 0 .75rem;
}

    .cfh-card-head h3 {
        margin: 0;
        font-size: .68rem;
        font-weight: 800;
        letter-spacing: .12em;
        text-transform: uppercase;
        color: var(--cfh-muted);
    }

.cfh-card-counter {
    background: var(--cfh-blue-soft);
    color: var(--cfh-blue);
    padding: .15rem .5rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
}

/* Workflow steps */
.cfh-flow {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .55rem;
}

    .cfh-flow li {
        display: flex;
        align-items: center;
        gap: .75rem;
        padding: .55rem .65rem;
        border-radius: 10px;
        background: #f8fafc;
        border: 1px solid var(--cfh-border);
        transition: background .15s ease;
    }

        .cfh-flow li:hover { background: var(--cfh-blue-soft); }

.cfh-flow-num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--cfh-blue);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .82rem;
    flex-shrink: 0;
}

.cfh-flow-body {
    flex: 1;
    min-width: 0;
}

    .cfh-flow-body b {
        display: block;
        font-size: .85rem;
        color: var(--cfh-text);
    }

    .cfh-flow-body span {
        font-size: .73rem;
        color: var(--cfh-muted);
    }

.cfh-flow-go {
    color: var(--cfh-muted-2);
    font-size: .8rem;
}

/* AI list */
.cfh-ai {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .65rem;
}

    .cfh-ai li {
        display: flex;
        gap: .65rem;
        align-items: flex-start;
    }

.cfh-ai-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    color: #fff;
}

.cfh-ai-body b {
    display: block;
    font-size: .82rem;
    color: var(--cfh-text);
    line-height: 1.3;
}

.cfh-ai-body span {
    font-size: .74rem;
    color: var(--cfh-muted);
    line-height: 1.3;
}

/* Task list */
.cfh-tasks {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .45rem;
}

    .cfh-tasks li {
        display: flex;
        align-items: center;
        gap: .5rem;
        font-size: .82rem;
        color: var(--cfh-text);
    }

    .cfh-tasks .dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        flex-shrink: 0;
    }

.cfh-tasks .dot.red { background: var(--cfh-red); }
.cfh-tasks .dot.amber { background: var(--cfh-amber); }
.cfh-tasks .dot.green { background: var(--cfh-green); }

.cfh-tasks .v {
    margin-left: auto;
    font-weight: 700;
    color: var(--cfh-muted);
}

/* Memo timeline */
.cfh-memo {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

    .cfh-memo li {
        display: grid;
        grid-template-columns: 60px 1fr auto;
        gap: .6rem;
        align-items: center;
        padding: .45rem .55rem;
        border-radius: 8px;
        background: #f8fafc;
        font-size: .8rem;
    }

.cfh-memo-date {
    color: var(--cfh-muted);
    font-weight: 600;
    font-size: .74rem;
}

.cfh-memo-title {
    color: var(--cfh-text);
    font-weight: 600;
}

.cfh-memo-amount {
    font-weight: 700;
    font-size: .82rem;
}

    .cfh-memo-amount.pos { color: var(--cfh-green); }
    .cfh-memo-amount.neg { color: var(--cfh-red); }

/* Empty state inside side cards */
.cfh-empty {
    color: var(--cfh-muted);
    font-size: .8rem;
    text-align: center;
    padding: .75rem 0;
}

/* ---- FOOTER ---------------------------------------------- */
.cfh-footer {
    margin-top: 1.5rem;
    padding: 1rem 1.25rem;
    background: var(--cfh-card);
    border: 1px solid var(--cfh-border);
    border-radius: var(--cfh-radius);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    color: var(--cfh-muted);
    font-size: .8rem;
}

.cfh-footer .tag {
    color: var(--cfh-blue);
    font-weight: 600;
}
