/* ========== BOGEMA Dashboard — brand CSS ========== */
:root, [data-theme="dark"] {
  --bg-0: #000000;
  --bg-1: #0D0D0D;
  --bg-2: #161616;
  --bg-card: rgba(255,255,255,0.03);
  --bg-card-hover: rgba(255,255,255,0.06);
  --border: rgba(245,243,241,0.10);
  --border-hover: rgba(198,178,153,0.35);
  --text-1: #F5F3F1;
  --text-2: #9E9E9E;
  --text-3: #6B6B6B;
  --beige: #C6B299;
  --gold-1: #D4AF37;
  --gold-2: #A8872E;
  --accent-emerald: #054218;
  --accent-teal:    #0992C3;
  --accent-violet:  #7F07A2;
  --accent-pudra:   #C7B2CC;
  --success: #9FB87B;
  --warn:    #D89B4A;
  --danger:  #C06464;
  --shadow: 0 8px 32px rgba(0,0,0,0.6);

  /* Theming helpers */
  --grad-1-color: 198,178,153;
  --grad-2-color: 9,146,195;
  --grad-alpha: 0.05;
  --noise-opacity: 0.4;
  --noise-blend: overlay;

  /* Delta badges (tuned for dark bg) */
  --delta-up-bg: rgba(159,184,123,0.18);
  --delta-up-fg: #C5DAA2;
  --delta-down-bg: rgba(192,100,100,0.22);
  --delta-down-fg: #E89999;
  --delta-flat-bg: rgba(107,107,107,0.18);
  --delta-flat-fg: #B5B5B5;

  /* Surface helpers (для hover/muted поверхностей) */
  --surface-hover: rgba(255,255,255,0.04);
  --surface-soft: rgba(255,255,255,0.06);
  --surface-softest: rgba(255,255,255,0.03);
  --surface-bar-bg: rgba(255,255,255,0.05);
  --surface-divider: rgba(255,255,255,0.06);
  --dd-menu-bg: #161616;

  /* Категорийная палитра графиков — dark: приглушённая премиальная */
  --chart-1: #C6B299;  /* beige — лиды */
  --chart-2: #0992C3;  /* teal — успехи */
  --chart-3: #D4AF37;  /* gold — сумма */
  --chart-4: #C06464;  /* danger — отказы */
  --chart-5: #7F07A2;  /* violet — конверсия */
  --chart-6: #4AA3C9;  /* sky */
  --chart-7: #D89B4A;  /* amber */
  --chart-8: #9FB87B;  /* green */
  --chart-fill-alpha: 0.08;
}

[data-theme="light"] {
  --bg-0: #FAFAF7;
  --bg-1: #FFFFFF;
  --bg-2: #F4F1EC;
  --bg-card: #FFFFFF;
  --bg-card-hover: #FBF9F5;
  --border: #E7E2D9;
  --border-hover: #C6B299;
  --text-1: #0F0F10;
  --text-2: #4B4B4F;
  --text-3: #8A8A90;
  --beige: #8C6F4F;
  --gold-1: #B8902A;
  --gold-2: #8A6B1F;
  --accent-emerald: #0C7A3A;
  --accent-teal:    #0B7DA8;
  --accent-violet:  #7A25A2;
  --accent-pudra:   #B492C0;
  --success: #16A34A;
  --warn:    #C98012;
  --danger:  #DC2626;
  --shadow: 0 1px 2px rgba(15,15,16,0.04), 0 8px 24px rgba(15,15,16,0.06);

  --grad-1-color: 184,144,42;
  --grad-2-color: 11,125,168;
  --grad-alpha: 0.05;
  --noise-opacity: 0;
  --noise-blend: normal;

  --delta-up-bg: rgba(22,163,74,0.12);
  --delta-up-fg: #15803D;
  --delta-down-bg: rgba(220,38,38,0.10);
  --delta-down-fg: #B91C1C;
  --delta-flat-bg: rgba(107,114,128,0.10);
  --delta-flat-fg: #4B5563;

  --surface-hover: rgba(15,15,16,0.04);
  --surface-soft: rgba(15,15,16,0.04);
  --surface-softest: rgba(15,15,16,0.02);
  --surface-bar-bg: rgba(15,15,16,0.06);
  --surface-divider: rgba(15,15,16,0.08);
  --dd-menu-bg: #FFFFFF;

  /* light: то же, что dark, но чуть темнее для контраста на белом */
  --chart-1: #8C6F4F;
  --chart-2: #0B7DA8;
  --chart-3: #B8902A;
  --chart-4: #DC2626;
  --chart-5: #7A25A2;
  --chart-6: #2E8BB8;
  --chart-7: #C98012;
  --chart-8: #16A34A;
  --chart-fill-alpha: 0.12;
}

