/* ==========================================================
   Horus product UI mocks — used in both directions
   Realistic-feeling but compact dashboard previews
   ========================================================== */

.app-frame { background: #fff; border-radius: 14px; box-shadow: var(--shadow-xl); overflow: hidden; border: 1px solid var(--border-subtle); position: relative; }
.app-frame.dark { background: #0E1322; border-color: rgba(255,255,255,0.06); }

.app-titlebar { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--neutral-50); border-bottom: 1px solid var(--border-subtle); }
.app-frame.dark .app-titlebar { background: #161C2E; border-color: rgba(255,255,255,0.06); }
.app-titlebar .dots { display: flex; gap: 6px; }
.app-titlebar .dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--neutral-300); }
.app-titlebar .dots span:nth-child(1) { background: #FF5F57; }
.app-titlebar .dots span:nth-child(2) { background: #FEBC2E; }
.app-titlebar .dots span:nth-child(3) { background: #28C840; }
.app-titlebar .url { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); flex: 1; text-align: center; padding: 4px 12px; background: #fff; border-radius: 6px; border: 1px solid var(--border-subtle); }
.app-frame.dark .app-titlebar .url { background: #0E1322; border-color: rgba(255,255,255,0.08); color: rgba(255,255,255,0.5); }

.app-shell { display: grid; grid-template-columns: 200px 1fr; min-height: 0; }
.app-sidebar { background: var(--neutral-900); color: rgba(255,255,255,0.85); padding: 18px 14px; display: flex; flex-direction: column; gap: 4px; }
.app-sidebar .brand { display: flex; align-items: center; gap: 8px; padding: 4px 8px 16px; }
.app-sidebar .brand .mark { width: 22px; height: 22px; border-radius: 50%; background: var(--horus-indigo); position: relative; }
.app-sidebar .brand .mark::after { content:''; position:absolute; inset: 6px; background: #fff; border-radius: 50%; }
.app-sidebar .brand .nm { font-weight: 700; font-size: 14px; letter-spacing: -0.01em; }
.app-sidebar .group { font-family: var(--font-mono); font-size: 9px; color: rgba(255,255,255,0.35); letter-spacing: 0.08em; text-transform: uppercase; padding: 12px 8px 4px; }
.app-sidebar .item { display: flex; align-items: center; gap: 10px; padding: 7px 8px; border-radius: 6px; font-size: 12px; cursor: pointer; color: rgba(255,255,255,0.7); }
.app-sidebar .item.active { background: rgba(255,255,255,0.08); color: #fff; font-weight: 500; }
.app-sidebar .item .ic { width: 14px; height: 14px; border-radius: 3px; background: rgba(255,255,255,0.2); flex-shrink: 0; }
.app-sidebar .item.active .ic { background: var(--horus-lavender); }

.app-main { padding: 18px 22px; background: var(--neutral-50); overflow: hidden; }
.app-frame.dark .app-main { background: #0E1322; color: rgba(255,255,255,0.9); }

.app-topbar { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid var(--border-subtle); margin-bottom: 16px; }
.app-frame.dark .app-topbar { border-color: rgba(255,255,255,0.08); }
.app-topbar .crumb { font-size: 12px; color: var(--fg-3); }
.app-topbar h2 { margin: 4px 0 0; font-size: 18px; font-weight: 700; letter-spacing: -0.01em; color: var(--fg-1); }
.app-frame.dark .app-topbar h2 { color: #fff; }
.app-topbar .controls { display: flex; gap: 6px; }
.app-topbar .pill { font-size: 11px; padding: 5px 10px; border-radius: 999px; background: #fff; border: 1px solid var(--border-subtle); color: var(--fg-2); font-weight: 500; }
.app-topbar .pill.active { background: var(--neutral-900); color: #fff; border-color: var(--neutral-900); }
.app-frame.dark .app-topbar .pill { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.08); color: rgba(255,255,255,0.8); }
.app-frame.dark .app-topbar .pill.active { background: var(--horus-indigo); border-color: var(--horus-indigo); }

/* KPI strip */
.kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 14px; }
.kpi { background: #fff; border: 1px solid var(--border-subtle); border-radius: 10px; padding: 12px; }
.app-frame.dark .kpi { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.kpi .label { font-size: 10px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.05em; font-family: var(--font-mono); }
.app-frame.dark .kpi .label { color: rgba(255,255,255,0.5); }
.kpi .value { font-family: var(--font-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin-top: 4px; font-variant-numeric: tabular-nums; }
.kpi .delta { font-size: 11px; font-family: var(--font-mono); margin-top: 2px; font-variant-numeric: tabular-nums; }
.kpi .delta.pos { color: var(--positive); }
.kpi .delta.neg { color: var(--negative); }

/* Forecast chart */
.fc-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 10px; padding: 14px 16px; margin-bottom: 12px; }
.app-frame.dark .fc-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.fc-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.fc-head h3 { margin: 0; font-size: 13px; font-weight: 600; color: var(--fg-1); }
.app-frame.dark .fc-head h3 { color: #fff; }
.fc-head .legend { display: flex; gap: 12px; font-size: 10px; color: var(--fg-3); font-family: var(--font-mono); }
.fc-head .legend i { width: 8px; height: 2px; display: inline-block; vertical-align: middle; margin-right: 4px; background: var(--horus-indigo); }
.fc-head .legend .actual i { background: var(--neutral-900); }
.app-frame.dark .fc-head .legend .actual i { background: #fff; }
.fc-head .legend .scenario i { background: var(--horus-lavender); border-top: 1px dashed var(--horus-indigo); height:1px; }

.fc-chart { position: relative; height: 130px; }
.fc-chart svg { width: 100%; height: 100%; display: block; }

/* Table */
.tbl { width: 100%; border-collapse: collapse; font-size: 11px; }
.tbl th, .tbl td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border-subtle); }
.app-frame.dark .tbl th, .app-frame.dark .tbl td { border-color: rgba(255,255,255,0.06); }
.tbl th { font-family: var(--font-mono); font-weight: 500; color: var(--fg-3); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase; }
.tbl td { font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--fg-1); }
.app-frame.dark .tbl td { color: rgba(255,255,255,0.9); }
.tbl td.label { font-family: var(--font-display); font-weight: 500; }
.tbl td.pos { color: var(--positive); }
.tbl td.neg { color: var(--negative); }
.tbl tr:last-child td { border-bottom: none; }

/* Variance bars in-row */
.var-bar { position: relative; height: 14px; background: var(--neutral-100); border-radius: 3px; min-width: 80px; }
.app-frame.dark .var-bar { background: rgba(255,255,255,0.06); }
.var-bar::before { content:''; position:absolute; left:50%; top:-2px; bottom:-2px; width:1px; background: var(--neutral-300); }
.app-frame.dark .var-bar::before { background: rgba(255,255,255,0.2); }
.var-bar > span { position: absolute; top: 1px; bottom: 1px; border-radius: 2px; }
.var-bar > span.p { left: 50%; background: var(--positive); }
.var-bar > span.n { right: 50%; background: var(--negative); }

/* Scenario list */
.scn-list { display: flex; flex-direction: column; gap: 6px; }
.scn-row { display: grid; grid-template-columns: 12px 1fr auto auto; gap: 10px; align-items: center; padding: 8px 10px; background: #fff; border: 1px solid var(--border-subtle); border-radius: 8px; font-size: 11px; }
.app-frame.dark .scn-row { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.scn-row.active { border-color: var(--horus-indigo); box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }
.scn-row .dot { width: 8px; height: 8px; border-radius: 50%; }
.scn-row .nm { font-weight: 500; color: var(--fg-1); }
.app-frame.dark .scn-row .nm { color: #fff; }
.scn-row .bar { width: 90px; height: 4px; background: var(--neutral-200); border-radius: 999px; overflow: hidden; }
.app-frame.dark .scn-row .bar { background: rgba(255,255,255,0.1); }
.scn-row .bar > i { display: block; height: 100%; background: var(--horus-indigo); border-radius: 999px; }
.scn-row .v { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 11px; color: var(--fg-2); }
.app-frame.dark .scn-row .v { color: rgba(255,255,255,0.8); }
