/* ======= Design tokens ======= */
:root{
  /* Surfaces & text */
  --bg: #0b0f14; --text:#e5e7eb; --muted:#a5b4c3;
  --text-labels: var(--text);
  --text-forms: var(--text);
  --card:#0f172a; --border:#1f2a44; --badge:#0b1220;

  /* Accent trio (will be derived from --accent-hue via JS) */
  --accent-hue: 260;
  --accent:  oklch(60% .22 calc(var(--accent-hue)*1deg));
  --accent-2:oklch(56% .22 calc(var(--accent-hue)*1deg));
  --accent-3:oklch(72% .22 calc(var(--accent-hue)*1deg));

  /* Status */
  --ok:#22c55e; --near:#06b6d4; --warn:#f59e0b; --err:#ef4444;
  --ok-bg:   color-mix(in oklab, var(--ok) var(--row-tint,16%), transparent);
  --near-bg: color-mix(in oklab, var(--near) var(--row-tint,18%), transparent);
  --warn-bg: color-mix(in oklab, var(--warn) var(--row-tint,16%), transparent);
  --err-bg:  color-mix(in oklab, var(--err) var(--row-tint,16%), transparent);

  /* Dashboard metric tokens (kept stable across themes) */
  --dash-metric-base: rgba(46, 57, 88, 0.9);
  --dash-metric-1-start: rgba(82, 131, 255, 0.25);
  --dash-metric-1-end:   rgba(28, 42, 88, 0.75);
  --dash-metric-2-start: rgba(54, 211, 153, 0.25);
  --dash-metric-2-end:   rgba(19, 58, 48, 0.75);
  --dash-metric-3-start: rgba(214, 116, 178, 0.28);
  --dash-metric-3-end:   rgba(68, 32, 59, 0.8);
  --dash-metric-4-start: rgba(248, 204, 42, 0.3);
  --dash-metric-4-end:   rgba(74, 54, 14, 0.78);

  /* Dashboard tools (Settings/Helper) tokens */
  --dash-tools-bg: rgba(14, 18, 32, 0.94);
  --dash-tools-border: rgba(90, 124, 210, 0.22);
  --dash-tools-inset: rgba(255, 255, 255, 0.05);

  /* Unified surfaces */
  --surface: color-mix(in oklab, var(--card) 94%, transparent);
  --surface-strong: color-mix(in oklab, var(--card) 98%, transparent);
  --surface-subtle: color-mix(in oklab, var(--card) 90%, transparent);
  --surface-hover: color-mix(in oklab, var(--accent) 18%, transparent);
  --stripe-1: color-mix(in oklab, var(--card) 96%, transparent);
  --stripe-2: color-mix(in oklab, var(--card) 98%, transparent);
  --overlay: color-mix(in oklab, var(--card) 80%, transparent);
  --border-strong: color-mix(in oklab, var(--border) 70%, transparent);
  /* Input tokens */
  --input-bg: rgba(6, 10, 20, 0.94);
  --input-border: rgba(255, 255, 255, 0.09);
  --input-border-hover: rgba(255, 255, 255, 0.14);
  --input-border-focus: rgba(255, 255, 255, 0.4);
  --input-focus-ring: rgba(255, 255, 255, 0.18);
  --input-accent: var(--accent);
  --input-text: #e5e8ff;
  --input-placeholder: rgba(229,232,255,0.55);
  --input-shadow: rgba(80,144,255,0.25);
  --drop-border: color-mix(in oklab, var(--input-accent) 70%, transparent);
  --drop-border-hover: color-mix(in oklab, var(--input-accent) 90%, transparent);
  --drop-bg: var(--input-bg);
  --drop-bg-hover: color-mix(in oklab, var(--input-bg) 85%, #000 15%);
  /* Table tokens */
  --table-bg: #0b1122;
  --table-header-bg: #1fab66;
  --table-border: rgba(255, 255, 255, 0.12);
  --table-text: rgba(223, 230, 255, 0.9);
  --table-header-text: #0a0f18;
  --table-stripe-odd: #0b1122;
  --table-stripe-even: #0a0e1b;
  /* Hero strip tokens */
  --hero-bg: linear-gradient(90deg, #0b0f1a 0%, #1a1c2b 50%, #0b0f1a 100%);
  --hero-border: rgba(255, 255, 255, 0.08);
  --hero-shadow: 0 12px 36px rgba(0, 0, 0, 0.32);
  --hero-metrics-bg: rgba(255, 255, 255, 0.04);
  --hero-metrics-border: rgba(255, 255, 255, 0.08);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  --hero-label: var(--muted);
  --hero-value: var(--text);
  --hero-delta: var(--muted);
  --hero-search-bg: rgba(0, 0, 0, 0.25);
  --hero-search-border: rgba(255, 255, 255, 0.12);
  --hero-search-text: var(--text);
  --hero-search-placeholder: var(--muted);
  --hero-search-btn-bg: linear-gradient(120deg, #2f8dff, #1c64f2);
  --hero-search-btn-border: rgba(76, 132, 255, 0.5);
  --hero-search-btn-text: #ffffff;
  --hero-search-btn-shadow: 0 10px 24px rgba(44, 120, 255, 0.25);
  --hero-search-btn-shadow-hover: 0 14px 30px rgba(44, 120, 255, 0.28);

  /* Depth */
  --radius:16px; --radius-sm:10px;
  --shadow-amb: 0 12px 24px rgba(0,0,0,.22);
  --shadow-key: 0  2px  6px rgba(0,0,0,.24);
  --shadow-hov: 0 16px 40px rgba(0,0,0,.28);

  --focus-ring: 0 0 0 3px color-mix(in oklab, var(--accent) 60%, transparent);

  /* Fluid type scale */
  --step--1: clamp(12px, 0.75vw + 9px, 13px);
  --step-0 : clamp(13px, 0.80vw + 10px, 14px);
  --step-1 : clamp(15px, 1.0vw + 12px, 16px);
  --step-2 : clamp(18px, 1.2vw + 14px, 20px);
  --step-3 : clamp(22px, 1.6vw + 16px, 24px);

  /* Workspace banner */
  --workspace-bg-start: rgba(247, 250, 255, 0.96);
  --workspace-bg-end: rgba(255, 255, 255, 0.86);
  --workspace-border: rgba(120, 170, 255, 0.42);
  --workspace-shadow: 0 24px 44px rgba(15, 30, 80, 0.18);
  --workspace-seg-bg: rgba(255, 255, 255, 0.88);
  --workspace-seg-border: rgba(120, 170, 255, 0.48);
  --workspace-chip-bg: rgba(247, 250, 255, 0.82);
  --workspace-chip-border: rgba(120, 170, 255, 0.52);
  --workspace-chip-text: #1a4ed8;
  --workspace-chip-shadow: 0 16px 32px rgba(36, 64, 120, 0.22);
  --workspace-chip-bg-hover: rgba(255, 255, 255, 0.95);
  --workspace-chip-border-hover: rgba(120, 170, 255, 0.72);
  --workspace-chip-shadow-hover: 0 22px 40px rgba(40, 70, 130, 0.28);
  --workspace-chip-shadow-active: 0 16px 28px rgba(40, 70, 120, 0.22);

  --status-pill-fg: #3a8bff;
  --status-pill-bg: #1f2937;
  --status-pill-border: #334155;
}

body.theme-default{
  --bg:#0b0f14;
  background:
    radial-gradient(60% 60% at 15% 20%, rgba(37,99,235,0.12), transparent),
    radial-gradient(45% 55% at 80% 0%, rgba(236,72,153,0.06), transparent),
    #05070f;
}
body.theme-canvas{
  --bg:#04070f;
  background:
    radial-gradient(circle at 20% 20%, rgba(56,189,248,0.18), transparent 35%),
    radial-gradient(circle at 75% 10%, rgba(248,113,113,0.22), transparent 40%),
    radial-gradient(circle at 80% 65%, rgba(168,85,247,0.18), transparent 55%),
    linear-gradient(120deg, rgba(2,6,23,0.9), rgba(15,23,42,0.8) 55%, rgba(2,6,23,0.92));
  background-attachment: fixed;
}
body.theme-nebula{
  --bg:#050510;
  background:
    radial-gradient(circle at 25% 75%, rgba(34,197,94,0.18), transparent 45%),
    radial-gradient(circle at 70% 30%, rgba(56,189,248,0.16), transparent 50%),
    radial-gradient(circle at 90% 80%, rgba(244,114,182,0.18), transparent 45%),
    linear-gradient(135deg, rgba(3,7,18,0.95), rgba(6,9,24,0.9));
  background-attachment: fixed;
}
body.theme-aurora{
  --bg:#040515;
  background:
    radial-gradient(circle at 15% 20%, rgba(59,203,255,0.28), transparent 40%),
    radial-gradient(circle at 80% 10%, rgba(191,108,255,0.18), transparent 45%),
    linear-gradient(135deg, #030711 0%, #041b33 55%, #05010e 100%);
  background-attachment: fixed;
}
body.theme-dusk{
  --bg:#120411;
  background:
    radial-gradient(circle at 10% 80%, rgba(255,184,108,0.2), transparent 40%),
    radial-gradient(circle at 90% 20%, rgba(187,104,255,0.25), transparent 50%),
    linear-gradient(120deg, #120217, #320a24, #1d0730);
  background-attachment: fixed;
}
body.theme-midnight{
  --bg:#020409;
  background:
    radial-gradient(circle at 80% 10%, rgba(61,130,255,0.2), transparent 45%),
    radial-gradient(circle at 15% 85%, rgba(99,229,255,0.12), transparent 40%),
    linear-gradient(160deg, #010308, #030816 60%, #010204);
  background-attachment: fixed;
}
body.theme-forest{
  --bg:#050d07;
  background:
    radial-gradient(circle at 20% 30%, rgba(34,197,94,0.2), transparent 45%),
    radial-gradient(circle at 80% 75%, rgba(16,185,129,0.18), transparent 50%),
    linear-gradient(140deg, #031107, #051c10 55%, #031006);
  background-attachment: fixed;
}
body.theme-ocean{
  --bg:#021119;
  background:
    radial-gradient(circle at 18% 25%, rgba(12,192,255,0.26), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(14,165,233,0.18), transparent 50%),
    linear-gradient(150deg, #01060b, #031b2c 60%, #010e17);
  background-attachment: fixed;
}
body.theme-ember{
  --bg:#140502;
  background:
    radial-gradient(circle at 75% 15%, rgba(255,140,66,0.25), transparent 45%),
    radial-gradient(circle at 15% 85%, rgba(244,63,94,0.2), transparent 50%),
    linear-gradient(145deg, #090100, #2a0705 55%, #0c0200);
  background-attachment: fixed;
}
body.theme-copper{
  --bg:#130a04;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,176,124,0.22), transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(255,116,81,0.16), transparent 55%),
    linear-gradient(120deg, #120701, #2c1405 60%, #110400);
  background-attachment: fixed;
}
body.theme-monochrome{
  --bg:#060606;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.08), transparent 35%),
    radial-gradient(circle at 80% 80%, rgba(255,255,255,0.06), transparent 45%),
    linear-gradient(135deg, #010101, #101010 60%, #050505);
  background-attachment: fixed;
}
body.theme-slate{
  --bg:#070910;
  background:
    radial-gradient(circle at 25% 30%, rgba(148,163,184,0.22), transparent 45%),
    radial-gradient(circle at 80% 60%, rgba(96,165,250,0.16), transparent 50%),
    linear-gradient(150deg, #05070d, #0e1724 65%, #05070d);
  background-attachment: fixed;
}
body.theme-neon{
  --bg:#050010;
  background:
    radial-gradient(circle at 20% 20%, rgba(0,255,196,0.28), transparent 40%),
    radial-gradient(circle at 80% 10%, rgba(255,0,184,0.2), transparent 45%),
    linear-gradient(135deg, #05000d, #150033 60%, #05000d);
  background-attachment: fixed;
}
body.theme-sandstorm{
  --bg:#130d04;
  background:
    radial-gradient(circle at 25% 70%, rgba(255,213,128,0.25), transparent 45%),
    radial-gradient(circle at 80% 25%, rgba(255,170,92,0.18), transparent 50%),
    linear-gradient(145deg, #120b03, #3b2507 60%, #120b03);
  background-attachment: fixed;
}
body.theme-velvet{
  --bg:#0c020a;
  background:
    radial-gradient(circle at 30% 20%, rgba(233,76,161,0.28), transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(141,78,255,0.2), transparent 50%),
    linear-gradient(135deg, #080107, #2a0225 65%, #080107);
  background-attachment: fixed;
}
body.theme-frost{
  --bg:#02070d;
  background:
    radial-gradient(circle at 20% 80%, rgba(145,205,255,0.24), transparent 45%),
    radial-gradient(circle at 85% 20%, rgba(191,219,254,0.2), transparent 50%),
    linear-gradient(150deg, #01040a, #0a1c2a 60%, #01040a);
  background-attachment: fixed;
}
body.theme-white{
  --bg:#f8fafc;
  --text:#0f172a;
  --muted:#475569;
  background: linear-gradient(180deg, #ffffff, #f4f6fb);
  color:var(--text);
}
body.theme-white-bg{
  background: linear-gradient(180deg, #ffffff, #f4f6fb);
}

body.theme-white-bg .app-header-title{
  color: #0f172a;
  text-shadow: 0 1px 2px rgba(0,0,0,0.08);
}

/* Respect optional bold text weight */
.form-grid label,
.terms-form-grid label,
.dashboard-metric-label,
.dashboard-dev-sliders .label,
.nav-strip .nav-label,
.nav-strip button span,
.dashboard-spotlight-card .dashboard-spotlight-header .dashboard-heading,
.contracts-form-grid label,
.contracts-notes-label {
  font-weight: var(--text-weight, inherit);
}

/* Text theme propagation: keep common shells honoring --text/--muted */
body .card,
body .dashboard-card,
body .contracts-card,
body .po-recon-card,
body .marketplace-card,
body .panel,
body .contracts-form,
body .contracts-summary,
body .hero-min,
body .app-header,
body .nav-strip,
body .dashboard-spotlight-card,
body .form-grid label,
body .terms-form-grid label,
body .column-map-label,
body .dashboard-theme-select label,
body .contracts-form-grid label,
body .contracts-notes-label,
body .seats-plan-grid label,
body .seats-alloc-form label {
  color: var(--text-labels, var(--text-forms, var(--text)));
}

body .muted,
body .nav-label,
body .nav-strip .nav-mode button span,
body .nav-strip .nav-stack button span,
body .nav-strip .nav-dropdown-toggle span,
body .dashboard-spotlight-card .muted {
  color: var(--muted);
}

body .dashboard-dev-sliders .label{
  color: var(--muted);
}

/* Hero theme presets (background + search bar) */
body.hero-theme-default{
  --hero-bg: linear-gradient(90deg, #0b0f1a 0%, #1a1c2b 50%, #0b0f1a 100%);
  --hero-border: rgba(255, 255, 255, 0.08);
  --hero-shadow: 0 12px 36px rgba(0,0,0,0.32);
  --hero-metrics-bg: rgba(255,255,255,0.04);
  --hero-metrics-border: rgba(255,255,255,0.08);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: var(--muted);
  --hero-value: var(--text);
  --hero-delta: var(--muted);
  --hero-search-bg: rgba(0,0,0,0.25);
  --hero-search-border: rgba(255,255,255,0.12);
  --hero-search-text: var(--text);
  --hero-search-placeholder: var(--muted);
  --hero-search-btn-bg: linear-gradient(120deg, #2f8dff, #1c64f2);
  --hero-search-btn-border: rgba(76,132,255,0.5);
  --hero-search-btn-text: #ffffff;
  --hero-search-btn-shadow: 0 10px 24px rgba(44,120,255,0.25);
  --hero-search-btn-shadow-hover: 0 14px 30px rgba(44,120,255,0.28);
}

body.hero-theme-cobalt{
  --hero-bg: linear-gradient(115deg, #0a1226 0%, #11213f 52%, #0a1226 100%);
  --hero-border: rgba(126, 178, 255, 0.32);
  --hero-shadow: 0 14px 38px rgba(8, 18, 38, 0.45);
  --hero-metrics-bg: rgba(73, 133, 255, 0.10);
  --hero-metrics-border: rgba(126, 178, 255, 0.45);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: rgba(186, 206, 255, 0.82);
  --hero-value: #e9f1ff;
  --hero-delta: rgba(186, 206, 255, 0.82);
  --hero-search-bg: rgba(7, 16, 30, 0.9);
  --hero-search-border: rgba(126, 178, 255, 0.55);
  --hero-search-text: #e9f1ff;
  --hero-search-placeholder: rgba(186, 206, 255, 0.72);
  --hero-search-btn-bg: linear-gradient(120deg, #64b5ff, #2f7dff);
  --hero-search-btn-border: rgba(126,178,255,0.72);
  --hero-search-btn-text: #0b1226;
  --hero-search-btn-shadow: 0 12px 26px rgba(47,125,255,0.35);
  --hero-search-btn-shadow-hover: 0 16px 34px rgba(47,125,255,0.38);
}

body.hero-theme-emerald{
  --hero-bg: linear-gradient(115deg, #071512 0%, #0e2620 55%, #071512 100%);
  --hero-border: rgba(52, 211, 153, 0.28);
  --hero-shadow: 0 14px 34px rgba(4, 18, 14, 0.42);
  --hero-metrics-bg: rgba(52, 211, 153, 0.12);
  --hero-metrics-border: rgba(52, 211, 153, 0.38);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: rgba(191, 226, 208, 0.88);
  --hero-value: #e3f9ef;
  --hero-delta: rgba(191, 226, 208, 0.82);
  --hero-search-bg: rgba(5, 20, 16, 0.9);
  --hero-search-border: rgba(52, 211, 153, 0.42);
  --hero-search-text: #e3f9ef;
  --hero-search-placeholder: rgba(191, 226, 208, 0.76);
  --hero-search-btn-bg: linear-gradient(120deg, #34d399, #0ea472);
  --hero-search-btn-border: rgba(52,211,153,0.52);
  --hero-search-btn-text: #041410;
  --hero-search-btn-shadow: 0 12px 26px rgba(14,164,114,0.32);
  --hero-search-btn-shadow-hover: 0 16px 32px rgba(14,164,114,0.36);
}

body.hero-theme-amber{
  --hero-bg: linear-gradient(115deg, #1a0c06 0%, #2a130b 55%, #1a0c06 100%);
  --hero-border: rgba(245, 158, 11, 0.28);
  --hero-shadow: 0 14px 34px rgba(22, 8, 2, 0.44);
  --hero-metrics-bg: rgba(245, 158, 11, 0.12);
  --hero-metrics-border: rgba(245, 158, 11, 0.35);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: rgba(252, 235, 210, 0.78);
  --hero-value: #ffeede;
  --hero-delta: rgba(252, 235, 210, 0.78);
  --hero-search-bg: rgba(22, 10, 4, 0.9);
  --hero-search-border: rgba(245, 158, 11, 0.32);
  --hero-search-text: #ffeede;
  --hero-search-placeholder: rgba(252, 235, 210, 0.72);
  --hero-search-btn-bg: linear-gradient(120deg, #f59e0b, #d97706);
  --hero-search-btn-border: rgba(245, 158, 11, 0.45);
  --hero-search-btn-text: #1a0c06;
  --hero-search-btn-shadow: 0 12px 26px rgba(217, 119, 6, 0.32);
  --hero-search-btn-shadow-hover: 0 16px 32px rgba(217, 119, 6, 0.36);
}

body.hero-theme-orchid{
  --hero-bg: linear-gradient(115deg, #12071a 0%, #1f0f2c 55%, #12071a 100%);
  --hero-border: rgba(192, 132, 252, 0.28);
  --hero-shadow: 0 14px 38px rgba(10, 4, 18, 0.45);
  --hero-metrics-bg: rgba(192, 132, 252, 0.12);
  --hero-metrics-border: rgba(192, 132, 252, 0.35);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: rgba(236, 221, 255, 0.82);
  --hero-value: #f3e8ff;
  --hero-delta: rgba(236, 221, 255, 0.82);
  --hero-search-bg: rgba(14, 6, 20, 0.9);
  --hero-search-border: rgba(192, 132, 252, 0.45);
  --hero-search-text: #f3e8ff;
  --hero-search-placeholder: rgba(236, 221, 255, 0.76);
  --hero-search-btn-bg: linear-gradient(120deg, #c084fc, #8b5cf6);
  --hero-search-btn-border: rgba(192, 132, 252, 0.52);
  --hero-search-btn-text: #0f0616;
  --hero-search-btn-shadow: 0 12px 26px rgba(139, 92, 246, 0.32);
  --hero-search-btn-shadow-hover: 0 16px 32px rgba(139, 92, 246, 0.36);
}

body.hero-theme-frost{
  --hero-bg: linear-gradient(115deg, #0a111a 0%, #101a27 55%, #0a111a 100%);
  --hero-border: rgba(125, 211, 252, 0.30);
  --hero-shadow: 0 14px 34px rgba(6, 12, 20, 0.42);
  --hero-metrics-bg: rgba(125, 211, 252, 0.12);
  --hero-metrics-border: rgba(125, 211, 252, 0.40);
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  --hero-label: rgba(206, 230, 248, 0.86);
  --hero-value: #e6f4ff;
  --hero-delta: rgba(206, 230, 248, 0.82);
  --hero-search-bg: rgba(8, 16, 24, 0.92);
  --hero-search-border: rgba(125, 211, 252, 0.42);
  --hero-search-text: #e6f4ff;
  --hero-search-placeholder: rgba(206, 230, 248, 0.74);
  --hero-search-btn-bg: linear-gradient(120deg, #7dd3fc, #38bdf8);
  --hero-search-btn-border: rgba(125, 211, 252, 0.50);
  --hero-search-btn-text: #071220;
  --hero-search-btn-shadow: 0 12px 26px rgba(56, 189, 248, 0.32);
  --hero-search-btn-shadow-hover: 0 16px 32px rgba(56, 189, 248, 0.36);
}

body.hero-theme-light{
  --hero-bg: linear-gradient(115deg, #ffffff 0%, #f3f6fb 55%, #ffffff 100%);
  --hero-border: #d7dde7;
  --hero-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
  --hero-metrics-bg: #f8fafc;
  --hero-metrics-border: #d7dde7;
  --hero-metrics-shadow: inset 0 1px 0 rgba(255,255,255,0.85);
  --hero-label: #475569;
  --hero-value: #0f172a;
  --hero-delta: #475569;
  --hero-search-bg: #ffffff;
  --hero-search-border: #d7dde7;
  --hero-search-text: #0f172a;
  --hero-search-placeholder: #64748b;
  --hero-search-btn-bg: linear-gradient(120deg, #3b82f6, #2563eb);
  --hero-search-btn-border: rgba(37, 99, 235, 0.40);
  --hero-search-btn-text: #ffffff;
  --hero-search-btn-shadow: 0 10px 22px rgba(37, 99, 235, 0.22);
  --hero-search-btn-shadow-hover: 0 14px 28px rgba(37, 99, 235, 0.26);
}
body.theme-twilight{
  --bg:#0b0a14;
  background:
    radial-gradient(circle at 20% 20%, rgba(168,85,247,0.18), transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(59,130,246,0.18), transparent 40%),
    linear-gradient(145deg, #060515, #0d1022);
}
body.theme-celestial{
  --bg:#030814;
  background:
    radial-gradient(120% 95% at 8% 8%, rgba(94,234,212,0.22), transparent 72%),
    radial-gradient(110% 85% at 95% 10%, rgba(56,189,248,0.2), transparent 70%),
    radial-gradient(120% 95% at 88% 90%, rgba(168,85,247,0.18), transparent 72%),
    linear-gradient(180deg, #081226 0%, #050915 100%);
}
body.theme-evergreen{
  --bg:#07100c;
  background:
    radial-gradient(circle at 25% 75%, rgba(52,211,153,0.2), transparent 45%),
    radial-gradient(circle at 80% 25%, rgba(16,185,129,0.18), transparent 50%),
    linear-gradient(160deg, #06120d, #0a1c14 65%, #05100b);
}
body.theme-sunset{
  --bg:#12070a;
  background:
    radial-gradient(circle at 30% 30%, rgba(248,113,113,0.22), transparent 45%),
    radial-gradient(circle at 75% 65%, rgba(251,146,60,0.18), transparent 45%),
    linear-gradient(150deg, #0c0508, #1c0b0f 60%, #0c0508);
}
body.theme-glacier{
  --bg:#0a0f18;
  background:
    radial-gradient(circle at 20% 70%, rgba(125,211,252,0.22), transparent 45%),
    radial-gradient(circle at 80% 20%, rgba(14,165,233,0.18), transparent 50%),
    linear-gradient(155deg, #050912, #0e1624 60%, #050912);
}
body.theme-onyx{
  --bg:#0b0f14;
  background:
    radial-gradient(circle at 25% 25%, rgba(148,163,184,0.08), transparent 45%),
    linear-gradient(140deg, #05070d, #0e1724 65%, #05070d);
}
body.theme-honey{
  --bg:#130d04;
  background:
    radial-gradient(circle at 70% 20%, rgba(244,176,35,0.22), transparent 45%),
    radial-gradient(circle at 25% 75%, rgba(250,204,21,0.16), transparent 45%),
    linear-gradient(145deg, #0e0903, #1a1307 60%, #0e0903);
}
body.theme-pearl{
  --bg:#f4f6fb;
  --text:#0f172a;
  --muted:#475569;
  background:
    radial-gradient(circle at 20% 20%, rgba(148,163,184,0.22), transparent 40%),
    radial-gradient(circle at 80% 60%, rgba(203,213,225,0.18), transparent 45%),
    #ffffff;
  color:var(--text);
}
body.theme-storm{
  --bg:#0a0f18;
  background:
    radial-gradient(circle at 30% 30%, rgba(100,116,139,0.18), transparent 45%),
    radial-gradient(circle at 75% 70%, rgba(14,116,144,0.18), transparent 45%),
    linear-gradient(150deg, #05070d, #0f172a 60%, #05070d);
}
body.theme-blush{
  --bg:#12040a;
  background:
    radial-gradient(circle at 25% 25%, rgba(244,114,182,0.22), transparent 45%),
    radial-gradient(circle at 75% 65%, rgba(248,113,113,0.18), transparent 45%),
    linear-gradient(150deg, #0a0306, #1a0a10 60%, #0a0306);
}

/* Keep dashboard background continuous while scrolling (no tiled cutoff). */
body.auth-ready[class*="theme-"]{
  background-attachment: fixed !important;
  background-repeat: no-repeat !important;
  background-size: 100% 100% !important;
}

/* Card theme palettes (independent from background theme) */
body.card-theme-default{
  --card:#0f172a;
  --border:#1f2a44;
  --badge:#0b1220;
}
body.card-theme-muted{
  --card:#0d1322;
  --border:#25314b;
  --badge:#0a101c;
}
body.card-theme-light{
  --card:#161f30;
  --border:#2f3c56;
  --badge:#111829;
}
body.card-theme-contrast{
  --card:#0b0f1c;
  --border:#304a73;
  --badge:#060a12;
}
body.card-theme-glass{
  --card:rgba(8, 12, 22, 0.74);
  --border:rgba(116, 162, 255, 0.32);
  --badge:rgba(5, 9, 16, 0.8);
}
body.card-theme-graphite-card{
  --card:#0f141c;
  --border:#2b3748;
  --badge:#0b0f16;
}
body.card-theme-midnight-card{
  --card:#0a0f1c;
  --border:#1f2a44;
  --badge:#060a12;
}
body.card-theme-frost-card{
  --card:#101723;
  --border:#2d455f;
  --badge:#0a111d;
}
body.card-theme-amber-card{
  --card:#191109;
  --border:#3a2412;
  --badge:#120c07;
}
body.card-theme-teal-card{
  --card:#0c1614;
  --border:#1f3a32;
  --badge:#08100e;
}
body.card-theme-orchid-card{
  --card:#160d1f;
  --border:#2d1f3a;
  --badge:#0f0816;
}
body.card-theme-sand-card{
  --card:#18120b;
  --border:#3a2a16;
  --badge:#120d08;
}
body.card-theme-slate-card{
  --card:#0f131b;
  --border:#283448;
  --badge:#0a0d14;
}
body.card-theme-charcoal-card{
  --card:#0d0f14;
  --border:#262a33;
  --badge:#08090e;
}
body.card-theme-sunset-card{
  --card:#1a0f0d;
  --border:#3b1f1a;
  --badge:#130b0a;
}
body.card-theme-white-card{
  --card:#ffffff;
  --border:#d7dde7;
  --badge:#eef1f6;
}

/* ======= Base ======= */
html{height:100%}
body{
  min-height:100%;
  margin:0; background:var(--bg); color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: var(--step-0); line-height: 1.45;
}
body.auth-ready{
  position:relative;
}
#appShell{
  position:relative;
  z-index:1;
}
body.auth-loading,
body.auth-pending{
  background:#0a0b0f;
  background-repeat:no-repeat;
  background-attachment:fixed;
}
body.radar-bg{
  background:
    radial-gradient(circle at 25% 5%, rgba(106, 190, 255, 0.95), rgba(106,190,255,0) 60%),
    radial-gradient(circle at 85% 90%, rgba(201, 92, 185, 0.8), rgba(201,92,185,0) 65%),
    linear-gradient(165deg, #0a1f38 0%, #060814 55%, #030307 100%);
  background-repeat:no-repeat;
  background-attachment:fixed;
}
.radar-bg .radar-panel .btn{
  background:linear-gradient(120deg,#4ed9ff,#ff6ad2);
  border:none;
  color:#05102a;
  font-weight:600;
}
body.boot-ready{
  transition: opacity .36s ease, transform .36s ease;
}
body.is-booting{
  opacity:1;
  transform:none;
}
body.modal-open{overflow:hidden}
*{ box-sizing: border-box }
#navScrollSpacer{
  width: 100%;
  height: 0;
  pointer-events: none;
  visibility: hidden;
}
h1{ font-size: var(--step-2); letter-spacing:.2px; margin:0 }
h3{ font-size: var(--step-1); margin:0 }
small, .muted{ color: var(--muted); font-size: var(--step--1) }
.sr-only{
  position:absolute;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.hub-connect-hidden{
  display:none !important;
}
th, td, .badge, .value{
  font-variant-numeric: tabular-nums lining-nums;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}

/* ======= Auth gate ======= */
body.auth-pending #appShell{ display:none; }
body.auth-ready #appShell{ display:block; }
body.auth-loading #appShell{ display:none; }
#authLoading{
  display:none;
}
#authGate{
  display:block;
  min-height:100vh;
  padding:0;
  background:transparent;
}
body.auth-ready #authGate,
body.auth-loading #authGate{ display:none; }
.auth-panel{
  width:100%;
  max-width:360px;
  padding:24px 28px;
  background:var(--card);
  border:1px solid color-mix(in oklab, var(--border) 80%, transparent);
  border-radius:var(--radius);
  box-shadow: var(--shadow-amb), var(--shadow-key);
  display:flex;
  flex-direction:column;
  gap:16px;
}
.auth-panel h2{
  margin:0;
  text-align:center;
  font-size: var(--step-2);
}
.auth-panel form{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.auth-panel input[type="email"],
.auth-panel input[type="password"]{
  width:100%;
}
.auth-panel button[type="submit"]{
  width:100%;
}
.auth-panel .auth-error{
  min-height:18px;
  color: var(--err);
  text-align:center;
  font-size: var(--step--1);
}
.auth-panel .auth-error.auth-success{
  color: var(--ok);
}
.auth-links{
  text-align:right;
  margin-top:-4px;
}
.auth-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size: var(--step--1);
  color: var(--accent);
  text-decoration:underline;
  cursor:pointer;
  transition: color 0.18s ease;
}
.auth-link:hover,
.auth-link:focus{
  color: color-mix(in oklab, var(--accent) 80%, white);
}
.auth-link-disabled{
  opacity:0.6;
  pointer-events:none;
}

.modal-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.column-map-fields{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.column-map-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.column-map-label{
  font-weight:600;
  display:flex;
  align-items:center;
  gap:6px;
}
.column-map-label.column-map-required::after{
  content:'*';
  color:var(--accent);
  font-weight:700;
}
.column-map-help{
  font-size:var(--step--1);
  color:var(--muted);
}
.column-map-fields select{
  width:100%;
}
#invoiceImportMappingPanel{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:12px;
}
#billImportMappingPanel{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:12px;
}
#billImportMappingPanel .column-map-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:stretch;
}
#invoiceImportMappingPanel .column-map-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:stretch;
}
.modal-form input{
  width:100%;
}
.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top:6px;
}
.modal-message{
  min-height:18px;
  font-size:var(--step--1);
  color:var(--muted);
  margin-top:6px;
}
.modal-message.success{ color: var(--ok); }
.modal-message.error{ color: var(--err); }

.stepper{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.step{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:var(--step--1);
  background: color-mix(in oklab, var(--card) 70%, transparent);
}
.step.active{
  background: color-mix(in oklab, var(--brand) 20%, transparent);
  border-color: color-mix(in oklab, var(--brand) 40%, var(--border));
}

/* ======= Top bar ======= */
header.topbar{
  position:sticky; top:0; z-index:30;
  backdrop-filter: blur(14px) saturate(1.15);
  background: color-mix(in oklab, var(--card) 90%, transparent);
  border-bottom:1px solid color-mix(in oklab, var(--accent) 18%, var(--border));
  box-shadow: 0 6px 18px rgba(15, 23, 42, .14);
}
header.topbar::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:2px;
  background: color-mix(in oklab, var(--accent) 80%, transparent);
  opacity:.75;
  pointer-events:none;
}
.topwrap{ position:relative; max-width:1200px; margin:0 auto; padding:10px 24px 12px; display:flex; align-items:center; gap:12px; justify-content:space-between }
.brand{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.brand-lockup{ display:flex; align-items:center; gap:10px; }
.brand svg{ width:24px; height:24px; }
.brand-tagline{
  font-size: var(--step--1);
  font-weight:500;
  color: color-mix(in oklab, var(--muted) 65%, transparent);
  letter-spacing:.18px;
  line-height:1.3;
  white-space:nowrap;
}
.brand-status{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size: var(--step--1);
  color: var(--status-pill-fg);
  background: var(--status-pill-bg);
  border:1px solid var(--status-pill-border);
  border-radius:999px;
  padding:4px 12px;
  margin-bottom:4px;
  white-space:nowrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  transition: box-shadow .18s ease, transform .18s ease;
}
.brand-status.is-disconnected{
  color: var(--err);
  font-weight: 700;
  border-color: var(--status-pill-border);
  background: var(--status-pill-bg);
  text-shadow: none;
}
.auth-controls{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.auth-session{
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.auth-session .brand-status{
  transition: box-shadow .18s ease;
}
.auth-session .brand-status:focus{
  outline:none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 0 0 2px var(--status-pill-border);
}
.auth-session__trigger{
  cursor:pointer;
}
.auth-popover{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translate(-50%, 10px);
  min-width:240px;
  max-width:calc(100vw - 32px);
  padding:18px 20px 20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  background: color-mix(in oklab, var(--card) 84%, #020617);
  border-radius:18px;
  border:1px solid color-mix(in oklab, var(--border) 82%, transparent);
  box-shadow: 0 26px 60px rgba(8, 15, 35, .42), 0 6px 18px rgba(8, 15, 35, .32);
  opacity:0;
  pointer-events:none;
  visibility:hidden;
  transition: opacity .2s ease, transform .22s ease;
  z-index:20;
}
.auth-popover::before{
  content:"";
  position:absolute;
  top:-9px;
  left:50%;
  width:18px;
  height:18px;
  background: inherit;
  border-left:1px solid color-mix(in oklab, var(--border) 82%, transparent);
  border-top:1px solid color-mix(in oklab, var(--border) 82%, transparent);
  transform: translate(-50%, 0) rotate(45deg);
  z-index:-1;
}
.auth-session:hover .auth-popover,
.auth-session:focus-within .auth-popover{
  opacity:1;
  pointer-events:auto;
  visibility:visible;
  transform:translate(-50%, 0);
}
.auth-popover__status{
  font-size: var(--step--1);
  line-height:1.4;
  color: color-mix(in oklab, var(--muted) 40%, white);
}
.auth-popover__signout{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  padding:12px 18px;
  border-radius:14px;
  border:0;
  font-size: var(--step-0);
  font-weight:600;
  color:#fff;
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--err) 72%, white),
    color-mix(in oklab, var(--err) 86%, #0b0f14));
  box-shadow: 0 18px 40px rgba(15, 23, 42, .45), inset 0 1px 0 rgba(255,255,255,.26);
  cursor:pointer;
  transition: transform .18s ease, box-shadow .22s ease, filter .2s ease;
}
.auth-popover__signout:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 46px rgba(15, 23, 42, .5), inset 0 1px 0 rgba(255,255,255,.3);
}
.auth-popover__signout:active{
  transform: translateY(0);
  box-shadow: 0 12px 26px rgba(15, 23, 42, .42), inset 0 1px 0 rgba(255,255,255,.22);
}
.auth-popover__signout:focus-visible{
  outline:none;
  box-shadow: var(--focus-ring), 0 18px 40px rgba(15, 23, 42, .45), inset 0 1px 0 rgba(255,255,255,.26);
}
#authStatusLabel{
  font-size: var(--step--1);
  color: var(--muted);
}
.auth-card{
  max-width: 620px;
  margin: 28px auto 0;
  padding: 24px 26px;
  text-align:center;
  background: var(--card);
  border:1px solid color-mix(in oklab, var(--border) 80%, transparent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-amb), var(--shadow-key);
}
.auth-card h2{
  margin:0 0 8px;
  font-size: var(--step-2);
}
.auth-card p{
  margin:0;
  color: var(--muted);
  font-size: var(--step--1);
}
.seg{ display:inline-flex; border:1px solid var(--border); border-radius:999px; overflow:hidden }
.seg button{
  padding:8px 14px; border:0; background:transparent; color:var(--text); cursor:pointer;
  transition: background .15s ease
}
.seg button:hover{ background: color-mix(in oklab, var(--badge) 70%, transparent) }
.seg button.active{ background: var(--accent); color:#fff }
.seg button[disabled],
.seg button[aria-disabled="true"]{
  opacity:.4;
  cursor:not-allowed;
  pointer-events:none;
}

.toolbar{ display:flex; gap:8px; align-items:center }

.app-layout{
    display:flex;
    align-items:flex-start;
    gap:18px;
    min-height:100vh;
  }
  .app-header{
    display:flex;
    align-items:center;
    gap:12px;
    padding:6px 0 12px;
  }
  .app-header-title{
    font-weight:900;
    letter-spacing:0.04em;
    font-size:18px;
    color:var(--text);
  }
  .app-header-line{
    flex:1;
    height:1px;
    background:linear-gradient(90deg, transparent, color-mix(in oklab, var(--accent) 55%, transparent), transparent);
  }
  .header-icon{
    border:1px solid var(--border);
    background:var(--surface-subtle);
    color:var(--text);
    border-radius:10px;
    padding:8px 9px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
  }
  .header-icon svg{width:16px;height:16px;}
  .header-icon[aria-pressed="true"]{
    background:color-mix(in oklab,var(--accent) 24%, transparent);
    border-color:color-mix(in oklab,var(--accent) 60%, transparent);
  }
.main-shell{
    flex:1 1 auto;
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:16px;
    overflow-anchor: none;
    padding:24px 24px 28px;
  }
  .app-support-footer{
    margin:8px 2px 0;
    padding:10px 14px;
    border:1px solid var(--border);
    border-radius:12px;
    background:var(--card);
    color:var(--muted);
    font-size:12px;
    text-align:center;
  }
  .app-support-footer a{
    color:var(--accent);
    text-decoration:none;
    font-weight:700;
  }
  .app-support-footer a:hover{
    text-decoration:underline;
  }
  .nav-sidebar{
    flex:0 0 230px;
  }
  .nav-sidebar.is-collapsed{
    flex:0 0 72px;
  }
  .nav-strip{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:24px 18px;
    box-sizing:border-box;
    margin:0;
    border-radius:0;
    background: linear-gradient(180deg, #0b1120 0%, #0a101c 100%);
    border:none;
    border-right:1px solid rgba(255,255,255,0.08);
    box-shadow:none;
    position:sticky;
    top:0;
    min-height:100vh;
  }
  .nav-brand{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:10px;
    padding:2px 4px 12px;
  }
  .nav-brand-button{
    display:flex;
    align-items:center;
    padding:2px;
    border-radius:10px;
    background:transparent;
    border:1px solid transparent;
    color:inherit;
    cursor:pointer;
  }
  .nav-brand-button:hover{
    background:rgba(255,255,255,0.04);
  }
  .nav-brand-mark{
    width:34px;
    height:34px;
    border-radius:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:color-mix(in oklab, var(--accent) 16%, transparent);
    border:1px solid color-mix(in oklab, var(--accent) 35%, transparent);
    color:var(--accent);
  }
  .nav-brand-mark svg{
    width:26px;
    height:26px;
  }
  .nav-brand-word{
    display:flex;
    flex-direction:column;
    line-height:1.05;
  }
  .nav-brand-title{
    font-size:12px;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--text);
  }
  .nav-brand-accent{
    color:color-mix(in oklab, var(--accent) 90%, var(--text));
  }
  .nav-status{
    display:flex;
    flex-direction:column;
    gap:8px;
    margin-bottom:6px;
  }
  .nav-strip .nav-status-toggle{
    width:100%;
    justify-content:flex-start;
    gap:6px;
    padding:6px 8px;
    border-radius:10px;
    background:transparent;
    border:1px solid transparent;
    cursor:pointer;
  }
  .nav-strip .nav-status-toggle:hover{
    background:rgba(255,255,255,0.04);
  }
  .nav-strip .nav-status-toggle.hero-status-pill{
    background:color-mix(in oklab, var(--hero-metrics-bg, rgba(255,255,255,0.04)) 85%, transparent);
    border:1px solid var(--hero-metrics-border, rgba(255,255,255,0.12));
    box-shadow:var(--hero-metrics-shadow, none);
  }
  .nav-strip .nav-status-toggle .hero-status-badge{
    padding:0;
    border:none !important;
    background:transparent !important;
    letter-spacing:0.08em;
  }
  .nav-status-label{
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:0.14em;
    color:var(--muted);
  }
  .nav-status-dot{
    width:6px;
    height:6px;
    border-radius:50%;
    background:var(--ok);
    box-shadow:0 0 8px color-mix(in oklab, var(--ok) 70%, transparent);
  }
  .nav-status-caret{
    margin-left:auto;
    width:14px;
    height:14px;
    opacity:0.7;
    transition:transform 0.2s ease;
  }
  .nav-status-toggle[aria-expanded="true"] .nav-status-caret{
    transform:rotate(180deg);
  }
  .nav-status-panel{
    border-radius:12px;
    padding:10px 12px;
    background:color-mix(in oklab, var(--hero-metrics-bg, var(--card)) 85%, transparent);
    border:1px solid var(--hero-metrics-border, color-mix(in oklab, var(--accent) 35%, transparent));
    box-shadow:var(--hero-metrics-shadow, none);
  }
  .nav-status-message{
    font-size:12px;
    color:var(--text);
    margin-bottom:8px;
  }
  .nav-status-message .hero-status-text{
    white-space:normal;
  }
  .nav-status-list{
    margin:0;
    padding-left:16px;
    display:flex;
    flex-direction:column;
    gap:6px;
    color:var(--muted);
    font-size:12px;
  }
  .nav-status-list li{
    list-style:disc;
    display:flex;
    align-items:center;
    gap:6px;
  }
  .nav-status-chip{
    font-size:10px;
    text-transform:uppercase;
    letter-spacing:0.12em;
    color:var(--muted);
  }
  .nav-status-value{
    color:var(--text);
  }
  .nav-status-list li.status-ok .nav-status-value{
    color:var(--ok);
  }
  .nav-status-list li.status-warn .nav-status-value{
    color:var(--warn);
  }
  .nav-status-list li.status-err .nav-status-value{
    color:var(--err);
  }
  .nav-status-list li.status-off .nav-status-value{
    color:var(--near);
  }
  .nav-status-updated{
    margin-top:8px;
    font-size:11px;
    color:var(--muted);
    letter-spacing:0.04em;
  }
  .nav-status-toggle.is-healthy .nav-status-dot{ background:var(--ok); }
  .nav-status-toggle.is-attention .nav-status-dot,
  .nav-status-toggle.is-disconnected .nav-status-dot,
  .nav-status-toggle.is-downloads .nav-status-dot{ background:var(--warn); }
  .nav-status-toggle.is-offline .nav-status-dot{ background:var(--near); }
  .nav-status-toggle.is-outage .nav-status-dot{ background:var(--err); }
  .nav-radar-outline{ opacity:0.85; }
  .nav-radar-ring{ opacity:0.45; }
  .nav-radar-core{ opacity:0.25; }
  .nav-radar-beam,
  .nav-radar-ping{
    fill:currentColor;
  }
  .nav-radar-beam{
    fill-opacity:0.22;
  }
  .nav-radar-sweep{
    transform-origin:32px 32px;
    animation:home-radar-sweep 2.8s linear infinite;
  }
  .nav-radar-ping{
    animation:home-radar-ping 2.4s ease-in-out infinite;
  }
  .nav-radar-ping-a{ animation-delay:0.2s; }
  .nav-radar-ping-b{ animation-delay:1.1s; }
  .nav-radar-line{
    stroke:currentColor;
    stroke-width:2;
    stroke-linecap:round;
    opacity:0.9;
    filter:drop-shadow(0 0 6px color-mix(in oklab, var(--accent) 60%, transparent));
  }
  .nav-strip.is-collapsed{
    align-items:center;
  }
  .nav-sidebar.is-collapsed .nav-brand{
    align-items:center;
    justify-content:center;
    padding-bottom:10px;
  }
  .nav-sidebar.is-collapsed .nav-brand-word{
    display:none;
  }
  .nav-sidebar.is-collapsed .nav-brand-button{
    justify-content:center;
  }
  .nav-sidebar.is-collapsed .nav-status{
    display:none;
  }
  .nav-mode{
    flex:1 1 auto;
    display:flex;
    justify-content:flex-start;
  }
  .nav-seg{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:12px;
  }
  .nav-group{display:flex;flex-direction:column;gap:10px;}
  .nav-label{
    font-size:11px;
    color:color-mix(in oklab, var(--muted) 85%, var(--text));
    text-transform:uppercase;
    letter-spacing:0.18em;
  }
  .nav-stack{display:flex;flex-direction:column;gap:10px;}
  .nav-seg button{
    font-weight:500;
    min-width:0;
    width:100%;
    padding:10px 14px;
    border-radius:14px;
    background:transparent;
    border:1px solid transparent;
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--text);
    font-size:16px;
    cursor:pointer;
    transition:background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease;
  }
  #btnMissing span,
  #btnCreditCards span{
    white-space:nowrap;
    font-size:15px;
    letter-spacing:-0.01em;
  }
  .nav-seg button .nav-icon{
    width:18px;
    height:18px;
    opacity:.9;
    flex-shrink:0;
    display:none;
  }
  .nav-sidebar.is-collapsed .nav-seg button{
    justify-content:center;
    padding:10px;
  }
  .nav-sidebar.is-collapsed .nav-seg button .nav-icon{
    display:inline-flex;
  }
  .nav-sidebar.is-collapsed .nav-seg button span{
    display:none;
  }
  .nav-sidebar.is-collapsed .nav-label{
    display:none;
  }
  .nav-seg button.active{
    background:linear-gradient(180deg, rgba(20,52,76,0.9), rgba(16,40,60,0.9));
    color:#eef6ff;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);
    border-color:rgba(78,155,189,0.45);
  }

.nav-seg button:hover:not(.active){
  background:rgba(255,255,255,0.04);
}
.nav-seg button.active .nav-icon{
  opacity:1;
}
.nav-seg button.nav-signout{
  min-width:0;
  margin-left:0;
  padding:10px 16px;
  background:linear-gradient(135deg,color-mix(in oklab,var(--err) 90%, transparent),color-mix(in oklab,var(--err) 75%, transparent));
  color:#fff;
  box-shadow:0 12px 28px color-mix(in oklab,var(--err) 35%, transparent);
  width:100%;
}
.nav-seg button.nav-signout:hover,
.nav-seg button.nav-signout:focus-visible{
  background:linear-gradient(135deg,color-mix(in oklab,var(--err) 95%, transparent),color-mix(in oklab,var(--err) 80%, transparent));
  color:#fff;
}
  @media (max-width:1100px){
    .app-layout{
      flex-direction:column;
    }
    .nav-sidebar{
      flex:0 0 auto;
      width:100%;
    }
    .nav-strip{
      position:relative;
      top:0;
      height:auto;
    }
  }

/* Top navigation layout (sidebar replacement) */
.app-layout.app-layout-topnav{
  display:block;
  min-height:100vh;
}
.app-layout.app-layout-topnav .nav-sidebar{
  display:none !important;
}
.app-layout.app-layout-topnav .main-shell{
  padding:14px clamp(12px,2vw,24px) 28px;
  gap:14px;
}
.app-layout.app-layout-topnav .main-shell > *{
  width:min(1450px, 100%);
  margin-inline:auto;
}
.app-topnav{
  position:sticky;
  top:10px;
  z-index:40;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;
  background:rgba(8,12,22,0.78);
  backdrop-filter:blur(10px) saturate(125%);
  -webkit-backdrop-filter:blur(10px) saturate(125%);
  box-shadow:0 16px 36px rgba(0,0,0,0.34);
  padding:12px 14px;
}
.app-topnav-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:16px;
}
.app-topnav-brand{
  display:flex;
  align-items:center;
  gap:11px;
  min-width:220px;
}
.app-topnav-mark{
  width:44px;
  height:44px;
  border-radius:13px;
  display:grid;
  place-items:center;
  border:1px solid color-mix(in oklab, var(--accent) 44%, transparent);
  background:color-mix(in oklab, var(--accent) 12%, transparent);
  color:var(--accent);
}
.app-topnav-mark svg{
  width:28px;
  height:28px;
}
.app-topnav-word{
  font-family:"Space Grotesk", sans-serif;
  font-size:13px;
  font-weight:700;
  line-height:1;
  letter-spacing:0.2em;
  text-transform:uppercase;
  white-space:nowrap;
}
.app-topnav-word span{
  color:color-mix(in oklab, var(--accent) 95%, var(--text));
}
.app-topnav-nav{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.app-topnav-item{
  position:relative;
}
.app-topnav-link,
.app-topnav-trigger{
  border:1px solid transparent;
  color:var(--text);
  border-radius:10px;
  padding:8px 11px;
  font-size:14px;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:7px;
  background:transparent;
  cursor:pointer;
}
.app-topnav-link:hover,
.app-topnav-trigger:hover{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,255,255,0.08);
}
.app-topnav-caret{
  font-size:11px;
  color:var(--muted);
}
.app-topnav-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:260px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:12px;
  background:rgba(10,16,30,0.92);
  box-shadow:0 18px 34px rgba(0,0,0,0.4);
  padding:8px;
  opacity:0;
  transform:translateY(6px);
  pointer-events:none;
  transition:opacity 0.15s ease, transform 0.15s ease;
  z-index:50;
}
.app-topnav-item:hover > .app-topnav-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.app-topnav-menu button{
  width:100%;
  border:0;
  background:transparent;
  color:rgba(237,243,255,0.93);
  border-radius:9px;
  padding:8px 10px;
  font-size:13px;
  font-weight:500;
  text-align:left;
  cursor:pointer;
}
.app-topnav-menu button:hover{
  background:rgba(255,255,255,0.06);
}
.app-topnav-menu hr{
  border:0;
  border-top:1px solid rgba(255,255,255,0.08);
  margin:7px 2px;
}
.app-topnav-link.is-active,
.app-topnav-trigger.is-active,
.app-topnav-menu button.is-active{
  background:color-mix(in oklab, var(--accent) 20%, transparent);
  border-color:color-mix(in oklab, var(--accent) 45%, transparent);
  color:var(--text);
}
.app-topnav-actions{
  display:flex;
  align-items:center;
  gap:10px;
  justify-self:end;
}
.app-topnav-status-item{
  position:relative;
}
.app-topnav-status-pill{
  border:1px solid color-mix(in oklab, var(--accent) 40%, transparent);
  color:#d6ffef;
  background:color-mix(in oklab, var(--accent) 11%, transparent);
  border-radius:999px;
  padding:7px 10px;
  font-size:12px;
  white-space:nowrap;
  cursor:default;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.app-topnav-status-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--ok);
  box-shadow:0 0 8px color-mix(in oklab, var(--ok) 70%, transparent);
}
.app-topnav-status-pill.is-healthy .app-topnav-status-dot{ background:var(--ok); }
.app-topnav-status-pill.is-attention .app-topnav-status-dot,
.app-topnav-status-pill.is-disconnected .app-topnav-status-dot,
.app-topnav-status-pill.is-downloads .app-topnav-status-dot{ background:var(--warn); }
.app-topnav-status-pill.is-offline .app-topnav-status-dot{ background:var(--near); }
.app-topnav-status-pill.is-outage .app-topnav-status-dot{ background:var(--err); }
.app-topnav-status-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:260px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:12px;
  background:rgba(10,16,30,0.92);
  box-shadow:0 18px 34px rgba(0,0,0,0.4);
  padding:8px;
  opacity:0;
  transform:translateY(6px);
  pointer-events:none;
  transition:opacity 0.15s ease, transform 0.15s ease;
  z-index:60;
}
.app-topnav-status-item:hover .app-topnav-status-menu,
.app-topnav-status-item:focus-within .app-topnav-status-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.app-topnav-status-item.is-dashboard-locked .app-topnav-status-menu,
.app-topnav-status-item.is-dashboard-locked:hover .app-topnav-status-menu,
.app-topnav-status-item.is-dashboard-locked:focus-within .app-topnav-status-menu{
  opacity:0 !important;
  transform:translateY(6px) !important;
  pointer-events:none !important;
}
.app-topnav-status-message{
  font-size:12px;
  color:var(--text);
  margin:2px 2px 8px;
}
.app-topnav-status-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.app-topnav-status-list li{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  border-radius:9px;
  padding:8px 10px;
  font-size:12px;
  color:rgba(237,243,255,0.9);
  background:rgba(255,255,255,0.03);
}
.app-topnav-status-list li span{
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
}
.top-status-value{
  color:var(--text);
  font-weight:600;
}
.top-status-value.status-ok{ color:var(--ok); }
.top-status-value.status-warn{ color:var(--warn); }
.top-status-value.status-err{ color:var(--err); }
.top-status-value.status-off{ color:var(--near); }
.app-topnav-status-updated{
  margin-top:8px;
  font-size:11px;
  color:var(--muted);
  letter-spacing:0.04em;
}
.app-topnav-signout{
  border:1px solid color-mix(in oklab, var(--err) 44%, white);
  background:color-mix(in oklab, var(--err) 14%, transparent);
  color:color-mix(in oklab, var(--err) 86%, white);
  border-radius:999px;
  padding:9px 16px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
}
.app-topnav-signout:hover{
  background:color-mix(in oklab, var(--err) 20%, transparent);
}
@media (max-width:980px){
  .app-topnav-row{
    grid-template-columns:1fr;
    align-items:start;
  }
  .app-topnav-actions{
    justify-self:start;
  }
  .app-topnav-nav{
    justify-content:flex-start;
  }
  .app-topnav-status-menu{
    right:auto;
    left:0;
  }
}
.control-card .muted,
.control-card .control-sub,
.control-card small{
  color:rgba(15,23,42,.66);
}
.chip-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid var(--workspace-chip-border);
  background: var(--workspace-chip-bg);
  color: var(--workspace-chip-text);
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .18s ease, background .2s ease, border-color .2s ease;
  box-shadow: var(--workspace-chip-shadow);
}
/* Inputs that borrow the chip styles should still show the text cursor */
.chip-btn[type="text"],
.chip-btn[type="search"],
.chip-btn[type="email"],
.chip-btn[type="password"]{
  cursor:text;
}
.chip-btn:hover{
  transform: translateY(-1px);
  background: var(--workspace-chip-bg-hover);
  border-color: var(--workspace-chip-border-hover);
  box-shadow: var(--workspace-chip-shadow-hover);
}
.chip-btn:active{
  transform: translateY(0);
  box-shadow: var(--workspace-chip-shadow-active);
}
.chip-btn:focus-visible{
  outline:none;
  box-shadow: var(--focus-ring), var(--workspace-chip-shadow-hover);
}
.chip-btn.secondary{
  background: var(--surface);
  border-color: var(--workspace-chip-border);
  color: var(--workspace-chip-text);
  box-shadow: var(--workspace-chip-shadow);
}
.chip-btn.secondary.is-active{
  background: color-mix(in oklab, var(--accent) 22%, var(--surface));
  border-color: color-mix(in oklab, var(--accent) 50%, var(--workspace-chip-border));
  color: var(--accent-strong);
  box-shadow: var(--workspace-chip-shadow-hover);
}
.chip-btn.secondary:hover{
  background: var(--workspace-chip-bg-hover);
}
.chip-btn.danger{
  background: color-mix(in oklab, var(--err) 18%, transparent);
  border-color: color-mix(in oklab, var(--err) 45%, white);
  color: color-mix(in oklab, var(--err) 70%, white);
  box-shadow: none;
}
.chip-btn.danger:hover{
  background: color-mix(in oklab, var(--err) 24%, transparent);
  border-color: color-mix(in oklab, var(--err) 65%, white);
  color: color-mix(in oklab, var(--err) 85%, white);
}

.contracts-table th.sortable{
  cursor: pointer;
  user-select: none;
}

.contracts-table th.sortable .sort-indicator{
  margin-left: 6px;
  font-size: 11px;
  opacity: 0.7;
}

.contracts-table td.editable-cell{
  cursor: text;
}
.inline-edit-input{
  width: 100%;
  min-width: 140px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  box-sizing: border-box;
}
.inline-edit-input:focus-visible{
  outline: none;
  box-shadow: var(--focus-ring);
}
.inline-edit-actions{
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.inline-edit-actions .inline-edit-btn,
.inline-edit-bar .inline-edit-btn{
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 12px;
}
.inline-edit-note{
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.3;
}
.inline-edit-bar{
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.source-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:12px;
  background: color-mix(in oklab, var(--surface) 82%, transparent);
}
.source-toggle .source-label{
  font-size:12px;
  letter-spacing:.02em;
}
.source-seg{
  display:inline-flex;
  border:1px solid var(--border);
  border-radius:999px;
  overflow:hidden;
  background: var(--surface);
}
.source-seg .chip-btn{
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:8px 14px;
  font-size:12px;
}
.source-seg .chip-btn + .chip-btn{
  border-left:1px solid var(--border);
}
.source-toggle .source-load{
  padding:6px 12px;
  border-radius:10px;
  font-size:12px;
}

.contracts-table td.editable-cell input{
  width: 100%;
  background: transparent;
  border: 1px solid var(--workspace-chip-border);
  border-radius: 8px;
  color: inherit;
  padding: 4px 8px;
}
.dashboard-session-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin:12px 0 16px;
}
.dashboard-session-bar .auth-controls{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
}
.dashboard-settings-session{
  margin:18px 0 0;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid var(--border-strong);
  background:var(--surface-subtle);
}
.dashboard-settings-session .auth-controls{
  justify-content:flex-start;
}
.dashboard-card.dashboard-tools-card{
  overflow:visible;
}
.pane-transition{
  will-change: opacity, transform;
}
.pane-transition.pane-animate{
  animation: paneFade .28s ease;
}
@keyframes paneFade{
  from{ opacity:0; transform: translateY(6px); }
  to{ opacity:1; transform: translateY(0); }
}
@media (max-width: 720px){
  .control-card .seg{
    width:100%;
    flex-wrap:wrap;
    justify-content:center;
  }
  .dashboard-session-bar{
    flex-direction:column;
    align-items:flex-start;
  }
  .dashboard-session-bar .auth-controls{
    width:100%;
    justify-content:flex-start;
  }
  .auth-session{
    width:100%;
  }
  .brand-status{
    width:100%;
    justify-content:flex-start;
    margin-bottom:6px;
  }
}

/* ======= Cards with premium borders ======= */
.container{ width:100%; max-width:none; margin:0; padding:24px 24px 28px }
#appShell.container{ padding:0; }
.card{
  position:relative; overflow: clip;
  background:linear-gradient(180deg,
    color-mix(in oklab, var(--card) 92%, white) 0%,
    color-mix(in oklab, var(--card) 85%, black) 100%);
  border:1px solid color-mix(in oklab, var(--border) 75%, transparent);
  border-radius:var(--radius); padding:16px; margin:16px 0;
  box-shadow: 0 24px 50px rgba(3,7,18,0.45), var(--shadow-amb);
  transition: box-shadow .15s ease, transform .08s ease, border-color .15s ease;
}
.card:hover{
  box-shadow: 0 28px 60px rgba(3,7,18,0.52), var(--shadow-hov);
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--accent) 35%, var(--border));
}
.card::before{
  content:""; position:absolute; inset:0; padding:1px; border-radius:var(--radius);
  background: conic-gradient(from 180deg at 50% 50%,
              color-mix(in oklab,var(--accent) 35%, transparent),
              color-mix(in oklab,var(--accent-2) 35%, transparent),
              color-mix(in oklab,var(--accent-3) 35%, transparent),
              color-mix(in oklab,var(--accent) 35%, transparent));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; opacity:.5; pointer-events:none;
}
.card.control-card{
  --workspace-bg-start: rgba(247, 250, 255, 0.96);
  --workspace-bg-end: rgba(255, 255, 255, 0.86);
  --workspace-border: rgba(120, 170, 255, 0.42);
  --workspace-shadow: 0 24px 44px rgba(15, 30, 80, 0.18);
  --workspace-seg-bg: rgba(255, 255, 255, 0.88);
  --workspace-seg-border: rgba(120, 170, 255, 0.48);
  --workspace-chip-bg: rgba(247, 250, 255, 0.82);
  --workspace-chip-border: rgba(120, 170, 255, 0.52);
  --workspace-chip-text: #1a4ed8;
  --workspace-chip-shadow: 0 16px 32px rgba(36, 64, 120, 0.22);
  --workspace-chip-bg-hover: rgba(255, 255, 255, 0.95);
  --workspace-chip-border-hover: rgba(120, 170, 255, 0.72);
  --workspace-chip-shadow-hover: 0 22px 40px rgba(40, 70, 130, 0.28);
  --workspace-chip-shadow-active: 0 16px 28px rgba(40, 70, 120, 0.22);
  color:#0f172a;
  background: linear-gradient(135deg, var(--workspace-bg-start) 0%, var(--workspace-bg-end) 100%);
  border:1px solid var(--workspace-border);
  box-shadow: var(--workspace-shadow);
  overflow:visible;
  z-index:2;
}
.card.control-card::before{ display:none; }
.card.control-card .control-sub,
.card.control-card .muted,
.card.control-card small{
  color:rgba(15,23,42,.66);
}
.card.control-card .seg button{
  color:#0f172a;
}
.card.control-card .seg button.active{
  color:#fff;
}

.btn, .btn-outline{
  padding:10px 14px; border-radius:12px; cursor:pointer; border:1px solid var(--border);
  display:inline-flex; gap:8px; align-items:center; user-select:none;
  text-decoration:none;
  transition: transform .08s ease, box-shadow .15s ease, background .2s ease, border-color .2s ease;
  will-change: transform;
}
.btn{ background:linear-gradient(180deg,var(--accent),var(--accent-2)); color:#fff; box-shadow: var(--shadow-amb), var(--shadow-key) }
.btn:hover{ transform: translateY(-1px) }
.btn:active{ transform: translateY(0) scale(.99) }
.btn:focus-visible{ outline:none; box-shadow: var(--focus-ring) }
.btn-outline{ background:transparent; color:var(--accent); border-color:var(--accent); box-shadow:none }
.btn-outline:hover{ border-color: color-mix(in oklab,var(--accent) 80%, white); background: color-mix(in oklab,var(--badge) 80%, transparent) }
.btn:disabled, .btn-outline:disabled{ opacity:.55; cursor:not-allowed }
.contracts-table-actions .btn-outline.is-active{
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  border-color: color-mix(in oklab, var(--accent) 65%, var(--border));
  color: var(--accent);
}

.row{ display:flex; gap:16px; flex-wrap:wrap; align-items:flex-end }

/* Shared form styling (user-scoped) */
label{
  font-weight:700;
  display:block;
  margin:6px 0 6px;
}

input[type="text"],
input[type="number"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="date"],
select,
textarea{
  width:260px;
  background:var(--input-bg);
  color:var(--text);
  border:1px solid var(--input-border);
  border-top:2px solid var(--input-accent);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  outline:none;
  transition: box-shadow .15s ease, border-color .15s ease;
}

input[type="file"]{
  width:260px;
  border:1px dashed var(--border);
  border-radius:var(--radius-sm);
  background: color-mix(in oklab,var(--badge) 60%, transparent);
  color:var(--text);
  padding:10px 12px;
}

input[type="range"]{
  width:260px;
}

input:focus,
select:focus,
textarea:focus{
  box-shadow: 0 0 0 1px var(--input-focus-ring);
  border-color: var(--input-border-focus);
  outline: none;
}

input:hover,
select:hover,
textarea:hover{
  background: var(--input-bg);
  border-color: var(--input-border-hover);
}

/* ======= Table ======= */
table{ width:100%; border-collapse:collapse }
th,td{ border-bottom:1px solid var(--border); padding:10px; text-align:left; vertical-align:top }
thead th{ position:sticky; top:0; background:var(--table-header-bg); color:var(--table-header-text); z-index:2; user-select:none }
#previewScroll{ overflow:auto; max-height:520px; border-radius:12px; border:1px solid var(--border) }

/* Numeric alignment (match your column order) */
th:nth-child(3), td:nth-child(3), /* Amount */
th:nth-child(5), td:nth-child(5), /* Amt Diff */
th:nth-child(6), td:nth-child(6)  /* Date Diff */ { text-align:right }

/* Sticky first column for long tables */
#previewScroll table td:first-child, #previewScroll table th:first-child{
  position: sticky; left: 0; background: var(--card); z-index: 3;
  box-shadow: 1px 0 0 var(--border);
}
#sentinel{ height:1px; }

/* Zebra + hover */
#previewBody tr:nth-child(odd) td{ background: color-mix(in oklab, var(--badge) 35%, transparent) }
#previewBody tr:hover td{ filter: brightness(1.03) }

/* Badges / Quality chips */
.badge{ display:inline-block; padding:2px 8px; border-radius:999px; font-size:12px; background:var(--badge);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.badge.exact{ background:var(--ok); color:#fff }
.badge.near { background:var(--near); color:#003 }
.badge.ok   { background:var(--warn); color:#111 }
.badge.none { background:var(--err); color:#fff }

.bill-import-first-cell{
  display:flex;
  align-items:center;
  gap:8px;
}
.bill-import-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
  border-radius:6px;
  border:1px solid color-mix(in oklab, var(--border) 75%, transparent);
  background: color-mix(in oklab, var(--badge) 65%, transparent);
  color: var(--text);
  font-size:12px;
  line-height:1;
  cursor:pointer;
  transition: transform .1s ease, border-color .2s ease, background .2s ease;
}
.bill-import-toggle:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--accent) 45%, var(--border));
}
.bill-import-toggle[aria-expanded="true"]{
  background: color-mix(in oklab, var(--accent) 20%, transparent);
  color: var(--accent-3);
  border-color: color-mix(in oklab, var(--accent) 50%, var(--border));
}
.bill-import-lines-row td{
  background: color-mix(in oklab, var(--badge) 40%, transparent);
}
.bill-import-lines-cell{
  padding:12px;
}
.bill-import-lines-table-wrap{
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  background: color-mix(in oklab, var(--card) 90%, transparent);
}
.bill-import-lines-table thead th{
  position: static;
  background: color-mix(in oklab, var(--table-header-bg) 70%, var(--card));
  color: var(--table-header-text);
  font-size:11px;
}
.bill-import-lines-table td{
  font-size:12px;
}
.invoice-import-lines-table{
  table-layout: fixed;
}
.invoice-import-lines-table td{
  word-break: break-word;
}

.legend{ display:flex; gap:10px; align-items:center; flex-wrap:wrap }
.legend .dot{ width:10px; height:10px; border-radius:999px; display:inline-block; margin-right:6px }
.legend .ex{ background:var(--ok) } .legend .ne{ background:var(--near) } .legend .ok{ background:var(--warn) } .legend .no{ background:var(--err) }

.stats{ display:flex; gap:12px; flex-wrap:wrap; margin:12px 0 }
.statsbar{ display:flex; justify-content:space-between; align-items:flex-start; gap:18px; flex-wrap:wrap }
.stat{
  position:relative; overflow:hidden;
  background: linear-gradient(160deg,
    color-mix(in oklab, var(--card) 86%, transparent),
    color-mix(in oklab, var(--badge) 55%, transparent));
  border:1px solid color-mix(in oklab, var(--accent) 18%, var(--border));
  border-radius:14px; padding:12px 16px; min-width:140px;
  box-shadow: 0 12px 24px rgba(8,12,24,.22);
  cursor:pointer;
  transition: transform .08s ease, box-shadow .15s ease, border-color .2s ease;
}
.stat::after{
  content:""; position:absolute; inset:0;
  background: radial-gradient(140% 100% at 15% 0%, color-mix(in oklab,var(--accent) 40%, transparent) 0%, transparent 55%);
  opacity:.0; pointer-events:none;
  transition: opacity .2s ease;
}
.stat:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-hov);
  border-color: color-mix(in oklab, var(--accent) 34%, var(--border));
}
.stat:hover::after{ opacity:.35; }
.stat.active{
  border-color: color-mix(in oklab, var(--accent) 60%, white);
  box-shadow: 0 18px 36px rgba(10, 30, 60, .32);
}
.stats-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:16px 0 0;
}
.stats-actions button{
  flex:0 1 220px;
  justify-content:center;
}
.stat .label{
  font-size: var(--step--1);
  font-weight:600;
  color: color-mix(in oklab, var(--muted) 78%, white);
  letter-spacing:.2px;
  text-transform:none;
}
.stat .value{
  margin-top:6px;
  font-size: clamp(20px, 1.4vw + 14px, 28px);
  font-weight:700;
  color: color-mix(in oklab, var(--accent) 78%, #fff);
  text-shadow: 0 6px 18px rgba(14, 122, 255, .14);
  display:flex; gap:8px; align-items:center;
}
.stat .value.err{ color: color-mix(in oklab, var(--err) 70%, #fff); text-shadow: 0 6px 18px rgba(239, 68, 68, .24); }
.stat .value.ok{ color: color-mix(in oklab, var(--ok) 70%, #fff); text-shadow: 0 6px 18px rgba(34, 197, 94, .24); }
.stat .value.warn{ color: color-mix(in oklab, var(--warn) 70%, #fff); text-shadow: 0 6px 18px rgba(245, 158, 11, .24); }
.stat .value.near{ color: color-mix(in oklab, var(--near) 70%, #fff); text-shadow: 0 6px 18px rgba(6, 182, 212, .24); }
#sparkBox{ min-width:300px; display:none }
#sparkTitle{ font-size: var(--step--1); color: var(--muted); margin-bottom:6px }

.rawprev{ margin-top:10px; border:1px dashed var(--border); border-radius:12px; padding:8px }
.sample{ font-size: var(--step--1); color: var(--muted) }
.bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin:4px 0 12px; flex-wrap:wrap }

tr.row-exact td{ background:var(--ok-bg) }
tr.row-near  td{ background:var(--near-bg) }
tr.row-ok    td{ background:var(--warn-bg) }
tr.row-none  td{ background:var(--err-bg) }

/* Busy overlay */
.busy{ position:fixed; inset:0; background:var(--overlay); display:none; align-items:center; justify-content:center; z-index:4000 }
.busy.show{ display:flex }
.busy .box{ background:var(--card); border:1px solid var(--border); border-radius:14px; padding:16px 20px; box-shadow: var(--shadow-amb), var(--shadow-key); display:flex; gap:10px; align-items:center }
.spinner{ width:18px; height:18px; border-radius:999px; border:3px solid color-mix(in oklab,var(--accent) 35%,transparent); border-top-color:var(--accent-3); animation: spin 1s linear infinite }
@keyframes spin{ to{ transform: rotate(360deg) } }

.loading-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid color-mix(in oklab,var(--accent-3) 35%, transparent);
  color:color-mix(in oklab,var(--accent-3) 70%, #fff);
  background:color-mix(in oklab,var(--accent-3) 12%, transparent);
  font-size:var(--step--1);
}

.loading-progress{
  height:6px;
  border-radius:999px;
  background:color-mix(in oklab,var(--text) 6%, transparent);
  overflow:hidden;
}
.loading-progress__bar{
  display:block;
  height:100%;
  width:0%;
  background:linear-gradient(90deg, var(--accent), var(--accent-3));
  background-size:200% 100%;
  transition: width 600ms ease;
}
.loading-progress.is-loading .loading-progress__bar{
  animation: loading-bar 1.6s linear infinite;
}
@keyframes loading-bar{
  0%{ background-position: 0% 50%; }
  100%{ background-position: 100% 50%; }
}

.loading-progress--indeterminate .loading-progress__bar{
  width:30%;
  background: linear-gradient(90deg, transparent, var(--accent-3), var(--accent), transparent);
  background-size:100% 100%;
  animation: indeterminate-bar 2.4s ease-in-out infinite;
}
.loading-progress--indeterminate.is-loading .loading-progress__bar{
  animation: indeterminate-bar 2.4s ease-in-out infinite;
}
@keyframes indeterminate-bar{
  0%{ transform: translateX(-120%); }
  100%{ transform: translateX(320%); }
}

/* Modals (frosted) */
.modal{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background: transparent; z-index:10000; backdrop-filter: none; padding:0; }
.modal.show{ display:flex }
.panel{ background:var(--card); border:1px solid var(--border); border-radius:14px; padding:16px; width:min(1000px,95vw); max-height:90vh; box-shadow:0 18px 40px rgba(0,0,0,0.45); display:flex; flex-direction:column; gap:8px }
.panel header{ position:sticky; top:0; z-index:1; display:flex; align-items:center; justify-content:space-between;
  background: linear-gradient(180deg, color-mix(in oklab,var(--card) 96%, transparent), color-mix(in oklab,var(--card) 92%, transparent));
  border-bottom:1px solid var(--border); padding-bottom:8px; margin-bottom:8px;
}
.panel h3{ margin:0; font-size: var(--step-1) }
.panel .toprow{ display:flex; gap:8px; align-items:center }
.panel textarea{ flex:1; min-height:300px; background:var(--card); color:var(--text); border:1px solid var(--border); border-radius:10px; padding:10px; font-family: ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; font-size:12px; white-space:pre; overflow:auto }
.panel .actions{ display:flex; justify-content:space-between; align-items:center }

/* Density */
body.compact th, body.compact td{ padding:6px 7px }
body.compact .stat{ min-width:110px; padding:10px 12px }

/* Merchant Review */
.mr-stats{ display:flex; gap:12px; flex-wrap:wrap }
.mr-box{ display:grid; grid-template-columns:1fr 1fr; gap:16px }
.mr-small{ font-size: var(--step--1); color: var(--muted) }
.mr-suggestions{ max-height:280px; overflow:auto; border:1px solid var(--border); border-radius:12px }
.chip{ display:inline-flex; align-items:center; gap:6px; padding:2px 8px; border-radius:999px; border:1px solid var(--border); background:var(--badge); font-size:12px }
.chip button{ border:0; background:transparent; color:var(--err); cursor:pointer }

/* Skeleton rows */
.skel{ position:relative; overflow:hidden; border-radius:6px; height:18px; background: color-mix(in oklab, var(--badge) 50%, transparent) }
.skel::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, color-mix(in oklab,var(--badge) 65%, transparent), transparent);
  animation: shimmer 1.1s infinite; transform: translateX(-100%);
}
@keyframes shimmer{ to{ transform: translateX(100%) } }

/* Toasts */
#toast{ position:fixed; right:16px; bottom:16px; z-index:99999; display:none }
.toast{
  background: var(--card); border:1px solid var(--border); box-shadow: var(--shadow-amb), var(--shadow-key);
  border-radius: 12px; padding:10px 14px; margin-top:8px; display:flex; gap:10px; align-items:center; color: var(--text);
  min-width:220px;
}
.toast .toast-icon{
  font-size:16px;
  line-height:1;
}
.toast .toast-msg{ flex:1; }
.toast.toast-success .toast-icon{ color: var(--ok); }
.toast.toast-error .toast-icon{ color: var(--err); }
.toast.toast-warn .toast-icon{ color: var(--warn); }
.toast.toast-info .toast-icon{ color: var(--near); }

/* Themed scrollbars */
#previewScroll::-webkit-scrollbar{ height:10px; width:12px }
#previewScroll::-webkit-scrollbar-track{ background: color-mix(in oklab,var(--badge) 70%, transparent); border-radius: 8px }
#previewScroll::-webkit-scrollbar-thumb{
  background: color-mix(in oklab,var(--accent) 30%, var(--border));
  border-radius: 8px; border: 2px solid transparent; background-clip: padding-box;
}
#previewScroll{ scrollbar-width: thin; scrollbar-color: color-mix(in oklab,var(--accent) 30%, var(--border)) transparent }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}

/* Endless scroll polish: non-breaking, CSS-only */
#previewScroll {
  scrollbar-gutter: stable;
  overscroll-behavior: contain;
  touch-action: pan-y;
}
@media (prefers-reduced-motion: no-preference) {
  #previewScroll { scroll-behavior: smooth; }
}

/* Modernize pack (CSS-only, no JS changes) */
#previewScroll thead th{ position: sticky; top: 0; z-index: 1; }
#previewScroll tbody tr:nth-child(even){ background: color-mix(in oklab, Canvas 92%, black); }
#previewScroll tbody tr:hover{ background: color-mix(in oklab, Canvas 88%, black); }
.col-amount, .col-diff, .col-qty{ text-align: right; font-variant-numeric: tabular-nums; }
.col-merchant{ max-width: 28ch; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
:focus-visible{ outline: 2px solid color-mix(in oklab, var(--accent, #3b82f6) 65%, white); outline-offset: 2px; }
@media (prefers-contrast: more){ .btn,.btn-outline{ border-width: 2px; } }
@media (forced-colors: active){ .chip,.badge{ border: 1px solid CanvasText; } }
@media print{
  header,.quick,#errorsCard,#busy,#toast{ display:none!important; }
  #previewScroll{ max-height:none; overflow:visible; border:none; }
  table{ font-size:12px; }
  .badge{ border:1px solid #000; background:#fff; color:#000; }
}

/* Beta X: Fluid type scale (CSS-only, safe) */
html { font-size: clamp(14px, 1.6vw, 16px); }

/* Beta Y: Gradient borders, subtle elevation, tactile buttons (CSS-only) */
.card, #errorsCard, #mrCard, #previewCard {
  box-shadow: 0 1px 2px rgba(0,0,0,.05), 0 8px 24px rgba(0,0,0,.08);
  border-radius: .75rem;
  background-clip: padding-box;
  border: 1px solid color-mix(in oklab, Canvas 85%, black);
}
.btn, .btn-outline {
  transition: transform .06s ease, box-shadow .12s ease;
  box-shadow: 0 1px 1px rgba(0,0,0,.04);
}
.btn:active, .btn-outline:active {
  transform: translateY(1px);
}
.btn-outline {
  background:
    linear-gradient(Canvas, Canvas) padding-box,
    linear-gradient(120deg, color-mix(in oklab, var(--accent) 40%, white), transparent 60%) border-box;
  border: 1px solid transparent;
  border-radius: .6rem;
}

/* Beta Z: Themed scrollbars (CSS-only; degrades gracefully) */
#previewScroll { scrollbar-width: thin; scrollbar-color: color-mix(in oklab, var(--accent) 50%, CanvasText) color-mix(in oklab, Canvas 96%, black); }
#previewScroll::-webkit-scrollbar { width: 12px; height: 12px; }
#previewScroll::-webkit-scrollbar-track { background: color-mix(in oklab, Canvas 96%, black); }
#previewScroll::-webkit-scrollbar-thumb {
  background: color-mix(in oklab, var(--accent) 55%, CanvasText);
  border-radius: 10px;
  border: 3px solid color-mix(in oklab, Canvas 96%, black);
}

/* Frosted modals (degrades gracefully) */
.modal-backdrop{ position:fixed; inset:0; background:transparent; backdrop-filter: none; -webkit-backdrop-filter: none; }
.modal{ background: color-mix(in oklab, Canvas 92%, white); border-radius: .8rem; border:1px solid color-mix(in oklab, Canvas 85%, black); box-shadow: 0 8px 40px rgba(0,0,0,.25); }
/* Skeleton loading (safe: purely visual) */
@keyframes shimmerSweep{ 0%{background-position:-40% 0} 100%{background-position:140% 0} }
body.skeleton-on #previewScroll{ position:relative; }
body.skeleton-on #previewScroll::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  background-size: 220% 100%; animation: shimmerSweep 1.2s infinite linear;
}
body.skeleton-on #previewScroll tbody{ opacity:.45; filter:grayscale(.25); }

#clContent{max-height:65vh;overflow-y:auto;padding-right:8px;}

/* Panel containment & responsive grid */
#devModal .panel, .dev-panel { overflow: hidden; }
#devModal .panel, .dev-panel, #devModal .panel *, .dev-panel * { box-sizing: border-box; }
#tmv20Extras, .tmv20-row, .tmv20-grid, .tmv20-tint { max-width: 100%; }
#tmv20Extras, .tmv20-row { grid-column: 1 / -1; width: 100%; }
.tmv20-row{ padding-top:12px; border-top:1px solid var(--border, rgba(0,0,0,.12)); }
.tmv20-grid{
  display:grid;
  width:100%;
  grid-template-columns: minmax(240px,1fr) minmax(240px,1fr);
  gap:18px;
  align-items:center;
}
@media (max-width: 980px){
  .tmv20-grid{ grid-template-columns:minmax(0,1fr); }
}
.tmv20-check{ display:flex; align-items:center; gap:10px; min-width:0; }
.tmv20-tint{ display:flex; align-items:center; gap:10px; min-width:0; width:100%; }
.tmv20-tint .label{ white-space:nowrap; min-width:96px; opacity:.9; }
.tmv20-tint input[type="range"]{ flex:1 1 auto; width:100%; min-width:0; max-width:100%; }
.tmv20-tint output{ white-space:nowrap; min-width:42px; text-align:left; }

.pane-disabled-message{
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
  background: color-mix(in oklab, var(--badge) 12%, transparent);
  font-weight:600;
}
.pane-disabled-message p{
  margin:8px 0 0;
}
[data-theme="dark"]{ --ok:#22c55e; --near:#06b6d4; --warn:#f59e0b; }

#bootOverlay{
  display:none;
}
#bootOverlay .boot-spinner{
  width:22px;
  height:22px;
  border-radius:999px;
  border:3px solid color-mix(in oklab,var(--accent) 28%, transparent);
  border-top-color: var(--accent-3);
  animation: spin 0.5s linear infinite;
}
  #bootOverlay .boot-msg{
    font-size: var(--step-0);
    font-weight:600;
    letter-spacing:.2px;
  }

/* Lock badge shown next to Matched PO when a row is locked */
.lock-badge { margin-left: 6px; font-size: 12px; opacity: .9; }

html { scrollbar-gutter: stable; }
#clModal{
  background: rgba(6,10,18,0.68);
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
}
#clModal .panel{
  background: linear-gradient(180deg, rgba(17,26,44,0.98), rgba(12,18,32,0.98));
  border: 1px solid rgba(86,108,146,0.45);
  box-shadow: 0 18px 50px rgba(0,0,0,0.55);
  max-height: min(70vh, 560px);
  overflow-y: auto !important;
}
#clModal .panel header{
  background: linear-gradient(180deg, rgba(21,32,56,0.98), rgba(17,26,44,0.92));
  border-bottom: 1px solid rgba(86,108,146,0.35);
}

/* Radar login hero */
.radar-panel{
  max-width:960px;
  width:100%;
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
}
.radar-card{
  display:flex;
  flex-wrap:wrap;
  gap:32px;
  padding:32px;
  border-radius:22px;
  background:linear-gradient(135deg,rgba(255,255,255,0.04),rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.06);
}
.radar-copy{
  flex:1 1 320px;
  min-width:260px;
}
.radar-panel form{
  max-width:520px;
}
.radar-callout{
  background:linear-gradient(135deg, rgba(30,37,60,0.92), rgba(12,15,28,0.8));
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.07);
  padding:18px 20px;
  margin-bottom:16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 10px 30px rgba(0,0,0,0.45);
}
.radar-callout h2{
  margin:0 0 8px;
  font-size:1.9rem;
  letter-spacing:0.08em;
}
.radar-callout p{
  margin:0;
  color:var(--muted);
}
.radar-status{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.radar-status-pill{
  border:1px solid var(--border-strong);
  background:var(--surface-subtle);
  border-radius:999px;
  padding:6px 14px;
  font-size:0.85rem;
  color:var(--muted);
}
.radar-panel input{
  background:
    linear-gradient(180deg, rgba(31,37,60,0.92), rgba(12,15,28,0.92));
  border:1px solid rgba(255,255,255,0.12);
  color:#f6f8ff;
  border-radius:22px;
  box-shadow:
    inset 0 1px 2px rgba(255,255,255,0.06),
    inset 0 3px 14px rgba(0,0,0,0.55);
  padding:14px 18px;
  height:54px;
}
.radar-panel input::placeholder{
  color:rgba(246,248,255,0.45);
}
.radar-panel input:focus{
  border-color:var(--accent);
  box-shadow:
    0 0 0 3px rgba(123,245,255,0.25),
    inset 0 1px 2px rgba(255,255,255,0.08);
}
.radar-visual{
  flex:1 1 300px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:240px;
}
.radar-scope{
  position:relative;
  width:320px;
  max-width:100%;
  aspect-ratio:1;
  border-radius:50%;
  border:2px solid rgba(10,215,255,0.25);
  box-shadow:0 0 30px rgba(10,215,255,0.2);
}
.radar-scope::before,
.radar-scope::after{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:50%;
  border:1px solid rgba(10,215,255,0.15);
}
.radar-scope::after{
  inset:48px;
  opacity:0.7;
}
.radar-sweep{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:conic-gradient(from 0deg, rgba(10,215,255,0.35), transparent 60%);
  animation:radar-spin 6s linear infinite;
}
.radar-dot{
  position:absolute;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#7bf5ff;
  box-shadow:0 0 16px rgba(123,245,255,0.8);
}
.radar-dot-a{ top:28%; left:68%; }
.radar-dot-b{ top:58%; left:24%; }
.radar-dot-c{ top:72%; left:64%; }
@keyframes radar-spin{
  to{ transform:rotate(360deg); }
}
@media (max-width: 720px){
  .radar-card{ padding:24px; }
  .radar-status{ flex-direction:column; }
  .radar-scope{ width:260px; }
}