/* ===== Тема 3: vivid — красочная сдержанно-яркая ===== */
[data-theme="vivid"] {
  --bg-0: #FBF8F3;
  --bg-1: #FFFFFF;
  --bg-2: #F3EEE6;
  --bg-card: #FFFFFF;
  --bg-card-hover: #FDFAF4;
  --border: #EDE6D8;
  --border-hover: #C8B89A;
  --text-1: #1A1D2E;
  --text-2: #5B6175;
  --text-3: #9CA3AF;
  --beige: #8C6F4F;
  --gold-1: #B8902A;
  --gold-2: #8A6B1F;
  --accent-emerald: #10B981;
  --accent-teal:    #14B8A6;
  --accent-violet:  #8B5CF6;
  --accent-pudra:   #F4C5D0;
  --success: #10B981;
  --warn:    #F59E0B;
  --danger:  #F43F5E;
  --shadow: 0 2px 12px rgba(26,29,46,0.06), 0 8px 32px rgba(26,29,46,0.08);

  --grad-1-color: 16,185,129;
  --grad-2-color: 139,92,246;
  --grad-alpha: 0.04;
  --noise-opacity: 0;
  --noise-blend: normal;

  /* Яркие дельты — сочные фоны */
  --delta-up-bg: #D1FAE5;
  --delta-up-fg: #065F46;
  --delta-down-bg: #FFE4E6;
  --delta-down-fg: #9F1239;
  --delta-flat-bg: #EEF2FF;
  --delta-flat-fg: #3730A3;

  --surface-hover: rgba(26,29,46,0.04);
  --surface-soft: rgba(26,29,46,0.04);
  --surface-softest: rgba(26,29,46,0.02);
  --surface-bar-bg: rgba(26,29,46,0.06);
  --surface-divider: rgba(26,29,46,0.08);
  --dd-menu-bg: #FFFFFF;

  /* Живая цветная палитра */
  --chart-1: #10B981;  /* emerald — лиды */
  --chart-2: #6366F1;  /* indigo — успехи */
  --chart-3: #F59E0B;  /* amber — сумма */
  --chart-4: #F43F5E;  /* rose — отказы */
  --chart-5: #8B5CF6;  /* violet — конверсия */
  --chart-6: #14B8A6;  /* teal — просмотры */
  --chart-7: #FB923C;  /* orange — квалифицированные */
  --chart-8: #EC4899;  /* pink — организация */
  --chart-fill-alpha: 0.16;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg-0); color: var(--text-1); font-family: 'Montserrat', system-ui, -apple-system, sans-serif; font-weight: 300; }
body {
  background:
    radial-gradient(ellipse at 20% 10%, rgba(var(--grad-1-color), var(--grad-alpha)), transparent 60%),
    radial-gradient(ellipse at 80% 90%, rgba(var(--grad-2-color), var(--grad-alpha)), transparent 60%),
    var(--bg-0);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background-color 0.3s, color 0.3s;
}
body::before {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.07'/></svg>");
  opacity: var(--noise-opacity); mix-blend-mode: var(--noise-blend);
}
.container { position: relative; z-index: 1; max-width: 1440px; margin: 0 auto; padding: 40px 32px 80px; }

