/* ============================================================
   Finance Intelligence Portal — Styles
   ============================================================ */

.fi-portal { display:flex; flex-direction:column; gap:18px; }

.fi-hero {
    display:flex; justify-content:space-between; align-items:center;
    gap:16px; flex-wrap:wrap;
    padding:18px 22px;
    background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 60%,#0891b2 100%);
    color:#fff;
    border-radius:18px;
    box-shadow:0 6px 24px rgba(8,145,178,.20);
}
.fi-hero-left { display:flex; gap:14px; align-items:center; }
.fi-hero-icon { width:54px; height:54px; border-radius:14px; background:rgba(255,255,255,.12);
                display:grid; place-items:center; font-size:22px; backdrop-filter: blur(10px); }
.fi-hero h1 { margin:0; font-size:24px; font-weight:700; }
.fi-hero p  { margin:4px 0 0; font-size:13px; opacity:.85; }
.fi-hero-actions { display:flex; gap:8px; flex-wrap:wrap; }
.fi-hero-actions .btn { background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.18); }
.fi-hero-actions .btn:hover { background:rgba(255,255,255,.22); }

/* Tile nav */
.fi-tiles { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:12px; }
.fi-tile {
    display:flex; gap:12px; align-items:center; padding:14px 16px;
    background:var(--bg-card,#fff); border:1px solid var(--border-color,#e5e7eb);
    border-radius:14px; cursor:pointer; text-align:left;
    transition:all .15s; font-family:inherit; color:inherit;
}
.fi-tile i { font-size:22px; color:#0891b2; flex-shrink:0; }
.fi-tile div { display:flex; flex-direction:column; min-width:0; }
.fi-tile strong { font-size:13.5px; }
.fi-tile span { font-size:11.5px; color:var(--text-muted); margin-top:2px; }
.fi-tile-active { border-color:#0891b2; box-shadow:0 4px 12px rgba(8,145,178,.15); background:rgba(8,145,178,.04); }
.fi-tile-soon { opacity:.55; cursor:not-allowed; }

[data-theme="dark"] .fi-tile { background:#1a1d24; border-color:rgba(255,255,255,.08); }

/* KPI row */
.fi-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:12px; }
.fi-kpi  { background:var(--bg-card,#fff); border:1px solid var(--border-color,#e5e7eb);
           border-radius:14px; padding:14px 16px;
           display:flex; flex-direction:column; gap:4px; position:relative; overflow:hidden; }
.fi-kpi-icon { position:absolute; top:10px; right:12px; font-size:24px; opacity:.10; }
.fi-kpi-label { font-size:11.5px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.04em; font-weight:600; }
.fi-kpi-value { font-size:24px; font-weight:700; color:var(--text-primary); display:flex; align-items:baseline; gap:6px; }
.fi-kpi-value small { font-size:11px; font-weight:500; color:var(--text-muted); }
.fi-kpi-foot { font-size:11px; color:var(--text-muted); margin-top:2px; }
.fi-kpi-margin .fi-kpi-icon { color:#16a34a; }
.fi-kpi-cost   .fi-kpi-icon { color:#F5A623; }
.fi-kpi-commit .fi-kpi-icon { color:#7c3aed; }
.fi-kpi-anom   .fi-kpi-icon { color:#dc2626; }

[data-theme="dark"] .fi-kpi { background:#1a1d24; border-color:rgba(255,255,255,.08); }

/* Grid of cards */
.fi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(380px,1fr)); gap:14px; }
.fi-card { background:var(--bg-card,#fff); border:1px solid var(--border-color,#e5e7eb);
           border-radius:14px; padding:16px 18px; }
.fi-card h3 { margin:0 0 12px; font-size:14.5px; font-weight:700; display:flex; gap:8px; align-items:center; }
.fi-card h3 i { color:#0891b2; }

[data-theme="dark"] .fi-card { background:#1a1d24; border-color:rgba(255,255,255,.08); }

.fi-tbl { width:100%; border-collapse:collapse; font-size:12.5px; }
.fi-tbl th, .fi-tbl td { padding:8px 10px; text-align:left; border-bottom:1px solid var(--border-color,#f1f5f9); }
.fi-tbl th { font-weight:600; font-size:11.5px; color:var(--text-muted); text-transform:uppercase; }
.fi-tbl tr:last-child td { border-bottom:0; }

.fi-chip { display:inline-block; padding:2px 8px; border-radius:999px; font-size:11px; font-weight:600; }
.fi-chip-red   { background:rgba(220,38,38,.12); color:#991b1b; }
.fi-chip-amber { background:rgba(245,166,35,.15); color:#b45309; }
.fi-chip-green { background:rgba(22,163,74,.12); color:#15803d; }
.fi-chip-grey  { background:rgba(100,116,139,.12); color:#475569; }

.fi-empty { padding:24px; text-align:center; color:var(--text-muted); font-size:13px; }

/* Cost mix viz */
.fi-mix { display:flex; flex-direction:column; gap:6px; }
.fi-mix-row { display:flex; gap:8px; align-items:center; font-size:12.5px; }
.fi-mix-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.fi-mix-label { width:110px; flex-shrink:0; }
.fi-mix-bar { flex:1; height:8px; background:rgba(0,0,0,.05); border-radius:4px; overflow:hidden; }
.fi-mix-bar span { display:block; height:100%; border-radius:4px; }
.fi-mix-val { width:110px; text-align:right; font-weight:600; }
.fi-mix-val small { color:var(--text-muted); font-weight:400; }

[data-theme="dark"] .fi-mix-bar { background:rgba(255,255,255,.06); }

/* Concentration */
.fi-conc { display:flex; flex-direction:column; gap:8px; }
.fi-conc-row { display:flex; gap:10px; align-items:center; }
.fi-conc-name { width:160px; font-size:12.5px; }
.fi-conc-name small { color:var(--text-muted); font-size:11px; }
.fi-conc-bar { flex:1; height:18px; background:rgba(0,0,0,.05); border-radius:4px; position:relative; }
.fi-conc-fill { height:100%; background:linear-gradient(90deg,#0891b2,#7c3aed); border-radius:4px; }
.fi-conc-bar span { position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:11px; font-weight:600; }

[data-theme="dark"] .fi-conc-bar { background:rgba(255,255,255,.06); }

/* Anomalies */
.fi-anom { display:flex; flex-direction:column; gap:6px; }
.fi-anom-row { display:flex; gap:10px; align-items:center; padding:8px 10px; background:rgba(0,0,0,.02); border-radius:8px; }
.fi-anom-row.on { background:rgba(220,38,38,.07); }
.fi-anom-count { font-size:18px; font-weight:700; width:34px; text-align:center; }
.fi-anom-row.on .fi-anom-count { color:#dc2626; }

[data-theme="dark"] .fi-anom-row { background:rgba(255,255,255,.03); }

/* Landed cost modal */
.fi-lc-summary { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.fi-lc-tile { padding:14px 12px; border-radius:12px; background:rgba(8,145,178,.06); text-align:center; }
.fi-lc-tile span { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.03em; display:block; margin-bottom:4px; }
.fi-lc-tile strong { font-size:20px; font-weight:700; }
.fi-lc-final { background:linear-gradient(135deg,#0891b2,#7c3aed); color:#fff; }
.fi-lc-final span { color:rgba(255,255,255,.85); }

@media (max-width:600px) {
    .fi-lc-summary { grid-template-columns:1fr 1fr; }
    .fi-mix-label, .fi-mix-val { width:auto; }
}

/* Cost allocation modal */
.ca-keys { display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:8px; }
.ca-key { display:flex; flex-direction:column; gap:4px; padding:10px 12px;
          border:1px solid var(--border-color,#e5e7eb); border-radius:10px;
          cursor:pointer; transition:all .15s; }
.ca-key:hover { border-color:#7c3aed; background:rgba(124,58,237,.04); }
.ca-key.on { border-color:#7c3aed; background:rgba(124,58,237,.08); }
.ca-key i { color:#7c3aed; font-size:16px; }
.ca-key strong { font-size:12.5px; }
.ca-key small { font-size:11px; color:var(--text-muted); line-height:1.35; }

.ca-pos { display:flex; flex-direction:column; gap:4px; max-height:200px; overflow:auto;
          border:1px solid var(--border-color,#e5e7eb); border-radius:10px; padding:6px;
          margin-top:6px; }
.ca-po { display:flex; gap:8px; align-items:center; padding:6px 8px; border-radius:6px;
         cursor:pointer; font-size:12.5px; }
.ca-po:hover { background:rgba(124,58,237,.05); }

.ca-prev-head { display:flex; justify-content:space-between; padding:8px 12px;
                background:rgba(124,58,237,.06); border-radius:8px; font-size:13px;
                margin-bottom:6px; }
.ca-prev-tbl { background:var(--bg-card,#fff); }

[data-theme="dark"] .ca-key, [data-theme="dark"] .ca-pos { border-color:rgba(255,255,255,.1); }

.text-red   { color:#dc2626 !important; }
.text-amber { color:#b45309 !important; }
.text-green { color:#15803d !important; }