/* ========== Header ========== */
.hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.brand { display: flex; align-items: center; gap: 20px; }
.brand .logo { width: 64px; height: 64px; }
.brand .logo svg { width: 100%; height: 100%; }
.brand .title { display: flex; flex-direction: column; }
.brand .title .name { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; letter-spacing: 8px; color: var(--text-1); }
.brand .title .desc { font-size: 10px; font-weight: 300; letter-spacing: 4px; color: var(--text-2); text-transform: uppercase; margin-top: 2px; }
.hdr .meta { text-align: right; }
.hdr .meta .period { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: var(--text-2); }
.hdr .meta .date-val { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--beige); margin-top: 4px; }
.hdr .nav a { color: var(--text-2); text-decoration: none; margin-left: 24px; font-size: 11px; letter-spacing: 3px; text-transform: uppercase; transition: color 0.2s; }
.hdr .nav a:hover, .hdr .nav a.active { color: var(--beige); }

/* ========== Hero / section titles ========== */
.section-title { display: flex; align-items: baseline; justify-content: space-between; margin: 48px 0 20px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.section-title h2 { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; letter-spacing: 4px; color: var(--text-1); margin: 0; text-transform: uppercase; }
.section-title .sub { font-size: 11px; letter-spacing: 3px; color: var(--text-3); text-transform: uppercase; }

/* ========== KPI tiles ========== */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 16px; }
.kpi {
  position: relative; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 2px; padding: 28px 28px 24px; backdrop-filter: blur(12px);
  transition: border-color 0.3s, background 0.3s; overflow: hidden;
}
.kpi:hover { border-color: var(--border-hover); background: var(--bg-card-hover); }
.kpi::before {
  content: ''; position: absolute; top: 0; left: 0; width: 32px; height: 1px;
  background: linear-gradient(90deg, var(--gold-1), transparent);
}
/* В vivid-теме KPI-тайлы получают тонкую цветную полоску слева (одного цвета, а не радугой) */
[data-theme="vivid"] .kpi {
  box-shadow: var(--shadow);
  border-radius: 10px;
  border: 1px solid var(--border);
}
[data-theme="vivid"] .kpi::before {
  left: 0; top: 0; width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--chart-1), var(--chart-2));
  border-radius: 10px 0 0 10px;
}
[data-theme="vivid"] .card {
  box-shadow: var(--shadow);
  border-radius: 10px;
}
.kpi .label { font-size: 10px; letter-spacing: 4px; color: var(--text-2); text-transform: uppercase; margin-bottom: 14px; }
.kpi .value { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; color: var(--text-1); line-height: 1; letter-spacing: -1px; }
.kpi .value .unit { font-size: 20px; color: var(--beige); margin-left: 4px; letter-spacing: 0; }
.kpi .sub { font-size: 11px; color: var(--text-3); margin-top: 10px; letter-spacing: 1px; }
.kpi .sub strong { color: var(--beige); font-weight: 400; }

/* 2-column compact KPI */
.kpi-grid.compact { grid-template-columns: repeat(2, 1fr); }
.kpi-grid.six { grid-template-columns: repeat(6, 1fr); }
.kpi-grid.six .kpi .value { font-size: 30px; }

/* ========== Card / chart container ========== */
.card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 2px; padding: 24px; backdrop-filter: blur(12px);
  transition: border-color 0.3s;
}
.card:hover { border-color: var(--border-hover); }
.card h3 { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 300; letter-spacing: 2px; color: var(--text-1); margin: 0 0 4px; text-transform: uppercase; }
.card .hint { font-size: 10px; color: var(--text-3); letter-spacing: 2px; text-transform: uppercase; margin-bottom: 20px; }
.insight { display: block; background: rgba(198,178,153,0.06); border-left: 2px solid var(--beige); padding: 10px 14px; margin: 16px 0 0; font-size: 12px; color: var(--text-2); letter-spacing: 0.3px; line-height: 1.55; }
.insight strong { color: var(--beige); font-weight: 400; }
.insight .insight-rec { display: inline-block; margin-top: 6px; color: var(--text-1); font-style: normal; font-weight: 300; letter-spacing: 0.3px; }
.insight:empty { display: none; }

/* ========== План / Факт (конверсия в успех) ========== */
.plan-fact-card {
  background: rgba(198,178,153,0.04);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 14px 18px;
  margin: 18px 0 0;
}
.plan-fact-card:empty { display: none; }
.pf-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 10px; flex-wrap: wrap; }
.pf-title { font-size: 10px; letter-spacing: 2px; color: var(--text-3); text-transform: uppercase; }
.pf-values { display: flex; align-items: baseline; gap: 6px; font-variant-numeric: tabular-nums; }
.pf-fact { font-size: 22px; font-weight: 400; letter-spacing: 0.5px; }
.pf-fact.pf-good   { color: var(--success); }
.pf-fact.pf-warn   { color: var(--warn); }
.pf-fact.pf-danger { color: var(--danger); }
.pf-sep { color: var(--text-3); font-size: 18px; }
.pf-plan { color: var(--text-2); font-size: 13px; }
.pf-bar { padding: 6px 0; }
.pf-bar-track {
  position: relative;
  height: 8px;
  background: rgba(128,128,128,0.12);
  border-radius: 4px;
  overflow: visible;
}
.pf-bar-fill { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 4px; transition: width 0.3s ease; }
.pf-bar-fill.pf-good   { background: linear-gradient(90deg, var(--success), var(--success)); }
.pf-bar-fill.pf-warn   { background: linear-gradient(90deg, var(--warn), var(--warn)); }
.pf-bar-fill.pf-danger { background: linear-gradient(90deg, var(--danger), var(--danger)); }
.pf-bar-marker {
  position: absolute; top: -3px; bottom: -3px;
  width: 2px;
  background: var(--beige);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.12);
}
.pf-bar-marker::after {
  content: 'ПЛАН'; position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  font-size: 8px; letter-spacing: 1.5px; color: var(--beige); white-space: nowrap;
}
.pf-foot { display: flex; align-items: center; gap: 6px; font-size: 12px; margin-top: 8px; letter-spacing: 0.3px; }
.pf-foot.pf-good   { color: var(--success); }
.pf-foot.pf-warn   { color: var(--warn); }
.pf-foot.pf-danger { color: var(--danger); }
.pf-arrow { font-size: 14px; }
.pf-delta { font-weight: 400; font-variant-numeric: tabular-nums; }
.pf-note { color: var(--text-2); }

/* Grid layouts */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-2-1 { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }

/* ========== Tables ========== */
.tbl { width: 100%; border-collapse: collapse; font-size: 12px; margin-top: 8px; }
.tbl th, .tbl td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.tbl th { font-size: 10px; letter-spacing: 2px; color: var(--text-3); text-transform: uppercase; font-weight: 400; }
.tbl td { color: var(--text-1); }
.tbl td.num { text-align: right; color: var(--beige); font-variant-numeric: tabular-nums; }
.tbl tr:hover td { background: var(--surface-softest); }

/* Progress bar */
.bar { display: inline-block; height: 4px; background: var(--surface-bar-bg); border-radius: 2px; overflow: hidden; width: 100px; vertical-align: middle; margin-left: 8px; }
.bar span { display: block; height: 100%; background: linear-gradient(90deg, var(--beige), var(--gold-1)); }

/* Chart wrapper */
.chart { width: 100%; height: 340px; margin-top: 8px; }
.chart.tall { height: 420px; }
.chart.xtall { height: 560px; }

/* ========== Metric tabs (plan page) ========== */
.metric-tabs {
  display: flex; gap: 4px; margin-bottom: 10px;
  border-bottom: 1px solid var(--surface-divider);
}
.metric-tabs .tab {
  padding: 8px 14px; font-size: 11px; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--text-3);
  background: transparent; border: none; cursor: pointer;
  border-bottom: 2px solid transparent;
  font-family: 'Montserrat', sans-serif; font-weight: 400;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.metric-tabs .tab:hover { color: var(--text-2); }
.metric-tabs .tab.active {
  color: var(--text-1);
  border-bottom-color: var(--beige);
}

/* ========== Matrix table (plan page) ========== */
.tbl-scroll { overflow-x: auto; margin: 0 -4px; }
.tbl.matrix { font-size: 11px; min-width: 900px; }
.tbl.matrix thead th { padding: 6px 4px; font-size: 10px; }
.tbl.matrix thead th.now { color: var(--beige); background: rgba(198,178,153,0.08); }
.tbl.matrix thead th.total { background: var(--surface-1); }
.tbl.matrix td { padding: 6px 4px; vertical-align: middle; }
.tbl.matrix td.future { opacity: 0.5; }
.tbl.matrix td.future .plan-only { color: var(--text-3); font-size: 10px; }
.tbl.matrix td.empty { color: var(--text-3); opacity: 0.35; }
.tbl.matrix td .pf { display: block; font-size: 11px; line-height: 1.1; }
.tbl.matrix td .pf .fc3 { color: var(--text-3); }
.tbl.matrix td .pfp { display: block; font-size: 9px; margin-top: 2px; }
.tbl.matrix td .fact-bold { font-weight: 500; color: var(--text-1); }
.tbl.matrix td.total { background: var(--surface-1); }
.tbl.matrix tr.matrix-total td {
  border-top: 2px solid var(--border);
  font-weight: 500;
  background: var(--surface-1);
}

/* ========== Legend chips ========== */
.legend-mini {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--surface-divider);
  font-size: 11px; color: var(--text-2);
}
.legend-mini .chip {
  display: inline-block; width: 10px; height: 10px;
  border-radius: 2px; background: var(--c, var(--text-3));
  margin-right: 6px; vertical-align: middle;
}
.chart.short { height: 260px; }

/* ========== Filter bar ========== */
.filter-bar {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 2px;
  padding: 16px 20px;
  backdrop-filter: blur(12px);
  margin: 0 0 8px;
  transition: border-color 0.3s;
}
.filter-bar:hover { border-color: var(--border-hover); }

.fb-presets {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 14px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.fb-preset {
  background: transparent; color: var(--text-2);
  border: 1px solid var(--border); border-radius: 2px;
  padding: 6px 14px;
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  font-family: inherit; font-weight: 300;
  cursor: pointer; transition: all 0.2s;
}
.fb-preset:hover { color: var(--beige); border-color: var(--border-hover); }

.fb-row {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 20px;
}
.fb-group { display: flex; flex-direction: column; gap: 6px; min-width: 140px; }
.fb-label {
  font-size: 9px; letter-spacing: 2px; color: var(--text-3);
  text-transform: uppercase;
}

.fb-months { flex: 1 1 auto; min-width: 280px; }
.fb-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.fb-chip {
  background: transparent; color: var(--text-1);
  border: 1px solid var(--border); border-radius: 20px;
  padding: 6px 14px;
  font-size: 11px; letter-spacing: 1px;
  font-family: inherit; font-weight: 300;
  cursor: pointer; transition: all 0.2s;
  min-width: 52px;
}
.fb-chip:hover { border-color: var(--border-hover); }
.fb-chip.active {
  background: rgba(198,178,153,0.15); color: var(--beige);
  border-color: var(--beige);
}

.fb-dd { position: relative; }
.fb-dd-btn {
  background: transparent; color: var(--text-1);
  border: 1px solid var(--border); border-radius: 2px;
  padding: 8px 10px; min-width: 160px; max-width: 240px;
  font-size: 11px; font-family: inherit; font-weight: 300;
  cursor: pointer; transition: all 0.2s;
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
.fb-dd-btn:hover { border-color: var(--border-hover); }
.fb-dd.open .fb-dd-btn { border-color: var(--beige); color: var(--beige); }
.fb-dd-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; text-align: left; }
.fb-dd-badge {
  background: var(--beige); color: var(--bg-0);
  border-radius: 10px; padding: 1px 8px;
  font-size: 10px; font-weight: 500;
}
.fb-dd-arrow { color: var(--text-3); font-size: 10px; }
.fb-dd-menu {
  display: none;
  position: absolute; top: calc(100% + 4px); left: 0; z-index: 100;
  background: var(--dd-menu-bg); border: 1px solid var(--border-hover);
  border-radius: 2px; min-width: 220px; max-width: 320px;
  max-height: 280px; overflow-y: auto;
  padding: 6px; box-shadow: var(--shadow);
}
.fb-dd.open .fb-dd-menu { display: block; }
.fb-dd-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; cursor: pointer; font-size: 11px;
  color: var(--text-1); border-radius: 2px;
  transition: background 0.15s;
}
.fb-dd-item:hover { background: var(--surface-hover); }
.fb-dd-item input { accent-color: var(--beige); cursor: pointer; margin: 0; }
.fb-dd-item span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.fb-clear {
  background: transparent; color: var(--text-3);
  border: 1px solid var(--border); border-radius: 2px;
  padding: 8px 16px;
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  font-family: inherit; font-weight: 300;
  cursor: pointer; transition: all 0.2s; align-self: flex-end;
}
.fb-clear:hover { color: var(--danger); border-color: var(--danger); }

.fb-counter {
  margin-top: 12px; padding-top: 10px;
  border-top: 1px solid var(--border);
  font-size: 11px; letter-spacing: 1px; color: var(--text-3);
}
.fb-counter strong { color: var(--beige); font-weight: 400; }

/* ========== KPI delta ========== */
.kpi .sub .delta {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 400; letter-spacing: 0;
}
.kpi .sub .delta-note { color: var(--text-3); font-size: 10px; margin-left: 4px; }

/* ========== KPI delta badge (яркие цветные плашки) ========== */
.kpi .delta-badge-wrap {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin-top: 12px;
}
.delta-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px;
  border-radius: 999px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 500; letter-spacing: 0.3px;
  line-height: 1;
  border: 1px solid transparent;
  transition: transform 0.2s;
}
.delta-badge .arrow { font-size: 11px; }
.delta-badge.up {
  background: var(--delta-up-bg);
  color: var(--delta-up-fg);
  border-color: rgba(22,163,74,0.18);
}
.delta-badge.down {
  background: var(--delta-down-bg);
  color: var(--delta-down-fg);
  border-color: rgba(220,38,38,0.18);
}
.delta-badge.flat {
  background: var(--delta-flat-bg);
  color: var(--delta-flat-fg);
}
[data-theme="dark"] .delta-badge.up { border-color: rgba(159,184,123,0.28); }
[data-theme="dark"] .delta-badge.down { border-color: rgba(192,100,100,0.32); }
.kpi:hover .delta-badge { transform: translateX(2px); }
.delta-note {
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text-3);
}

/* ========== Theme toggle ========== */
.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  margin-left: 20px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-2);
  cursor: pointer;
  transition: all 0.2s;
  vertical-align: middle;
}
.theme-toggle:hover {
  color: var(--beige);
  border-color: var(--border-hover);
}
.theme-toggle svg { width: 16px; height: 16px; }
/* Управление видимостью 3 иконок: по одной на тему */
.theme-toggle .icon-sun, .theme-toggle .icon-palette { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="light"] .theme-toggle .icon-moon,
[data-theme="light"] .theme-toggle .icon-palette { display: none; }
[data-theme="light"] .theme-toggle .icon-sun { display: block; }
[data-theme="vivid"] .theme-toggle .icon-moon,
[data-theme="vivid"] .theme-toggle .icon-sun { display: none; }
[data-theme="vivid"] .theme-toggle .icon-palette { display: block; }
[data-theme="vivid"] .theme-toggle { color: var(--accent-violet); border-color: var(--accent-violet); }
[data-theme="vivid"] .theme-toggle:hover { color: var(--success); border-color: var(--success); }

/* ========== Refuse card (плашка отказов у воронки) ========== */
.refuse-card {
  margin-top: 16px;
  padding: 16px 18px;
  background: rgba(192,100,100,0.06);
  border: 1px solid rgba(192,100,100,0.25);
  border-left: 2px solid var(--danger);
  border-radius: 2px;
}
.refuse-card:empty { display: none; }
.rc-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 12px; margin-bottom: 10px;
  padding-bottom: 10px; border-bottom: 1px solid var(--surface-divider);
}
.rc-title {
  font-size: 10px; letter-spacing: 3px; color: var(--danger);
  text-transform: uppercase; font-weight: 400;
}
.rc-share { text-align: right; }
.rc-big {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px; font-weight: 300; color: var(--text-1);
  letter-spacing: -0.5px; line-height: 1;
}
.rc-sub {
  display: block; font-size: 10px; color: var(--text-3);
  letter-spacing: 1px; margin-top: 4px;
}
.rc-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.rc-list li {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 12px;
}
.rc-reason { color: var(--text-1); letter-spacing: 0.3px; }
.rc-num { color: var(--beige); font-variant-numeric: tabular-nums; font-size: 11px; }

/* ========== Badge "мусор" в таблице причин ========== */
.badge-muted {
  display: inline-block;
  background: var(--surface-soft);
  color: var(--text-3);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1px 8px;
  font-size: 9px; letter-spacing: 1px; text-transform: uppercase;
  margin-left: 6px; vertical-align: middle;
}

/* ========== Junk-toggle в филтр-баре ========== */
.fb-junk { min-width: 160px; }
.fb-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; color: var(--text-1); cursor: pointer;
  padding: 7px 10px;
  border: 1px solid var(--border); border-radius: 2px;
  transition: border-color 0.2s;
  user-select: none;
}
.fb-toggle:hover { border-color: var(--border-hover); }
.fb-toggle input {
  accent-color: var(--beige); cursor: pointer; margin: 0;
}
.fb-toggle span { letter-spacing: 0.3px; }

.fb-hint {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: 10px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text-3);
  background: var(--surface-softest);
  border: 1px solid var(--border);
  border-radius: 10px;
}

/* ========== NPS status banner ========== */
.nps-status {
  display: none;
  margin: 8px 0 24px;
  padding: 14px 18px;
  border-radius: 2px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  font-size: 12px;
  letter-spacing: 0.5px;
  color: var(--text-2);
}
.nps-status strong { color: var(--text-1); font-weight: 400; }
.nps-status-info { border-left: 2px solid var(--beige); }
.nps-status-error { border-left: 2px solid var(--danger); color: var(--text-1); }
.nps-status-error strong { color: var(--danger); }

/* ========== Footer ========== */
.ftr { margin-top: 80px; padding-top: 24px; border-top: 1px solid var(--border); text-align: center; color: var(--text-3); font-size: 10px; letter-spacing: 3px; text-transform: uppercase; }

/* ========== Plotly hover tooltip — принудительно по теме ========== */
/* Plotly funnel иногда игнорит hoverlabel в trace; переопределяем SVG напрямую */
.hovertext > path {
  fill: #161616 !important;
  stroke: var(--beige) !important;
}
.hovertext > text,
.hovertext > text tspan,
.hovertext .name,
.hovertext .nums,
g.hovertext text {
  fill: var(--text-1) !important;
}
/* Светлые темы — белый фон тултипа + тёмный текст */
[data-theme="light"] .hovertext > path,
[data-theme="vivid"] .hovertext > path {
  fill: #FFFFFF !important;
  stroke: var(--beige) !important;
}
[data-theme="light"] .hovertext > text,
[data-theme="light"] .hovertext > text tspan,
[data-theme="light"] .hovertext .name,
[data-theme="light"] .hovertext .nums,
[data-theme="light"] g.hovertext text,
[data-theme="vivid"] .hovertext > text,
[data-theme="vivid"] .hovertext > text tspan,
[data-theme="vivid"] .hovertext .name,
[data-theme="vivid"] .hovertext .nums,
[data-theme="vivid"] g.hovertext text {
  fill: var(--text-1) !important;
}

/* ========== Views card (плашка реальных просмотров) ========== */
.views-card {
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(9,146,195,0.06);
  border: 1px solid rgba(9,146,195,0.22);
  border-left: 2px solid var(--accent-teal);
  border-radius: 2px;
}
.views-card:empty { display: none; }
.vc-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 12px; margin-bottom: 10px;
  padding-bottom: 10px; border-bottom: 1px solid var(--surface-divider);
}
.vc-title {
  font-size: 10px; letter-spacing: 3px; color: var(--accent-teal);
  text-transform: uppercase; font-weight: 400;
}
.vc-big {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px; font-weight: 300; color: var(--text-1);
  letter-spacing: -0.5px; line-height: 1;
  text-align: right;
}
.vc-big small {
  display: block; font-size: 10px; color: var(--text-3);
  letter-spacing: 1px; margin-top: 4px; font-family: 'Montserrat', sans-serif;
}
.vc-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px;
  margin-bottom: 10px;
}
.vc-cell {
  padding: 10px 12px;
  background: var(--surface-1);
  border: 1px solid var(--surface-divider);
  border-radius: 2px;
}
.vc-cell .lbl {
  font-size: 9px; letter-spacing: 2px; color: var(--text-3);
  text-transform: uppercase; margin-bottom: 6px;
}
.vc-cell .num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 300; color: var(--text-1);
  letter-spacing: -0.5px; line-height: 1;
}
.vc-cell.past .num  { color: var(--text-1); }
.vc-cell.fut .num   { color: var(--accent-teal); }
.vc-cell.gap .num   { color: var(--text-2); }
.vc-foot {
  font-size: 11px; color: var(--text-2); line-height: 1.5;
}
.vc-foot strong { color: var(--text-1); font-weight: 400; }
.vc-foot .warn   { color: var(--danger); }
.vc-foot .ok     { color: var(--success); }

/* ========== Segment card (С просмотром vs Без просмотра) ========== */
.segment-card {
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(198,178,153,0.05);
  border: 1px solid rgba(198,178,153,0.22);
  border-left: 2px solid var(--beige);
  border-radius: 2px;
}
.segment-card:empty { display: none; }
.sc-title {
  font-size: 10px; letter-spacing: 3px; color: var(--beige);
  text-transform: uppercase; font-weight: 400;
  margin-bottom: 10px; padding-bottom: 10px;
  border-bottom: 1px solid var(--surface-divider);
}
.sc-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  margin-bottom: 10px;
}
.sc-col {
  padding: 12px 14px;
  background: var(--surface-1);
  border: 1px solid var(--surface-divider);
  border-radius: 2px;
}
.sc-col .head {
  font-size: 10px; letter-spacing: 2px; color: var(--text-2);
  text-transform: uppercase; margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
}
.sc-col .head .dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
}
.sc-col.yes .head .dot { background: var(--accent-teal); }
.sc-col.no  .head .dot { background: var(--text-3); }
.sc-col .rows { display: grid; gap: 6px; }
.sc-col .row {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 8px; padding: 4px 0;
  border-bottom: 1px dashed var(--surface-divider);
}
.sc-col .row:last-child { border-bottom: none; }
.sc-col .row .k {
  font-size: 10px; color: var(--text-3); letter-spacing: 1px; text-transform: uppercase;
}
.sc-col .row .v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; font-weight: 300; color: var(--text-1);
  letter-spacing: -0.3px;
}
.sc-foot {
  font-size: 11px; color: var(--text-2); line-height: 1.5;
}
.sc-foot strong { color: var(--text-1); font-weight: 400; }

/* ========== Responsive ========== */
@media (max-width: 900px) {
  .kpi-grid, .kpi-grid.six, .grid-2, .grid-3, .grid-2-1 { grid-template-columns: 1fr; }
  .hdr { flex-direction: column; align-items: flex-start; gap: 16px; }
  .hdr .meta { text-align: left; }
  .vc-row, .sc-grid { grid-template-columns: 1fr; }
}
