/* ====== Reset & Tokens ====== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
input { font: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
a { color: inherit; text-decoration: none; }

:root {
  /* Palette */
  --bg: #FFFFFF;
  --page-bg: #F7F7F9;
  --ink-900: #0F1115;
  --ink-800: #1A1D24;
  --ink-700: #2C313B;
  --ink-600: #4B5159;
  --ink-500: #6B7280;
  --ink-400: #9097A2;
  --ink-300: #B7BCC4;
  --line: #ECEEF1;
  --line-2: #E5E7EB;
  --line-3: #F2F3F5;

  /* Brand */
  --brand: #5B46E5;
  --brand-600: #4F3CD6;
  --brand-50: #EFEBFF;
  --brand-100: #E3DDFF;

  /* Sidebar */
  --sb-bg-top: #1C1D26;
  --sb-bg-bot: #14151D;
  --sb-text: #D6D8DE;
  --sb-text-dim: #8C8F99;
  --sb-label: #8C8F99;
  --sb-hover: #25262F;
  --sb-active: #5B46E5;
  --sb-divider: #2A2C36;

  /* Status */
  --green: #10B981;
  --green-700: #047857;
  --green-lt: #34D399;
  --red: #EF4444;
  --orange: #F59E0B;
  --blue: #2563EB;

  /* Engagement labels */
  --eng-high: #E11D48;   /* red-ish on screenshot */
  --eng-good: #2563EB;
  --eng-excellent: #10B981;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(15,17,21,.04);
  --shadow-card: 0 1px 2px rgba(15,17,21,.04), 0 1px 0 rgba(15,17,21,.02);

  --r-sm: 8px;
  --r-md: 10px;
  --r-lg: 12px;
  --r-xl: 14px;
  --r-2xl: 18px;

  --sidebar-w: 224px;
  --rail-w: 324px;
}

html, body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink-900);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ====== App layout ====== */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr);
  min-height: 100vh;
  background: var(--bg);
}

/* ============================================================
   SIDEBAR
============================================================ */
.sidebar {
  position: sticky; top: 0;
  height: 100vh;
  background: linear-gradient(180deg, var(--sb-bg-top), var(--sb-bg-bot));
  color: var(--sb-text);
  display: flex; flex-direction: column;
  padding: 14px 14px 12px;
  border-right: 1px solid #000;
}
.sidebar__top { padding: 2px 4px 8px; }
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 8px; color: inherit;
  transition: background .15s ease, color .15s ease;
}
.icon-btn:hover { background: rgba(255,255,255,.06); }

.sidebar__nav { flex: 1; overflow-y: auto; padding-top: 10px; }
.sidebar__nav::-webkit-scrollbar { width: 0; }

.nav-section + .nav-section { margin-top: 18px; }
.nav-label {
  font-size: 10px; font-weight: 600;
  letter-spacing: .12em; color: var(--sb-label);
  padding: 0 12px 8px;
}

.nav-item {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 13.5px; font-weight: 500;
  color: #D6D8DE;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
  white-space: nowrap;
}
.nav-item svg { color: #B0B4BD; flex-shrink: 0; }
.nav-item:hover { background: var(--sb-hover); color: #fff; }
.nav-item:hover svg { color: #fff; }
.nav-item.is-active {
  background: var(--brand);
  color: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,.05) inset;
}
.nav-item.is-active svg { color: #fff; }
.nav-item .badge {
  margin-left: auto;
  background: var(--brand);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  min-width: 20px; height: 20px;
  border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 6px;
}
.nav-item.is-active .badge { background: rgba(255,255,255,.18); }

/* Bottom area */
.sidebar__bottom { padding-top: 10px; flex-shrink: 0; }
.trial-card {
  background: #25262F;
  border: 1px solid #313340;
  border-radius: 12px;
  padding: 14px 14px 12px;
  margin-bottom: 12px;
}
.trial-card__head {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: #fff;
  margin-bottom: 6px;
  white-space: nowrap;
}
.trial-card__icon {
  width: 22px; height: 22px; border-radius: 6px;
  background: var(--brand); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.trial-card p {
  margin: 0 0 12px;
  font-size: 11.5px; color: #A6AAB4; line-height: 1.45;
  text-wrap: pretty;
}
.trial-card__cta {
  width: 100%;
  background: var(--brand); color: #fff;
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 12.5px; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s ease;
}
.trial-card__cta:hover { background: var(--brand-600); }

.profile-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 6px;
  border-radius: 10px;
  margin-bottom: 6px;
}
.profile-row__avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(180deg, #383A47, #25272F);
  color: #fff; font-size: 12px; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid #34363F;
}
.profile-row__meta { line-height: 1.2; flex: 1; min-width: 0; }
.profile-row__name { font-size: 12.5px; font-weight: 600; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.profile-row__plan { font-size: 11px; color: #95989F; }
.profile-row__chev { width: 26px; height: 26px; }

.collapse-btn {
  width: 100%;
  display: flex; align-items: center; gap: 8px;
  padding: 9px 10px;
  border-top: 1px solid var(--sb-divider);
  font-size: 12.5px; color: #C9CCD3;
  margin-top: 4px;
}
.collapse-btn:hover { color: #fff; }

/* ============================================================
   MAIN
============================================================ */
.main-wrap {
  display: flex; flex-direction: column;
  min-width: 0;
}

/* TOPBAR */
.topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 24px;
  background: #fff;
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 10;
}
.search {
  flex: 1; max-width: 520px;
  position: relative;
  height: 38px;
  background: #F4F5F7;
  border: 1px solid #ECEEF1;
  border-radius: 10px;
  display: flex; align-items: center;
  padding: 0 14px 0 38px;
  transition: border-color .15s ease, background .15s ease;
}
.search:focus-within { background: #fff; border-color: #D9DDE3; }
.search__icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--ink-400); }
.search input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font-size: 13.5px; color: var(--ink-900);
}
.search input::placeholder { color: var(--ink-400); }
.kbd {
  font-size: 11px; color: var(--ink-500);
  background: #fff; border: 1px solid #E2E5EA;
  border-radius: 6px;
  padding: 2px 7px;
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
}

.topbar__actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 10px;
}
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  height: 38px; padding: 0 16px;
  border-radius: 10px;
  font-size: 13px; font-weight: 600;
  transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease;
  white-space: nowrap;
}
.btn--ghost { background: #fff; border: 1px solid #E2E5EA; color: var(--ink-800); }
.btn--ghost:hover { background: #F4F5F7; }
.btn--primary { background: var(--brand); color: #fff; }
.btn--primary:hover { background: var(--brand-600); }
.btn--sm { height: 32px; padding: 0 12px; font-size: 12.5px; border-radius: 8px; gap: 6px; }

.topbar__bell { width: 38px; height: 38px; border-radius: 10px; color: var(--ink-700); border: 1px solid transparent; position: relative; }
.topbar__bell:hover { background: #F4F5F7; }
.bell-dot {
  position: absolute; top: 9px; right: 10px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--brand);
  border: 2px solid #fff;
}
.topbar__avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(180deg, #2A2C36, #14151B);
  color: #fff; font-size: 13px; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
}

/* CONTENT */
.content {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--rail-w);
  gap: 20px;
  padding: 22px 24px 8px;
  align-items: flex-start;
}

/* Sections that live below the main fold (full width across center + rail) */
.below-fold {
  padding: 14px 24px 36px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* CENTER */
.center { min-width: 0; }

.page-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  margin-bottom: 18px;
}
.page-head h1 {
  margin: 0 0 4px;
  font-size: 24px; font-weight: 700; letter-spacing: -0.01em; color: var(--ink-900);
}
.page-sub { margin: 0; color: var(--ink-500); font-size: 13.5px; }
.how-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 36px; padding: 0 14px 0 8px;
  background: #fff; border: 1px solid var(--line-2);
  border-radius: 999px;
  font-size: 13px; color: var(--ink-800); font-weight: 500;
  box-shadow: var(--shadow-sm);
}
.how-btn:hover { background: #F8F8FB; }
.how-btn__play {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--brand); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}

/* FILTERS */
.filters {
  display: flex; align-items: stretch; gap: 8px;
  margin-bottom: 18px;
  flex-wrap: nowrap;
}
.filter {
  flex: 1 1 0; min-width: 110px;
  background: #fff;
  border: 1px solid var(--line-2);
  border-radius: 12px;
  padding: 9px 12px;
  text-align: left;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.filter:hover { border-color: #D2D6DD; }
.filter__label { font-size: 11px; color: var(--ink-500); margin-bottom: 2px; white-space: nowrap; }
.filter__value {
  font-size: 13.5px; font-weight: 600; color: var(--ink-900);
  display: flex; align-items: center; justify-content: flex-start; gap: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.filter__value > svg:last-child { margin-left: auto; flex-shrink: 0; color: var(--ink-500); }
.filter__value svg { color: var(--ink-500); flex-shrink: 0; }
.filter__value--stack { line-height: 1.15; font-size: 12.5px; }

.filter--platform .filter__platforms { gap: 4px; }
.filter__platforms { display: flex; align-items: center; }
.plat {
  width: 22px; height: 22px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.plat--ig { background: linear-gradient(45deg, #FEDA75, #FA7E1E 25%, #D62976 55%, #962FBF 80%, #4F5BD5); }
.plat--tt { background: #111;}
.plat--yt { background: #FF0033; }
.filter__chev { margin-left: auto; color: var(--ink-500); }

.filter--more {
  flex: 0 1 110px;
  min-width: 96px;
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
}
.filter--more > svg { color: var(--ink-700); }

.filter-link {
  flex: 0 0 auto;
  font-size: 13px; font-weight: 600;
  color: var(--brand);
  padding: 8px 8px;
  white-space: nowrap;
}
.filter-link:hover { color: var(--brand-600); }

/* TABLE CARD */
.table-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 18px;
}
.table-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
}
.table-head__count { font-size: 13.5px; font-weight: 600; color: var(--ink-900); white-space: nowrap; }
.sort {
  display: inline-flex; align-items: center; gap: 6px;
  background: #fff; border: 1px solid var(--line-2);
  border-radius: 8px; padding: 6px 10px;
  font-size: 12.5px; color: var(--ink-700);
}
.sort strong { font-weight: 600; color: var(--ink-900); }
.sort svg { color: var(--ink-500); }
.sort:hover { background: #F8F8FB; }

.table { display: flex; flex-direction: column; }
.row {
  display: grid;
  grid-template-columns: 44px 2fr 0.75fr 0.85fr 1.1fr 0.75fr 1.7fr;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
  transition: background .15s ease;
}
.row:last-child { border-bottom: 0; }
.row:not(.row--head):hover { background: #FAFAFC; }
.row--head {
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  background: #FBFBFD;
}
.row--head .cell { font-size: 11.5px; font-weight: 500; color: var(--ink-500); }

.cell { font-size: 13.5px; color: var(--ink-900); white-space: nowrap; }
.cell--check { display: flex; align-items: center; }
.cell--num { font-weight: 600; }
.cell--creator { display: flex; align-items: center; gap: 12px; }
.cell--actions { display: flex; align-items: center; justify-content: flex-end; gap: 6px; }

.row--head .cell--num { font-weight: 500; text-align: left; }
.row--head .cell--actions { justify-content: flex-end; padding-right: 26px; }

input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--brand);
  border-radius: 4px;
  border: 1px solid var(--line-2);
  cursor: pointer;
}

.avatar {
  position: relative;
  width: 40px; height: 40px; border-radius: 50%;
  background: #EEE center/cover no-repeat;
  flex-shrink: 0;
}
.avatar--lg { width: 42px; height: 42px; }
.platform-dot {
  position: absolute; right: -2px; bottom: -2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid #fff;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
}
.platform-dot--ig { background: linear-gradient(45deg, #FEDA75, #FA7E1E 25%, #D62976 55%, #962FBF 80%, #4F5BD5); }
.platform-dot--tt { background: #111; }
.platform-dot--yt { background: #FF0033; }
.platform-dot--x { background: #000; }

.creator-meta { line-height: 1.25; }
.creator-name {
  display: flex; align-items: center; gap: 4px;
  font-size: 14px; font-weight: 600; color: var(--ink-900);
  white-space: nowrap;
}
.creator-handle { font-size: 12.5px; color: var(--ink-500); margin-top: 1px; white-space: nowrap; }
.creator-niche { font-size: 12px; color: var(--ink-500); margin-top: 1px; white-space: nowrap; }
.verified { display: inline-flex; align-items: center; }

.metric { font-size: 14px; font-weight: 600; color: var(--ink-900); display: flex; align-items: center; gap: 6px; }
.metric--strong { font-weight: 600; }
.metric-sub { font-size: 11.5px; font-weight: 500; margin-top: 2px; }
.metric-sub--high { color: var(--eng-high); }
.metric-sub--good { color: var(--eng-good); }
.metric-sub--excellent { color: var(--green); }
.metric-sub--vgood { color: var(--green); }

.dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }
.dot--green { background: var(--green); }
.dot--green-lt { background: var(--green-lt); }

/* Pagination */
.table-foot {
  padding: 14px 18px;
  display: flex; justify-content: center;
  border-top: 1px solid var(--line);
}
.pager {
  display: inline-flex; align-items: center; gap: 4px;
}
.pager__btn {
  min-width: 32px; height: 32px;
  padding: 0 10px;
  border-radius: 8px;
  font-size: 12.5px; font-weight: 600;
  color: var(--ink-700);
  border: 1px solid transparent;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.pager__btn:hover { background: #F4F5F7; }
.pager__btn--active { background: var(--brand); color: #fff; }
.pager__btn--active:hover { background: var(--brand-600); }
.pager__dots { color: var(--ink-400); padding: 0 6px; font-weight: 600; }
.pager__btn--more { color: var(--ink-400); }

/* FEATURES */
.features {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  background: #F4F1FF;
  border-radius: 14px;
  padding: 22px 24px;
  margin-bottom: 0;
}
.feature {
  display: flex; gap: 12px; align-items: flex-start;
}
.feature__icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: #fff; border: 1px solid #E7E2FF;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.feature__title { font-size: 13.5px; font-weight: 600; color: var(--ink-900); margin-bottom: 4px; }
.feature p { margin: 0; font-size: 12.5px; color: var(--ink-600); line-height: 1.5; }

/* INSIGHTS */
.insights__head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 12px;
  margin-bottom: 14px;
}
.insights h2 {
  margin: 0 0 4px;
  font-size: 19px; font-weight: 700; letter-spacing: -0.01em;
}
.insights__sub { margin: 0; color: var(--ink-500); font-size: 13px; }
.insights__view {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--brand); font-size: 13px; font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.insights__view:hover { color: var(--brand-600); }

.article-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.article {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.article:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(15,17,21,.06);
  border-color: var(--line-2);
}
.article__img {
  height: 130px; position: relative;
  background: #1F2330 center/cover no-repeat;
}
.chip {
  position: absolute; top: 10px; left: 10px;
  background: rgba(255,255,255,.92);
  color: var(--ink-900);
  font-size: 11px; font-weight: 600;
  padding: 4px 8px; border-radius: 6px;
  backdrop-filter: blur(6px);
  white-space: nowrap;
}
.article__body { padding: 14px 14px 14px; }
.article__body h3 {
  margin: 0 0 6px;
  font-size: 14px; font-weight: 600; line-height: 1.35; color: var(--ink-900);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.article__body p {
  margin: 0 0 10px;
  font-size: 12px; color: var(--ink-500); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.article__meta { display: flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--ink-400); }
.dot-sep { opacity: .7; }

/* ============================================================
   RIGHT RAIL
============================================================ */
.rail {
  display: flex; flex-direction: column; gap: 14px;
}
.rail-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px;
}
.rail-card h3 { margin: 0 0 12px; font-size: 14px; font-weight: 700; color: var(--ink-900); }
.rail-sub { margin: -8px 0 12px; font-size: 12px; color: var(--ink-500); }
.rail-card__head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: nowrap;
}
.rail-card__head h3 { margin: 0; white-space: nowrap; }
.rail-dd {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500; color: var(--ink-700);
  background: #fff; border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: 5px 9px;
  white-space: nowrap;
  flex-shrink: 0;
}
.rail-dd:hover { background: #F8F8FB; }

.kpi-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  column-gap: 18px;
}
.kpi { min-width: 0; }
.kpi__label { font-size: 11.5px; color: var(--ink-500); margin-bottom: 6px; line-height: 1.35; white-space: nowrap; }
.kpi__row { display: flex; align-items: baseline; gap: 6px; white-space: nowrap; }
.kpi__val { font-size: 20px; font-weight: 700; letter-spacing: -0.01em; color: var(--ink-900); }
.trend { font-size: 11px; font-weight: 600; flex-shrink: 0; }
.trend--up { color: var(--green); }
.trend--down { color: var(--red); }

/* Donut */
.donut-row { display: flex; align-items: center; gap: 12px; }
.donut { position: relative; flex-shrink: 0; }
.donut__center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  line-height: 1.1;
}
.donut__num { font-size: 17px; font-weight: 700; color: var(--ink-900); }
.donut__lbl { font-size: 10.5px; color: var(--ink-500); margin-top: 2px; }

.legend { display: flex; flex-direction: column; gap: 9px; flex: 1; min-width: 0; }
.legend li {
  display: grid; grid-template-columns: 10px minmax(0, 1fr) auto; gap: 6px; align-items: center;
  font-size: 11.5px;
  min-width: 0;
  white-space: nowrap;
}
.legend .lg-label { color: var(--ink-700); overflow: hidden; text-overflow: ellipsis; }
.lg-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.lg-label { color: var(--ink-700); }
.legend li { min-width: 0; }
.lg-val { color: var(--ink-900); font-weight: 600; }

/* Niches */
.niche-list { display: flex; flex-direction: column; gap: 10px; }
.niche-list li {
  display: grid; grid-template-columns: 64px 1fr auto;
  align-items: center; gap: 10px;
  font-size: 12.5px;
}
.niche-name { color: var(--ink-700); }
.niche-val { color: var(--ink-900); font-weight: 600; }
.niche-bar {
  display: block; width: 100%; height: 6px; border-radius: 999px;
  background: #F2F3F5; overflow: hidden;
}
.niche-bar span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--brand), #7B66FF);
  border-radius: 999px;
}

/* Platforms */
.platform-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.plat-tile {
  background: #FAFAFC;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 10px;
  text-align: center;
  min-width: 0;
}
.plat-tile__ic {
  width: 36px; height: 36px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 8px;
}
.plat-tile__ic--ig { background: linear-gradient(45deg, #FEDA75, #FA7E1E 25%, #D62976 55%, #962FBF 80%, #4F5BD5); }
.plat-tile__ic--tt { background: #111; }
.plat-tile__ic--yt { background: #FF0033; }
.plat-tile__ic--x  { background: #000; }
.plat-tile__pct { font-size: 16px; font-weight: 700; color: var(--ink-900); }
.plat-tile__lbl { font-size: 11px; color: var(--ink-500); margin-top: 2px; }

/* Rail promo card */
.rail-promo {
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  color: var(--navy);
  overflow: hidden;
  padding: 18px 18px 20px;
}
.rail-promo::before {
  content: '';
  position: absolute;
  right: -40px; bottom: -40px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: rgba(91,70,229,0.04);
  pointer-events: none;
}
.rail-promo::after {
  content: '';
  position: absolute;
  left: -20px; top: -20px;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(91,70,229,0.03);
  pointer-events: none;
}
.rail-promo__chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9.5px; font-weight: 700; letter-spacing: 0.06em;
  color: var(--brand);
  background: var(--brand-50);
  padding: 4px 8px; border-radius: 999px;
  margin-bottom: 12px;
  position: relative; z-index: 2;
}
.rail-promo h3 {
  margin: 0 0 8px;
  font-size: 17px; font-weight: 700;
  color: var(--navy);
  letter-spacing: -0.005em;
  position: relative; z-index: 2;
}
.rail-promo p {
  margin: 0 0 16px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  position: relative; z-index: 2;
}
.rail-promo__avatars {
  display: flex; align-items: center;
  margin-bottom: 16px;
  position: relative; z-index: 2;
}
.rail-promo__avatars span {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: #EEE center/cover no-repeat;
  border: 2px solid #fff;
  margin-left: -8px;
}
.rail-promo__avatars span:first-child { margin-left: 0; }
.rail-promo__avatars .more {
  background: var(--brand-50);
  color: var(--brand);
  font-size: 10px;
  font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
}
.rail-promo__cta {
  width: 100%;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  background: var(--brand);
  color: #fff;
  border-radius: 9px;
  padding: 9px 12px;
  font-size: 12.5px; font-weight: 700;
  transition: background .15s ease, transform .15s ease;
  position: relative; z-index: 2;
}
.rail-promo__cta:hover { background: var(--brand-600); }

/* ============================================================
   ROUTES
============================================================ */
.route { display: none; }
.route.is-active { display: block; }
.route-pad { padding: 22px 24px 36px; }
.route-pad .page-head { margin-bottom: 22px; }

.stat-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.stat-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
}
.stat-card__label { font-size: 11.5px; color: var(--ink-500); }
.stat-card__val { font-size: 22px; font-weight: 700; letter-spacing: -0.01em; margin-top: 6px; }
.stat-card__trend { font-size: 11.5px; color: var(--ink-500); margin-top: 4px; font-weight: 500; }

/* Campaign list */
.campaign-list { display: flex; flex-direction: column; }
.campaign-list li {
  display: grid;
  grid-template-columns: 44px minmax(0, 1.6fr) repeat(3, minmax(0, 0.8fr)) auto auto;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
}
.campaign-list li:last-child { border-bottom: 0; }
.campaign-list li:hover { background: #FAFAFC; }
.campaign-cover { width: 44px; height: 44px; border-radius: 10px; }
.campaign-meta { min-width: 0; }
.campaign-name { font-size: 14px; font-weight: 600; color: var(--ink-900); }
.campaign-sub { font-size: 12px; color: var(--ink-500); margin-top: 2px; }
.campaign-stat__l { font-size: 11px; color: var(--ink-500); }
.campaign-stat__v { font-size: 13.5px; font-weight: 600; color: var(--ink-900); margin-top: 2px; }
.status {
  font-size: 11px; font-weight: 600;
  padding: 4px 8px; border-radius: 999px;
}
.status--active { background: rgba(16,185,129,0.12); color: var(--green-700); }
.status--review { background: rgba(245,158,11,0.14); color: #B45309; }
.status--done { background: var(--line-3); color: var(--ink-600); }

/* Pipeline */
.pipeline {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.pipe-col {
  background: #F7F7F9;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  min-height: 320px;
}
.pipe-col__head {
  display: flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600;
  color: var(--ink-800);
  margin-bottom: 10px;
}
.pipe-col__head em { font-style: normal; color: var(--ink-500); margin-left: 4px; font-weight: 500; }
.pipe-dot { width: 8px; height: 8px; border-radius: 50%; }
.pipe-card {
  background: #fff; border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 8px;
}
.pipe-card:hover { border-color: #D2D6DD; box-shadow: var(--shadow-card); }
.pipe-card__name { font-size: 13px; font-weight: 600; color: var(--ink-900); }
.pipe-card__sub { font-size: 11.5px; color: var(--ink-500); margin-top: 2px; }
.pipe-card__time { font-size: 11px; color: var(--ink-400); margin-top: 6px; }

/* Chart card */
.chart-card { padding: 18px; }
.line-chart { width: 100%; height: 220px; }

/* Reports list */
.report-list { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.report-list li {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
}
.report-list li:last-child { border-bottom: 0; }
.report-list li:hover { background: #FAFAFC; }
.report-ic { width: 36px; height: 36px; border-radius: 10px; background: #F4F1FF; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.report-meta { flex: 1; min-width: 0; }
.report-name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); }
.report-sub { font-size: 12px; color: var(--ink-500); margin-top: 2px; }

/* Lists */
.list-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.list-card {
  background: #fff; border: 1px solid var(--line);
  border-radius: 12px; padding: 14px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.list-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(15,17,21,.06); }
.list-card__cover { height: 84px; border-radius: 10px; margin-bottom: 12px; }
.list-card__name { font-size: 14px; font-weight: 600; color: var(--ink-900); }
.list-card__meta { font-size: 12px; color: var(--ink-500); margin-top: 4px; }

/* Inbox */
.msg-list { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.msg-list li.msg {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
  position: relative;
}
.msg-list li:last-child { border-bottom: 0; }
.msg-list li:hover { background: #FAFAFC; cursor: pointer; }
.msg-avatar { width: 40px; height: 40px; border-radius: 50%; background: #EEE center/cover no-repeat; flex-shrink: 0; }
.msg-body { flex: 1; min-width: 0; }
.msg-row { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.msg-name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); }
.msg-time { font-size: 11.5px; color: var(--ink-400); flex-shrink: 0; }
.msg-sub { font-size: 12.5px; color: var(--ink-500); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.msg-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand); flex-shrink: 0; }
.msg--unread .msg-name { color: var(--ink-900); }
.msg--unread .msg-sub { color: var(--ink-700); font-weight: 500; }
.msg:not(.msg--unread) .msg-dot { display: none; }

/* Tasks */
.task-list { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.task-list li {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
}
.task-list li:last-child { border-bottom: 0; }
.task-list li:hover { background: #FAFAFC; }
.task-list input[type="checkbox"] { margin-top: 2px; width: 16px; height: 16px; accent-color: var(--brand); flex-shrink: 0; }
.task-name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); }
.task-name--done { color: var(--ink-400); text-decoration: line-through; }
.task-meta { display: flex; align-items: center; gap: 10px; margin-top: 4px; font-size: 11.5px; color: var(--ink-500); }
.task-tag { font-size: 10.5px; font-weight: 600; padding: 2px 8px; border-radius: 999px; }
.task-tag--high { background: rgba(225,29,72,0.12); color: #BE123C; }
.task-tag--med { background: rgba(245,158,11,0.14); color: #B45309; }
.task-tag--low { background: var(--line-3); color: var(--ink-600); }

/* Notifications */
.notif-list { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.notif-list li.notif {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
  position: relative;
}
.notif-list li:last-child { border-bottom: 0; }
.notif-list li:hover { background: #FAFAFC; }
.notif--new { background: #FBFAFF; }
.notif--new::before {
  content: ''; position: absolute; left: 6px; top: 22px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--brand);
}
.notif-ic { width: 30px; height: 30px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.notif-ic--purple { background: #F4F1FF; color: var(--brand); }
.notif-ic--green { background: rgba(16,185,129,0.14); color: var(--green-700); }
.notif-ic--orange { background: rgba(245,158,11,0.14); color: #B45309; }
.notif-ic--red { background: rgba(239,68,68,0.12); color: #B91C1C; }
.notif-text { font-size: 13px; color: var(--ink-800); }
.notif-text strong { color: var(--ink-900); font-weight: 600; }
.notif-time { font-size: 11.5px; color: var(--ink-400); margin-top: 4px; }

/* Saved Creators grid */
.saved-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
}
.saved-card {
  background: #fff; border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.saved-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(15,17,21,.06); }
.saved-card .avatar--lg { width: 60px; height: 60px; }
.saved-name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); }
.saved-sub { font-size: 12px; color: var(--ink-500); }
.saved-card .btn--sm { margin-top: 6px; }

/* Saved Searches */
.search-list { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.search-list li {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-3);
}
.search-list li:last-child { border-bottom: 0; }
.search-list li:hover { background: #FAFAFC; }
.search-ic { width: 32px; height: 32px; border-radius: 8px; background: #F4F1FF; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.search-meta { flex: 1; min-width: 0; }
.search-name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); }
.search-tags { font-size: 12px; color: var(--ink-500); margin-top: 2px; }
.search-count { font-size: 12.5px; font-weight: 600; color: var(--ink-700); }

/* Profile dropdown */
.profile-row { position: relative; cursor: pointer; }
.profile-row:hover { background: rgba(255,255,255,.04); }
.profile-menu {
  position: absolute; bottom: calc(100% + 6px); left: 0; right: 0;
  background: #1A1B22;
  border: 1px solid #2A2C36;
  border-radius: 10px;
  padding: 6px;
  display: none;
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
  z-index: 20;
}
.profile-row.is-open .profile-menu { display: block; }
.profile-menu button {
  display: flex; align-items: center; gap: 8px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 12.5px;
  color: #C9CCD3;
  text-align: left;
}
.profile-menu button:hover { background: rgba(255,255,255,.05); color: #fff; }
.profile-menu hr { border: 0; border-top: 1px solid #2A2C36; margin: 4px 0; }

/* Bell dropdown */
.bell-panel {
  position: absolute; right: 0; top: calc(100% + 6px);
  width: 320px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(15,17,21,.12);
  padding: 6px;
  display: none;
  z-index: 30;
}
.topbar__bell.is-open + .bell-panel,
.bell-panel.is-open { display: block; }
.bell-panel__head { padding: 10px 12px; font-size: 13px; font-weight: 600; }
.bell-panel ul { display: flex; flex-direction: column; }
.bell-panel li {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 12.5px; color: var(--ink-700);
}
.bell-panel li:hover { background: #FAFAFC; }
.bell-panel__time { font-size: 11px; color: var(--ink-400); margin-top: 2px; }
.bell-wrap { position: relative; }

/* Sidebar collapse toggle (manual via button) */
.sidebar.is-collapsed { padding: 14px 8px; }
.sidebar.is-collapsed .nav-item span,
.sidebar.is-collapsed .nav-label,
.sidebar.is-collapsed .trial-card,
.sidebar.is-collapsed .profile-row__meta,
.sidebar.is-collapsed .profile-row__chev,
.sidebar.is-collapsed .collapse-btn span { display: none; }
.sidebar.is-collapsed .nav-item { justify-content: center; padding: 9px; position: relative; }
.sidebar.is-collapsed .nav-item .badge {
  position: absolute; top: 2px; right: 2px;
  transform: none; min-width: 16px; height: 16px;
  font-size: 10px; padding: 0 4px;
}
.app:has(.sidebar.is-collapsed) { grid-template-columns: 64px 1fr; }
.app:has(.sidebar.is-expanded) { grid-template-columns: 216px 1fr; }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 1600px) {
  :root { --rail-w: 312px; }
}

@media (max-width: 1440px) {
  :root { --rail-w: 300px; --sidebar-w: 216px; }
  .content { gap: 16px; padding: 20px 20px 8px; }
  .below-fold { padding: 12px 20px 28px; gap: 20px; }
  .topbar { padding: 12px 20px; }
  .page-head h1 { font-size: 22px; }
  .filter { min-width: 100px; padding: 9px 10px; }
  .filter__value { font-size: 13px; }
  .filter__label { font-size: 10.5px; }
}

/* From 1300 down: tighten paddings but keep labels visible.
   user can manually collapse via the menu/collapse buttons. */
@media (max-width: 1300px) {
  :root { --sidebar-w: 200px; --rail-w: 288px; }
  .filter { padding: 8px 10px; min-width: 90px; }
  .filter__label { font-size: 10px; }
  .filter__value { font-size: 12.5px; gap: 6px; }
  .filter--platform .plat { width: 20px; height: 20px; }
  .kpi__val { font-size: 19px; }
}

@media (max-width: 1100px) {
  :root { --rail-w: 244px; }
  .filter { padding: 8px 8px; min-width: 80px; }
  .filter__label { font-size: 10px; }
  .filter__value { font-size: 12px; gap: 4px; }
}

@media (max-width: 960px) {
  .content { grid-template-columns: 1fr; }
  .rail { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .filter { padding: 9px 12px; min-width: 100px; }
  .filter__label { font-size: 10.5px; }
  .filter__value { font-size: 12.5px; }
  .table-card { overflow-x: auto; }
  .table { min-width: 720px; }
}

@media (max-width: 820px) {
  /* Auto-collapse sidebar on small screens */
  :root { --sidebar-w: 64px; }
  .sidebar:not(.is-expanded) { padding: 14px 8px; }
  .sidebar:not(.is-expanded) .nav-item span,
  .sidebar:not(.is-expanded) .nav-label,
  .sidebar:not(.is-expanded) .trial-card,
  .sidebar:not(.is-expanded) .profile-row__meta,
  .sidebar:not(.is-expanded) .profile-row__chev,
  .sidebar:not(.is-expanded) .collapse-btn span { display: none; }
  .sidebar:not(.is-expanded) .nav-item { justify-content: center; padding: 9px; position: relative; }
  .sidebar:not(.is-expanded) .sidebar__brand-name { display: none; }
  .sidebar:not(.is-expanded) .sidebar__menu { display: none; }
  .sidebar:not(.is-expanded) .sidebar__top { justify-content: center; padding-left: 0; padding-right: 0; }
  .sidebar:not(.is-expanded) .sidebar__home { justify-content: center; gap: 0; width: 100%; }
  .sidebar:not(.is-expanded) .nav-item .badge { position: absolute; top: 2px; right: 2px; transform: none; min-width: 16px; height: 16px; font-size: 10px; padding: 0 4px; }
  .filters { flex-wrap: wrap; }
  .filter { flex: 1 1 calc(33.333% - 6px); min-width: 0; }
  .filter--more { flex: 1 1 calc(33.333% - 6px); }
  .filter-link { flex: 0 1 auto; }
}

@media (max-width: 720px) {
  .topbar__actions .btn--ghost { display: none; }
  .topbar { padding: 10px 14px; gap: 8px; }
  .content { padding: 16px 14px 8px; }
  .below-fold { padding: 12px 14px 24px; }
  .filter { flex: 1 1 calc(50% - 4px); }
  .rail { grid-template-columns: 1fr; }
  .features { grid-template-columns: 1fr 1fr; padding: 16px; }
  .article-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .insights__head { flex-direction: column; align-items: flex-start; gap: 8px; }
}

/* === MOBILE-ONLY OVERFLOW GUARD ===
   Scoped to mobile only because overflow-x:hidden on body breaks
   position:sticky on the desktop sidebar and topbar. */
@media (max-width: 640px) {
  html, body { max-width: 100vw; overflow-x: hidden; }
}

/* === MOBILE HERO (hidden on desktop) === */
.mhero { display: none; }

/* === MOBILE HEADER (mhdr) + DRAWER (mdrawer) — visible only on mobile === */
.mhdr { display: none; }
.mdrawer { display: none; }
.mdrawer-backdrop { display: none; }

@media (max-width: 640px) {
  /* === MOBILE PUNCH-LINE HERO === */
  .mhero {
    display: block !important;
    padding: 22px 16px 14px;
    background: linear-gradient(180deg, #FAFBFE 0%, #fff 100%);
    border-bottom: 1px solid var(--line);
  }
  .mhero__eyebrow {
    display: inline-block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--brand);
    background: var(--brand-50);
    padding: 5px 10px;
    border-radius: 999px;
    margin-bottom: 10px;
  }
  .mhero__h1 {
    margin: 0 0 8px;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--ink-900);
  }
  .mhero__hl {
    background: linear-gradient(120deg, var(--brand) 0%, #7B6BF0 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
  .mhero__sub {
    margin: 0 0 14px;
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--ink-600);
  }
  /* === HIGHLIGHTED SEARCH BAR === */
  .mhero__searchwrap {
    position: relative;
    background: #fff;
    border: 2px solid var(--brand);
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 12px;
    height: 48px;
    box-shadow: 0 6px 18px rgba(91, 70, 229, 0.18), 0 0 0 4px rgba(91, 70, 229, 0.08);
    transition: box-shadow .15s ease, border-color .15s ease;
  }
  .mhero__searchwrap:focus-within {
    border-color: var(--brand-600);
    box-shadow: 0 8px 24px rgba(91, 70, 229, 0.28), 0 0 0 5px rgba(91, 70, 229, 0.15);
  }
  .mhero__searchicon { color: var(--brand); display: inline-flex; flex-shrink: 0; }
  .mhero__search {
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 14px;
    font-family: inherit;
    color: var(--ink-900);
    flex: 1 1 auto;
    width: 0;
    min-width: 0;
    height: 100%;
    padding: 0;
  }
  .mhero__search::placeholder { color: var(--ink-500); }
  /* Pulse ring to draw the eye */
  .mhero__searchpulse {
    position: absolute;
    inset: -2px;
    border-radius: 12px;
    pointer-events: none;
    border: 2px solid var(--brand);
    opacity: 0;
    animation: mheroPulse 2.4s ease-out infinite;
  }
  @keyframes mheroPulse {
    0% { opacity: 0.55; transform: scale(1); }
    70% { opacity: 0; transform: scale(1.06); }
    100% { opacity: 0; transform: scale(1.06); }
  }

  /* === DOWN-SIZE the existing Discover heading on mobile so it doesn't compete with the hero === */
  .page-head { margin-top: 14px !important; }
  .page-head h1 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--ink-600) !important;
    margin: 0 !important;
    letter-spacing: 0 !important;
  }
  .page-head .page-sub { display: none !important; }
  .how-btn { font-size: 12px !important; padding: 6px 10px !important; }

  /* === COMPACT FILTERS so they don't dominate the first fold === */
  .filters {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }
  .filter, .filter--more {
    min-width: 0 !important;
    padding: 9px 11px !important;
    min-height: 46px !important;
    border-radius: 9px !important;
  }
  .filter__label { font-size: 10px !important; margin-bottom: 1px !important; }
  .filter__value { font-size: 12.5px !important; gap: 4px !important; }

  /* === 1. MOBILE HEADER: logo left, CTA + hamburger right
        Position: sticky so the header floats at the top of the viewport during scroll
        (matches user spec). */
  .mhdr {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    height: 60px;
    padding: 0 14px;
    background: #fff;
    border-bottom: 1px solid var(--line);
    position: sticky !important;
    top: 0 !important;
    z-index: 200;
    gap: 8px;
  }
  .mhdr__brand { display: flex; align-items: center; gap: 9px; text-decoration: none; color: var(--ink-900); min-width: 0; flex: 0 1 auto; }
  .mhdr__icon { width: 34px; height: 34px; flex-shrink: 0; display: block; }
  .mhdr__words { display: flex; flex-direction: column; min-width: 0; line-height: 1; gap: 3px; }
  .mhdr__name { font-size: 17px; font-weight: 800; letter-spacing: -0.01em; color: #0F172A; white-space: nowrap; }
  .mhdr__tagline { font-size: 9.5px; font-weight: 500; color: #64748B; letter-spacing: 0.02em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }
  .mhdr__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
  }
  .mhdr__cta {
    background: var(--brand);
    color: #fff;
    font-weight: 700;
    font-size: 13px;
    padding: 8px 14px;
    border-radius: 8px;
    text-decoration: none;
    white-space: nowrap;
    transition: background .15s;
  }
  .mhdr__cta:active { background: var(--brand-600); }
  .mhdr__menu {
    background: transparent;
    border: 1px solid var(--line);
    border-radius: 8px;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-900);
    cursor: pointer;
    flex-shrink: 0;
    padding: 0;
  }
  .mhdr__menu:active { background: var(--brand-50); }

  /* === 2. SLIDE-IN MOBILE DRAWER (unified with internal pages — white background, marketing nav) === */
  .sidebar { display: none !important; }  /* hide homepage's app-shell sidebar on mobile */
  .mdrawer {
    display: flex !important;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    height: 100dvh;
    width: 300px;
    max-width: 85vw;
    background: #fff;
    z-index: 300;
    transform: translateX(-100%);
    transition: transform .28s cubic-bezier(.4, 0, .2, 1);
    box-shadow: 6px 0 24px rgba(0, 0, 0, 0.18);
    overflow-y: auto;
  }
  .mdrawer.is-open { transform: translateX(0); }
  .mdrawer__head { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid var(--line); }
  .mdrawer__brand { display: flex; align-items: center; gap: 9px; text-decoration: none; color: var(--ink-900); }
  .mdrawer__icon { width: 32px; height: 32px; display: block; }
  .mdrawer__words { display: flex; flex-direction: column; line-height: 1; gap: 3px; }
  .mdrawer__name { font-size: 16px; font-weight: 800; letter-spacing: -0.01em; color: #0F172A; }
  .mdrawer__tagline { font-size: 9.5px; font-weight: 500; color: #64748B; letter-spacing: 0.02em; }
  .mdrawer__close { background: transparent; border: 0; width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; color: #64748B; cursor: pointer; border-radius: 8px; padding: 0; }
  .mdrawer__close:active { background: var(--brand-50); }
  .mdrawer__nav { display: flex; flex-direction: column; padding: 8px 8px 16px; flex: 1; overflow-y: auto; }
  .mdrawer__link { display: block; padding: 13px 16px; color: #0F172A; text-decoration: none; font-size: 15px; font-weight: 600; border-radius: 8px; transition: background .12s, color .12s; }
  .mdrawer__link:hover, .mdrawer__link:active { background: var(--brand-50); color: var(--brand); }
  .mdrawer__foot { padding: 14px 16px 22px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 10px; }
  .mdrawer__cta { background: #FBBF24; color: #0F172A; font-weight: 800; font-size: 15px; padding: 13px 16px; border-radius: 10px; text-align: center; text-decoration: none; cursor: pointer; }
  .mdrawer__cta:active { transform: scale(0.98); }
  .mdrawer__sales { color: var(--brand); font-weight: 600; font-size: 14px; text-align: center; text-decoration: none; padding: 8px; }

  /* Drawer backdrop */
  .mdrawer-backdrop {
    display: block !important;
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0);
    z-index: 250;
    pointer-events: none;
    transition: background .25s ease;
    border: 0;
    cursor: pointer;
    padding: 0;
  }
  .mdrawer-backdrop.is-shown {
    background: rgba(15, 23, 42, 0.5);
    pointer-events: auto;
  }
  body.mdrawer-open { overflow: hidden; }

  /* === 3. APP LAYOUT: full width, no sidebar slot reserved === */
  .app,
  .app:has(.sidebar),
  .app:has(.sidebar.is-collapsed),
  .app:has(.sidebar.is-expanded) {
    grid-template-columns: 1fr !important;
  }
  :root { --sidebar-w: 0px !important; }
  .main-wrap, .center, .main { min-width: 0 !important; max-width: 100vw !important; }

  /* === 4. HIDE DESKTOP TOPBAR ENTIRELY === */
  /* The mobile header (.mhdr) above takes its place */
  .topbar { display: none !important; }

  /* === 5. CONTENT WRAPPER === */
  .content { padding: 16px 14px 8px !important; }
  .below-fold { padding: 12px 14px 28px !important; }

  /* === 6. DISCOVER PANEL: page-head styling already set in mobile hero section above === */
  .page-head {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px;
  }
  .how-link, .page-head a.how-link {
    align-self: center;
  }

  /* Filters: compact rules already set above (in mobile hero section), no override here */

  /* === 7. PROMOTE "Search" FROM TEXT LINK TO PROPER PRIMARY BUTTON ===
     Note: there is only one .filter-link button. JS relabels its text to "Search". */
  .filter-link {
    grid-column: 1 / -1 !important;
    background: var(--brand) !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    padding: 14px !important;
    border-radius: 12px !important;
    text-align: center !important;
    margin-top: 4px !important;
    box-shadow: 0 4px 14px rgba(91, 70, 229, 0.28) !important;
    border: 0 !important;
    cursor: pointer !important;
    width: 100% !important;
  }
  .filter-link:active { background: var(--brand-600) !important; transform: scale(0.98); }

  /* === 8. TABLE: card layout per row === */
  .table-card {
    overflow-x: visible !important;
    overflow: visible !important;
    border-radius: 12px !important;
    margin-top: 18px !important;
  }
  .table { min-width: 0 !important; max-width: 100% !important; }
  /* Higher-specificity selector beats the .row rule on display */
  .row.row--head, .row--head { display: none !important; }
  .row {
    display: grid !important;
    grid-template-columns: 24px 1fr !important;
    column-gap: 10px !important;
    row-gap: 8px !important;
    padding: 14px 12px !important;
    border-bottom: 1px solid var(--line) !important;
    min-width: 0 !important;
    width: 100% !important;
    align-items: start !important;
  }
  .cell--check {
    grid-column: 1 !important;
    grid-row: 1 !important;
    padding-top: 6px !important;
    margin: 0 !important;
  }
  .cell--creator {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
  }
  .cell--creator .creator-name { font-size: 14px !important; }
  .cell--creator .creator-handle, .cell--creator .creator-niche { font-size: 12px !important; }
  /* Each metric: label-left, value-right, full row width */
  .cell--num {
    grid-column: 1 / -1 !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 9px 12px !important;
    background: #FAFAFC !important;
    border-radius: 8px !important;
    font-size: 13.5px !important;
    font-weight: 700 !important;
    color: var(--ink-900) !important;
    white-space: normal !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .cell--num::before {
    content: attr(data-label) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--ink-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    flex-shrink: 0 !important;
  }
  .cell--num .metric, .cell--num .metric-sub {
    text-align: right !important;
    font-size: 13.5px !important;
    display: inline-block !important;
  }
  .cell--num .metric-sub {
    font-size: 11px !important;
    color: var(--ink-500) !important;
    margin-left: 6px !important;
    font-weight: 500 !important;
  }
  /* "View Profile" full-width button */
  .cell--actions {
    grid-column: 1 / -1 !important;
    display: flex !important;
    width: 100% !important;
    padding-top: 6px !important;
    gap: 8px !important;
  }
  .cell--actions .btn {
    flex: 1 1 auto !important;
    font-size: 13px !important;
    padding: 10px 14px !important;
    height: 38px !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 8px !important;
  }

  /* === 9. TABLE HEAD + FOOT === */
  .table-head {
    padding: 14px 12px !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  .table-head__count { font-size: 13px !important; font-weight: 700 !important; }
  .table-foot {
    padding: 14px 12px !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    justify-content: center !important;
  }

  /* === 10. FLOATING TOAST: bounded === */
  #kiq-toast {
    right: 12px !important;
    left: 12px !important;
    width: auto !important;
    max-width: calc(100vw - 24px) !important;
    bottom: 18px !important;
  }

  /* === 11. SECTION GUARDS === */
  section, .promo-hero, .features, .article-grid, .insights__head, .rail {
    max-width: 100% !important;
    min-width: 0 !important;
  }
  .features, .article-grid, .rail { grid-template-columns: 1fr !important; }
  .promo-hero { grid-template-columns: 1fr !important; gap: 24px !important; padding: 14px !important; }
  .promo-h { font-size: 28px !important; line-height: 1.15 !important; }
  .promo-sub, .promo-bullets, .promo-cta, .promo-fine { max-width: 100% !important; }

  /* === 12. FOOTER === */
  .site-foot__cols, .sfoot__cols { grid-template-columns: 1fr 1fr !important; gap: 24px !important; }
  .site-foot__bar { flex-direction: column !important; gap: 12px !important; align-items: flex-start !important; }
  .site-foot__legal { flex-wrap: wrap !important; gap: 12px !important; }

  /* === 13. IMAGES === */
  img, svg, video, iframe { max-width: 100% !important; height: auto !important; }
  img[width][height], svg[width][height] { height: auto !important; }
}

@media (max-width: 380px) {
  .mhdr__lockup { height: 30px; max-width: 160px; }
  .mhdr__cta { font-size: 12.5px; padding: 8px 12px; }
  .filters { grid-template-columns: 1fr !important; }
}



/* ============================================================
   PROMO HERO + DOWNSTREAM MARKETING SECTIONS
============================================================ */
.below-fold > section { margin-top: 8px; }
.below-fold > section + section { margin-top: 28px; }

/* --- PROMO HERO --- */
.promo-hero {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 32px;
  align-items: start;
  padding: 12px 8px 0;
}
.trust-pill {
  display: inline-block;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--brand);
  background: #EFEBFF;
  padding: 6px 10px; border-radius: 999px;
  margin-bottom: 18px;
}
.promo-h {
  margin: 0 0 12px;
  font-size: 36px; font-weight: 800; line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ink-900);
}
.brand-text { color: var(--brand); display: block; }
.promo-sub { margin: 0 0 18px; color: var(--ink-600); font-size: 14px; line-height: 1.6; max-width: 460px; }
.promo-bullets { display: flex; flex-direction: column; gap: 10px; margin-bottom: 22px; }
.promo-bullets li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink-800); }
.promo-bullets li svg { flex-shrink: 0; }
.promo-cta { display: flex; align-items: center; gap: 16px; margin-bottom: 14px; flex-wrap: wrap; }
.promo-cta .btn { height: 44px; padding: 0 18px; font-size: 13.5px; flex-shrink: 0; }
.promo-fine { display: flex; gap: 14px; font-size: 12.5px; color: var(--ink-500); flex-wrap: wrap; }
.promo-fine span { display: inline-flex; align-items: center; gap: 6px; }
.promo-fine svg { color: var(--brand); }

/* --- OVERVIEW CARD --- */
.overview-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 20px;
  box-shadow: 0 24px 60px rgba(91,70,229,0.06);
  position: relative;
}
.overview-head h3 { margin: 0 0 14px; font-size: 14px; font-weight: 700; color: var(--ink-900); }
.overview-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 12px; }
.ovtile { background: #FAFAFC; border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; }
.ovtile__l { font-size: 11px; color: var(--ink-500); }
.ovtile__v { font-size: 18px; font-weight: 700; color: var(--ink-900); margin-top: 4px; display: flex; align-items: baseline; gap: 6px; }
.ovtile__v .trend { font-size: 11px; }
.ovtile__den { font-size: 13px; color: var(--ink-500); font-weight: 600; }
.ovtile__sub { font-size: 11px; font-weight: 600; margin-top: 2px; }
.ovtile__sub.trend--up { color: var(--green); }

.overview-chart-wrap {
  position: relative;
  height: 240px;
  padding: 16px 16px 24px 36px;
  background: #FBFAFE;
  border-radius: 12px;
  border: 1px solid var(--line);
  margin-bottom: 12px;
}
.overview-chart { width: 100%; height: 100%; }
.overview-axis {
  position: absolute; bottom: 4px; left: 36px; right: 16px;
  display: flex; justify-content: space-between;
  font-size: 10.5px; color: var(--ink-400);
}
.overview-yaxis {
  position: absolute; top: 16px; bottom: 24px; left: 6px;
  display: flex; flex-direction: column; justify-content: space-between;
  font-size: 10.5px; color: var(--ink-400);
}
.overview-tooltip {
  position: absolute; top: 56px;
  transform: translateX(-50%);
  background: #1A1B22; color: #fff;
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 11.5px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  white-space: nowrap;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease, left .08s ease, top .08s ease;
}
.overview-tooltip.is-on { opacity: 1; }
.overview-tooltip__date { font-weight: 600; margin-bottom: 4px; }
.overview-tooltip__row { display: flex; align-items: center; gap: 6px; color: #C9CCD3; }
.overview-tooltip__row strong { color: #fff; margin-left: 4px; }
.overview-tooltip__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand); }

.overview-niches {
  position: absolute;
  right: 18px; top: 50%; transform: translateY(-40%);
  width: 200px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  box-shadow: 0 8px 24px rgba(15,17,21,0.08);
}
.overview-niches__head { font-size: 12px; font-weight: 700; color: var(--ink-900); margin-bottom: 8px; }
.overview-niches__head span { display: block; font-weight: 400; color: var(--ink-500); font-size: 10.5px; margin-top: 1px; }
.overview-niches ul { display: flex; flex-direction: column; gap: 6px; }
.overview-niches li {
  display: grid; grid-template-columns: 56px 1fr auto;
  gap: 8px; align-items: center;
  font-size: 10.5px; color: var(--ink-700);
}
.overview-niches .bar { height: 4px; border-radius: 999px; background: #F2F3F5; overflow: hidden; }
.overview-niches .bar span { display: block; height: 100%; background: var(--brand); border-radius: 999px; }
.overview-niches b { font-weight: 600; color: var(--ink-900); font-size: 10.5px; }

.overview-foot { display: flex; align-items: center; gap: 12px; }
.avatar-stack { display: flex; }
.avatar-stack span {
  width: 26px; height: 26px; border-radius: 50%;
  background: #EEE center/cover no-repeat;
  border: 2px solid #fff;
  margin-left: -8px;
}
.avatar-stack span:first-child { margin-left: 0; }
.overview-foot__txt { font-size: 12px; color: var(--ink-500); }
.overview-foot__txt strong { color: var(--ink-900); font-weight: 700; }

/* --- POWERFUL FEATURES --- */
.feat-grid__head { margin-bottom: 22px; }
.feat-grid__head h2 { margin: 0 0 6px; font-size: 26px; font-weight: 700; letter-spacing: -0.01em; }
.feat-grid__head p { margin: 0; color: var(--ink-500); font-size: 14px; }
.feat-grid__items {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.feat {
  display: flex; flex-direction: column;
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px; padding: 22px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.feat:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(15,17,21,.06); border-color: var(--line-2); }
.feat__ic {
  width: 40px; height: 40px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.feat__ic--purple { background: #F0EBFF; color: var(--brand); }
.feat__ic--green { background: #E7F8EE; color: #047857; }
.feat__ic--red { background: #FFE9EE; color: #DC2626; }
.feat__ic--blue { background: #E6F0FF; color: #2563EB; }
.feat__ic--pink { background: #FFE9F1; color: #BE185D; }
.feat__ic--teal { background: #E0F7F4; color: #0D9488; }
.feat h3 { margin: 0 0 8px; font-size: 15px; font-weight: 700; color: var(--ink-900); }
.feat p { margin: 0 0 12px; font-size: 12.5px; color: var(--ink-500); line-height: 1.55; }
.feat__lnk { color: var(--brand); font-size: 12.5px; font-weight: 600; margin-top: auto; }
.feat__lnk:hover { color: var(--brand-600); }

/* --- COMPARE --- */
.compare__head { margin-bottom: 22px; }
.compare__head h2 { margin: 0 0 6px; font-size: 24px; font-weight: 700; letter-spacing: -0.01em; }
.compare__head p { margin: 0; color: var(--ink-500); font-size: 13.5px; }
.compare__table {
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
}
.compare__row {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  align-items: stretch;
  font-size: 13px;
  border-bottom: 1px solid var(--line-3);
}
.compare__row:last-child { border-bottom: 0; }
.compare__row > .ccol {
  padding: 13px 18px;
  display: flex; align-items: center; gap: 8px;
  color: var(--ink-700);
  min-width: 0;
}
.compare__row--head > .ccol {
  background: #FAFAFC;
  font-size: 12px; font-weight: 600; color: var(--ink-700);
}
.ccol--feat { color: var(--ink-900); font-weight: 500; }

/* Our Platform column: purple-tinted column with brand border */
.ccol--ours {
  position: relative;
  background: rgba(91,70,229,0.06);
  color: var(--ink-900); font-weight: 600;
  border-left: 2px solid var(--brand);
  border-right: 2px solid var(--brand);
}
.compare__row--head > .ccol--ours {
  background: rgba(91,70,229,0.12);
  color: var(--brand);
  font-weight: 700;
  border-top: 2px solid var(--brand);
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}
.compare__row:last-child > .ccol--ours {
  border-bottom: 2px solid var(--brand);
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

.cic {
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cic--x { background: rgba(239,68,68,0.14); color: #DC2626; }
.cic--v { background: rgba(91,70,229,0.16); color: var(--brand); }
.cic--o {
  background: rgba(245,158,11,0.16);
  position: relative;
}
.cic--o::after {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #F59E0B;
}

/* --- WHAT IS --- */
.what-is {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 36px;
  align-items: stretch;
}
.what-is__left { display: flex; flex-direction: column; }
.what-is__left h2 { margin: 0 0 14px; font-size: 22px; font-weight: 700; letter-spacing: -0.01em; }
.what-is__left p { margin: 0 0 12px; color: var(--ink-600); font-size: 13.5px; line-height: 1.65; }
.what-is__bullets {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 24px;
  margin-top: 20px;
}
.what-is__bullets li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink-800); font-weight: 500; }
.wic {
  width: 28px; height: 28px; border-radius: 8px;
  background: #F0EBFF;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

.what-is__right {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: stretch;
}
.creator-card {
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  display: flex; flex-direction: column;
}
.creator-card__img {
  height: 210px; position: relative;
  background: #ddd center/cover no-repeat;
  flex-shrink: 0;
}
.creator-card__heart, .creator-card__verif {
  position: absolute;
  width: 30px; height: 30px; border-radius: 50%;
  background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.creator-card__heart { top: 12px; left: 12px; color: var(--ink-700); }
.creator-card__verif { top: 12px; right: 12px; }
.creator-card__body { padding: 14px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.creator-card__row { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.creator-card__name { font-size: 14px; font-weight: 700; color: var(--ink-900); display: flex; align-items: center; gap: 4px; }
.creator-card__handle { font-size: 11.5px; color: var(--ink-500); margin-top: 2px; }
.creator-card__tag { font-size: 10.5px; font-weight: 600; color: var(--brand); background: #F0EBFF; padding: 4px 8px; border-radius: 6px; white-space: nowrap; }
.creator-card__bio { margin: 0; font-size: 12px; color: var(--ink-600); line-height: 1.5; }
.creator-card__stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  padding: 12px 0;
  border-top: 1px solid var(--line-3);
  border-bottom: 1px solid var(--line-3);
}
.cmtr { font-size: 14px; font-weight: 700; color: var(--ink-900); }
.cmlb { font-size: 10.5px; color: var(--ink-500); margin-top: 2px; }
.creator-card__plats { display: flex; gap: 6px; flex-wrap: wrap; }
.cpb {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 8px 4px 6px; border-radius: 999px;
  color: #fff; font-size: 11px; font-weight: 600;
}
.cpb--ig { background: linear-gradient(45deg, #FEDA75, #FA7E1E 25%, #D62976 55%, #962FBF 80%, #4F5BD5); }
.cpb--tt { background: #111; }
.cpb--yt { background: #FF0033; }
.creator-card__cta { display: flex; gap: 8px; margin-top: auto; padding-top: 8px; }
.creator-card__cta .btn { flex: 1; justify-content: center; }
.creator-card__bm {
  width: 36px; height: 32px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  background: #fff;
  color: var(--ink-700);
  flex-shrink: 0;
}
.creator-card__bm:hover { background: #F4F5F7; }

.aud-demo {
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px;
  display: flex; flex-direction: column;
}
.aud-demo h3 { margin: 0 0 14px; font-size: 14px; font-weight: 700; color: var(--ink-900); }
.aud-demo__lbl { font-size: 11.5px; color: var(--ink-500); margin-bottom: 8px; }
.aud-demo__gender { margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line-3); }
.aud-demo__donut-row { display: flex; align-items: center; gap: 16px; }
.aud-demo__pcts { display: flex; flex-direction: column; gap: 6px; }
.adp { display: flex; align-items: baseline; gap: 6px; }
.adp b { font-size: 14px; font-weight: 700; color: var(--ink-900); }
.adp span { font-size: 11.5px; color: var(--ink-500); }
.aud-demo__countries ul { display: flex; flex-direction: column; gap: 8px; }
.aud-demo__countries li {
  display: grid; grid-template-columns: 90px 1fr 32px;
  gap: 8px; align-items: center;
  font-size: 11.5px; color: var(--ink-700);
}
.aud-demo__countries .bar { height: 4px; border-radius: 999px; background: #F2F3F5; overflow: hidden; }
.aud-demo__countries .bar span { display: block; height: 100%; background: var(--brand); border-radius: 999px; }
.aud-demo__countries b { font-weight: 600; color: var(--ink-900); font-size: 11.5px; text-align: right; }

/* Age bars in audience demographics */
.aud-demo__ages { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--line-3); }
.age-bars { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; align-items: end; height: 84px; padding-top: 6px; }
.age-bar {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center;
  height: 100%;
  justify-content: flex-end;
}
.age-bar__col {
  width: 100%;
  height: var(--h);
  background: linear-gradient(180deg, #E3DDFF, #BFB1FF);
  border-radius: 4px;
  min-height: 4px;
}
.age-bar__col--lead { background: linear-gradient(180deg, #7B66FF, var(--brand)); }
.age-bar b { font-size: 10px; color: var(--ink-500); font-weight: 500; }
.age-bar i { font-size: 11px; font-style: normal; font-weight: 700; color: var(--ink-900); }

.aud-demo__interests { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line-3); }
.chip-row { display: flex; flex-wrap: wrap; gap: 6px; }
.ichip {
  font-size: 11px; font-weight: 500; color: var(--brand);
  background: #F0EBFF;
  padding: 5px 10px; border-radius: 999px;
}

/* Leaderboard promo banner inside What is */
.lb-promo {
  position: relative;
  margin-top: 22px;
  border-radius: 14px;
  overflow: hidden;
  background:
    radial-gradient(100% 120% at 100% 0%, rgba(255,255,255,0.12), transparent 60%),
    linear-gradient(135deg, #5B46E5 0%, #4031B8 100%);
  color: #fff;
  padding: 16px 18px;
}
.lb-promo__bg {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(255,255,255,0.08) 0, transparent 40%),
    radial-gradient(circle at 90% 30%, rgba(255,255,255,0.08) 0, transparent 30%);
  pointer-events: none;
}
.lb-promo__content {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 16px;
  align-items: center;
  position: relative; z-index: 2;
}
.lb-promo__chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 9.5px; font-weight: 700; letter-spacing: 0.07em;
  color: #fff;
  background: rgba(255,255,255,0.18);
  padding: 5px 9px; border-radius: 999px;
  white-space: nowrap;
}
.lb-promo__chip svg { color: #FDE68A; }
.lb-promo__text h4 {
  margin: 0 0 2px;
  font-size: 15px; font-weight: 700; color: #fff;
  letter-spacing: -0.005em;
}
.lb-promo__text p {
  margin: 0;
  font-size: 12px; color: rgba(255,255,255,0.78);
  line-height: 1.45;
}
.lb-promo__cta {
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
}
.lb-promo__cta .btn {
  background: #fff;
  color: var(--brand);
  height: 36px; padding: 0 14px;
}
.lb-promo__cta .btn:hover { background: #F4F1FF; }
.lb-promo__small {
  font-size: 10.5px; color: rgba(255,255,255,0.7);
  font-weight: 500;
}

/* Testimonial card */
.testi {
  margin-top: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.testi__quote {
  display: flex; align-items: flex-start; gap: 12px;
}
.testi__quote > svg { color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.testi__quote p {
  margin: 0;
  font-size: 13px; color: var(--ink-700);
  line-height: 1.55;
}
.testi__quote b { color: var(--ink-900); font-weight: 700; }
.testi__person {
  display: flex; align-items: center; gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--line-3);
}
.testi__avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: #ddd center/cover no-repeat;
  flex-shrink: 0;
}
.testi__name { font-size: 13px; font-weight: 700; color: var(--ink-900); }
.testi__role { font-size: 11.5px; color: var(--ink-500); margin-top: 1px; }
.testi__stars {
  margin-left: auto;
  display: inline-flex; gap: 1px;
  color: #F59E0B;
}

@media (max-width: 720px) {
  .lb-promo__content { grid-template-columns: 1fr; gap: 12px; }
  .lb-promo__cta { align-items: flex-start; }
}

/* --- USE CASES --- */
.use-cases__head { margin-bottom: 22px; }
.use-cases__head h2 { margin: 0 0 6px; font-size: 22px; font-weight: 700; letter-spacing: -0.01em; }
.use-cases__head p { margin: 0; color: var(--ink-500); font-size: 13.5px; }
.use-cases__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.uc {
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px; padding: 18px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.uc:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(15,17,21,.06); border-color: var(--line-2); }
.uc__ic {
  width: 38px; height: 38px; border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.uc h3 { margin: 0 0 8px; font-size: 13.5px; font-weight: 700; color: var(--ink-900); }
.uc p { margin: 0 0 10px; font-size: 11.5px; color: var(--ink-500); line-height: 1.55; }

/* --- TRUSTED ROW --- */
.trusted-row {
  text-align: center;
  padding: 32px 24px;
  background: linear-gradient(180deg, #FAFAFC, #fff);
  border: 1px solid var(--line);
  border-radius: 16px;
}
.trusted-row__head { margin-bottom: 24px; }
.trusted-row__head h3 { margin: 0 0 6px; font-size: 16px; font-weight: 700; color: var(--ink-900); letter-spacing: -0.005em; }
.trusted-row__head p { margin: 0; font-size: 12.5px; color: var(--ink-500); }

.logos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px 18px;
  align-items: center;
  justify-items: center;
}
.logo {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Inter', sans-serif;
  font-size: 17px; font-weight: 800; letter-spacing: 0.05em;
  color: #6B7280;
  filter: grayscale(1);
  opacity: 0.7;
  transition: opacity .2s ease, filter .2s ease, color .2s ease, transform .2s ease;
  cursor: default;
  white-space: nowrap;
  line-height: 1;
}
.logo:hover { opacity: 1; filter: grayscale(0); color: var(--ink-900); transform: translateY(-1px); }
.logo svg { flex-shrink: 0; }
.logo b { font-weight: 800; }
.logo i { font-style: italic; font-weight: 600; letter-spacing: 0.02em; opacity: 0.7; }
.logo em { font-style: italic; font-weight: 500; margin-left: 4px; }

.logo--script {
  font-family: 'Brush Script MT', 'Snell Roundhand', cursive;
  font-weight: 400; font-style: italic;
  font-size: 26px; letter-spacing: 0;
  text-transform: lowercase;
}
.logo--hf {
  font-size: 11px; line-height: 1.05;
  letter-spacing: 0.02em;
}
.logo--hf > span { display: inline-block; text-align: left; }
.logo--hf b { font-weight: 800; font-size: 12px; letter-spacing: 0; }
.logo--hf svg { color: #6B7280; }
.logo--soft {
  text-transform: none;
  font-size: 16px;
  letter-spacing: 0;
  font-weight: 700;
}

/* --- FAQ --- */
.faq h2 { margin: 0 0 18px; font-size: 22px; font-weight: 700; letter-spacing: -0.01em; }
.faq__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.faq__col { display: flex; flex-direction: column; gap: 8px; }
.faq-item { background: #fff; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.faq-btn {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 14px 16px;
  font-size: 13.5px; font-weight: 500; color: var(--ink-900);
  text-align: left;
}
.faq-plus {
  width: 22px; height: 22px; border-radius: 50%;
  background: #F0EBFF; color: var(--brand);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 600; line-height: 1;
  transition: transform .2s ease;
}
.faq-ans {
  display: none;
  padding: 0 16px 14px;
  font-size: 12.5px; color: var(--ink-600); line-height: 1.6;
}
.faq-item.is-open .faq-ans { display: block; }
.faq-item.is-open .faq-plus { transform: rotate(45deg); }

/* --- FINAL CTA --- */
.final-cta {
  background: linear-gradient(135deg, #F0EBFF, #E7E0FF);
  border-radius: 18px;
  padding: 28px 32px;
  display: grid; grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: 24px;
  position: relative;
  overflow: hidden;
}
.final-cta__left h2 { margin: 0 0 8px; font-size: 22px; font-weight: 800; letter-spacing: -0.01em; }
.final-cta__left p { margin: 0 0 18px; color: var(--ink-600); font-size: 13.5px; }
.final-cta .promo-cta { margin-bottom: 0; }
.final-cta__right { position: relative; height: 160px; }
.float-av {
  position: absolute;
  width: 64px; height: 64px; border-radius: 50%;
  background: #ddd center/cover no-repeat;
  border: 4px solid #fff;
  box-shadow: 0 8px 24px rgba(91,70,229,0.18);
}
.float-av--1 { left: 0; top: 30px; }
.float-av--2 { left: 76px; top: 0; }
.float-av--3 { left: 76px; top: 90px; }
.roi-card {
  position: absolute;
  right: 0; top: 30px;
  background: #fff;
  border-radius: 12px;
  padding: 14px 18px;
  box-shadow: 0 12px 32px rgba(91,70,229,0.18);
  min-width: 160px;
}
.roi-card__l { font-size: 11px; color: var(--ink-500); }
.roi-card__v { font-size: 26px; font-weight: 800; color: var(--ink-900); margin: 4px 0 2px; letter-spacing: -0.01em; }
.roi-spark { width: 100%; height: 30px; margin-top: 6px; display: block; }

/* --- FOOTER --- */
.site-foot {
  margin-top: 48px;
  background: #0E0E14;
  color: #C9CCD3;
  border-radius: 18px;
  padding: 40px 32px 20px;
}
.site-foot__main {
  display: grid;
  grid-template-columns: 1.3fr 2.6fr;
  gap: 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid #1F2129;
}
.site-foot__brand p {
  margin: 14px 0 18px;
  font-size: 13px; color: #797D88;
  line-height: 1.6;
  max-width: 320px;
}
.brand-mark { display: flex; align-items: center; gap: 10px; }
.brand-mark__logo {
  width: 32px; height: 32px;
  border-radius: 9px;
  background: var(--brand);
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
}
.brand-mark__name {
  font-size: 18px; font-weight: 800; letter-spacing: -0.01em;
  color: #fff;
}

.site-foot__newsletter {
  display: flex; gap: 8px; align-items: center;
  background: #15161D;
  border: 1px solid #20222B;
  border-radius: 10px;
  padding: 4px 4px 4px 12px;
  margin-bottom: 18px;
  max-width: 360px;
}
.site-foot__newsletter input {
  flex: 1; min-width: 0;
  border: 0; outline: 0;
  background: transparent;
  color: #fff;
  font-size: 13px;
  padding: 8px 0;
}
.site-foot__newsletter input::placeholder { color: #6B6F7A; }
.site-foot__newsletter .btn { height: 32px; padding: 0 14px; font-size: 12.5px; }

.site-foot__social { display: flex; gap: 8px; }
.site-foot__social a {
  width: 32px; height: 32px; border-radius: 8px;
  background: #15161D;
  border: 1px solid #20222B;
  color: #9BA0AC;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.site-foot__social a:hover { background: #1A1B22; color: #fff; border-color: #2A2C36; }
.site-foot__quick { display: flex; flex-direction: column; gap: 8px; margin: 18px 0 20px; }
.site-foot__quick a { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: #9BA0AC; text-decoration: none; transition: color .15s; }
.site-foot__quick a:hover { color: #fff; }
.foot-tag { display: inline-flex; align-items: center; font-size: 9px; font-weight: 700; letter-spacing: .04em; padding: 2px 6px; border-radius: 4px; text-transform: uppercase; line-height: 1.4; }
.foot-tag--free { background: rgba(52,211,153,.15); color: #34D399; }
.foot-tag--new { background: rgba(91,70,229,.2); color: #9585FF; }
.foot-tag--hiring { background: rgba(251,191,36,.15); color: #FBBF24; }
.site-foot__col li a { display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; }

.site-foot__cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.site-foot__col h4 {
  margin: 0 0 12px;
  font-size: 12px; font-weight: 700;
  color: #fff;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.site-foot__col ul { display: flex; flex-direction: column; gap: 9px; }
.site-foot__col a {
  font-size: 13px; color: #9BA0AC;
  transition: color .15s ease;
  display: inline-flex; align-items: center; gap: 8px;
}
.site-foot__col a:hover { color: #fff; }
.pill-new {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.03em;
  background: var(--brand); color: #fff;
  padding: 2px 6px; border-radius: 999px;
  text-transform: uppercase;
}

.site-foot__bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px;
  padding-top: 18px;
  flex-wrap: wrap;
  border-top: 1px solid #1F2129;
}

/* Footer certification / partner row */
.site-foot__certs {
  padding: 22px 0;
  border-bottom: 1px solid #1F2129;
}
.site-foot__certs-label {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em;
  color: #797D88;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.site-foot__certs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 28px;
  align-items: center;
}
.partner-logo {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600;
  color: #D6D8DE;
  letter-spacing: 0;
  transition: color .15s ease, opacity .15s ease;
  cursor: default;
}
.partner-logo:hover { color: #fff; }
.partner-logo svg { flex-shrink: 0; }
.partner-logo__txt { line-height: 1; }

/* SOC / GDPR mono seals */
.partner-logo--mono { color: #9BA0AC; }
.partner-logo--mono .partner-logo__seal {
  width: 26px; height: 26px;
  border-radius: 6px;
  background: #15161D;
  border: 1px solid #2A2C36;
  color: #C9CCD3;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9.5px; font-weight: 800;
  letter-spacing: 0.04em;
}
.partner-logo__seal--gdpr {
  background: linear-gradient(135deg, #003399, #0033CC) !important;
  color: #FFCC00 !important;
  border-color: transparent !important;
}

@media (max-width: 900px) {
  .site-foot__certs-row { gap: 10px 20px; }
}
.site-foot__copy { font-size: 12px; color: #797D88; }
.site-foot__legal {
  display: flex; gap: 18px;
}
.site-foot__legal a { font-size: 12px; color: #797D88; transition: color .15s ease; }
.site-foot__legal a:hover { color: #C9CCD3; }
.site-foot__lang {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; color: #C9CCD3;
  background: #15161D;
  border: 1px solid #20222B;
  border-radius: 8px;
  padding: 6px 10px;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease;
}
.site-foot__lang:hover { background: #1A1B22; border-color: #2A2C36; }

/* --- Promo Hero responsive --- */
@media (max-width: 1100px) {
  .promo-hero { grid-template-columns: 1fr; }
  .what-is { grid-template-columns: 1fr; }
  .feat-grid__items { grid-template-columns: repeat(2, 1fr); }
  .use-cases__grid { grid-template-columns: repeat(3, 1fr); }
  .overview-niches { display: none; }
  .site-foot__main { grid-template-columns: 1fr; gap: 32px; }
  .site-foot__cols { grid-template-columns: repeat(2, 1fr); }
  .logos { grid-template-columns: repeat(4, 1fr); gap: 24px 12px; }
}
@media (max-width: 720px) {
  .promo-h { font-size: 28px; }
  .feat-grid__items { grid-template-columns: 1fr; }
  .use-cases__grid { grid-template-columns: repeat(2, 1fr); }
  .faq__grid { grid-template-columns: 1fr; }
  .final-cta { grid-template-columns: 1fr; }
  .final-cta__right { display: none; }
  .what-is__right { grid-template-columns: 1fr; }
  .compare__row { grid-template-columns: 1fr 1fr; }
  .compare__row > .ccol:nth-child(2),
  .compare__row > .ccol:nth-child(3) { display: none; }
  .site-foot { padding: 28px 18px 18px; }
  .site-foot__cols { grid-template-columns: 1fr 1fr; gap: 18px; }
  .site-foot__bar { flex-direction: column; align-items: flex-start; gap: 12px; }
  .logos { grid-template-columns: repeat(2, 1fr); }
}


/* ============ KALO PRICING + FAQ (scoped, added without touching original) ============ */
.kalo-pricing-wrap, .kalo-faq-wrap{
  --navy:#0F172A; --ink:#0B1220; --slate:#334155; --muted:#64748B;
  --light-gray:#E2E8F0; --off-white:#F8FAFC; --mint:#34D399; --coral:#FF6B6B;
  --sky:#80B2F2; --amber:#FBBF24; --amber-600:#E5A912; --amber-ink:#0F172A;
  --brand:#5B46E5; --brand-600:#4F3CD6; --brand-50:#EFEBFF; --brand-100:#E3DDFF;
  --periwinkle:#667BF2; --deep:#5058F2; --pale-mint:#D1FAE5; --pale-sky:#E0F2FE;
  --soft-lilac:#EDE9FE;
  --g-hero:linear-gradient(120deg,#5B46E5,#5058F2);
  --g-cap:linear-gradient(120deg,#5B46E5,#667BF2);
  --g-cta:linear-gradient(120deg,#5B46E5,#667BF2);
  font-family:'Inter',sans-serif;
}
.kalo-pricing-wrap *, .kalo-faq-wrap *{ box-sizing:border-box; }

/* --- pricing (scoped) --- */

.kalo-pricing-wrap html, .kalo-pricing-wrap .pricing{padding:48px 24px 56px;max-width:1180px;margin:0 auto;}
.kalo-pricing-wrap .pricing__head{text-align:center;margin-bottom:30px;}
.kalo-pricing-wrap .pricing__eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--brand);background:var(--brand-50);padding:5px 12px;border-radius:999px;margin-bottom:14px;}
.kalo-pricing-wrap .pricing__head h2{margin:0 0 8px;font-size:28px;font-weight:700;letter-spacing:-0.01em;}
.kalo-pricing-wrap .pricing__head p{margin:0 auto;max-width:560px;color:var(--ink-500);font-size:14.5px;line-height:1.55;}
.kalo-pricing-wrap .billing{display:inline-flex;align-items:center;gap:0;margin-top:22px;background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:4px;}
.kalo-pricing-wrap .billing button{border:0;background:transparent;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink-600);padding:8px 18px;border-radius:999px;transition:all .18s;}
.kalo-pricing-wrap .billing button.is-active{background:var(--brand);color:#fff;}
.kalo-pricing-wrap .billing__save{margin-left:10px;font-size:12px;font-weight:700;color:var(--green-700);}

  /* team-size recommender (option 5) - full width, polished */
  
.kalo-pricing-wrap .recommender{max-width:100%;margin:28px 0 0;background:linear-gradient(180deg,#fff,#FCFBFF);border:1px solid var(--brand-100);border-radius:16px;padding:22px 28px;box-shadow:0 6px 24px rgba(91,70,229,.05);}
.kalo-pricing-wrap .recommender__inner{max-width:760px;margin:0 auto;}
.kalo-pricing-wrap .recommender__row{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.kalo-pricing-wrap .recommender__label{font-size:14px;font-weight:600;color:var(--ink-800);}
.kalo-pricing-wrap .recommender__count{font-size:14px;color:var(--ink-600);}
.kalo-pricing-wrap .recommender__count b{color:var(--brand);font-weight:800;font-size:18px;}
.kalo-pricing-wrap .recommender input[type=range]{width:100%;height:8px;margin:18px 0 6px;cursor:pointer;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--brand) 0%,var(--brand) var(--fill,5%),var(--line-2) var(--fill,5%),var(--line-2) 100%);border-radius:999px;}
.kalo-pricing-wrap .recommender input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--brand);box-shadow:0 2px 8px rgba(91,70,229,.35);cursor:pointer;transition:transform .12s;}
.kalo-pricing-wrap .recommender input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.12);}
.kalo-pricing-wrap .recommender input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--brand);box-shadow:0 2px 8px rgba(91,70,229,.35);cursor:pointer;}
.kalo-pricing-wrap .recommender__scale{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-400);margin-top:2px;}
.kalo-pricing-wrap .recommender__rec{margin-top:16px;text-align:center;font-size:14px;color:var(--ink-700);padding:12px;background:var(--brand-50);border-radius:10px;}
.kalo-pricing-wrap .recommender__rec b{color:var(--brand-600);font-weight:700;}
.kalo-pricing-wrap .plans{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px;align-items:stretch;}
.kalo-pricing-wrap .plan{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 20px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;}
.kalo-pricing-wrap .plan:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(15,17,21,.06);border-color:var(--line-2);}
.kalo-pricing-wrap .plan--featured{border-color:var(--brand);box-shadow:0 12px 32px rgba(91,70,229,.12);}
.kalo-pricing-wrap .plan--featured:hover{box-shadow:0 16px 40px rgba(91,70,229,.16);}
.kalo-pricing-wrap .plan.is-rec{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-100);}
.kalo-pricing-wrap .plan__badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:5px 12px;border-radius:999px;white-space:nowrap;}
.kalo-pricing-wrap .plan__rec-badge{position:absolute;top:-11px;right:14px;background:var(--green);color:#fff;font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:4px 10px;border-radius:999px;display:none;}
.kalo-pricing-wrap .plan.is-rec .plan__rec-badge{display:block;}
.kalo-pricing-wrap .plan__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px;}
.kalo-pricing-wrap .plan__name{font-size:14px;font-weight:700;color:var(--ink-900);}
.kalo-pricing-wrap .plan__off{font-size:11px;font-weight:700;color:var(--brand);background:var(--brand-50);padding:3px 8px;border-radius:999px;white-space:nowrap;display:none;}
.kalo-pricing-wrap .plan__off.show{display:inline-block;}
.kalo-pricing-wrap .plan__desc{font-size:12px;color:var(--ink-500);margin:0 0 16px;line-height:1.5;min-height:32px;}
.kalo-pricing-wrap .plan__price{display:flex;align-items:baseline;gap:4px;margin-bottom:2px;}
.kalo-pricing-wrap .plan__amount{font-size:34px;font-weight:800;letter-spacing:-0.02em;color:var(--ink-900);}
.kalo-pricing-wrap .plan__per{font-size:13px;color:var(--ink-500);font-weight:500;}
.kalo-pricing-wrap .plan__annual{font-size:12px;color:var(--ink-400);margin:0 0 18px;min-height:16px;}
.kalo-pricing-wrap .plan__annual b{color:var(--green-700);font-weight:700;}
.kalo-pricing-wrap .plan__cta{display:block;text-align:center;font-family:inherit;font-size:13px;font-weight:600;padding:11px 14px;border-radius:10px;cursor:pointer;text-decoration:none;transition:all .18s;margin-bottom:18px;border:1px solid transparent;}
.kalo-pricing-wrap .plan__cta--solid{background:var(--amber);color:var(--amber-ink);}
.kalo-pricing-wrap .plan__cta--solid:hover{background:var(--amber-600);}
.kalo-pricing-wrap .plan__cta--ghost{background:#fff;color:var(--ink-800);border-color:var(--line-2);}
.kalo-pricing-wrap .plan__cta--ghost:hover{border-color:var(--brand);color:var(--brand);}
.kalo-pricing-wrap .plan__cta--dark{background:var(--ink-900);color:#fff;}
.kalo-pricing-wrap .plan__cta--dark:hover{background:var(--ink-800);}
.kalo-pricing-wrap .plan__cta--bottom{margin-top:18px;margin-bottom:0;}
.kalo-pricing-wrap .plan__div{height:1px;background:var(--line);margin:0 0 16px;}
.kalo-pricing-wrap .plan__feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;flex:1 1 auto;}
.kalo-pricing-wrap .plan__feats li{display:flex;align-items:flex-start;gap:9px;font-size:12px;color:var(--ink-700);line-height:1.45;}
.kalo-pricing-wrap .plan__feats .ic{flex-shrink:0;width:15px;height:15px;color:var(--brand);margin-top:1px;}
.kalo-pricing-wrap .plan__feats li.no{color:var(--ink-400);}
.kalo-pricing-wrap .plan__feats li.no .ic{color:var(--ink-300);}
  /* tooltip (option 3) */
  
.kalo-pricing-wrap .tip{position:relative;border-bottom:1px dashed var(--ink-300);cursor:help;}
.kalo-pricing-wrap .tip:hover .tip__box{opacity:1;visibility:visible;transform:translateY(0);}
.kalo-pricing-wrap .tip__box{position:absolute;bottom:145%;left:0;width:210px;background:var(--ink-900);color:#fff;font-size:11.5px;line-height:1.45;font-weight:400;padding:9px 11px;border-radius:8px;opacity:0;visibility:hidden;transform:translateY(4px);transition:all .18s;z-index:8;text-align:left;}
.kalo-pricing-wrap .tip__box::after{content:"";position:absolute;top:100%;left:16px;border:6px solid transparent;border-top-color:var(--ink-900);}
.kalo-pricing-wrap .pricing__foot{text-align:center;margin-top:30px;font-size:13px;color:var(--ink-500);}
.kalo-pricing-wrap .pricing__foot b{color:var(--ink-700);}
  @media (max-width:1080px){
.kalo-pricing-wrap .plans{grid-template-columns:repeat(2,1fr);max-width:680px;margin-left:auto;margin-right:auto;}}
  @media (max-width:560px){
.kalo-pricing-wrap .plans{grid-template-columns:1fr;max-width:380px;}
.kalo-pricing-wrap .plan--featured{order:-1;}}

/* --- faq (scoped) --- */

.kalo-faq-wrap html, .kalo-faq-wrap .faq{padding:48px 24px 56px;max-width:820px;margin:0 auto;}
.kalo-faq-wrap .faq__head{text-align:center;margin-bottom:26px;}
.kalo-faq-wrap .faq__eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--brand);background:var(--brand-50);padding:5px 12px;border-radius:999px;margin-bottom:14px;}
.kalo-faq-wrap .faq__head h2{margin:0 0 8px;font-size:28px;font-weight:700;letter-spacing:-0.01em;}
.kalo-faq-wrap .faq__head p{margin:0 auto;max-width:540px;color:var(--ink-500);font-size:14.5px;line-height:1.55;}
.kalo-faq-wrap .faq__tabs{display:flex;justify-content:center;gap:4px;flex-wrap:wrap;margin:26px 0 28px;border-bottom:1px solid var(--line);}
.kalo-faq-wrap .faq__tab{border:0;background:transparent;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink-500);padding:12px 18px;position:relative;transition:color .18s;}
.kalo-faq-wrap .faq__tab:hover{color:var(--ink-800);}
.kalo-faq-wrap .faq__tab.is-active{color:var(--brand);}
.kalo-faq-wrap .faq__tab.is-active::after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--brand);border-radius:2px;}
.kalo-faq-wrap .faq__list{display:flex;flex-direction:column;gap:12px;}
.kalo-faq-wrap .faq__panel{display:none;flex-direction:column;gap:12px;}
.kalo-faq-wrap .faq__panel.is-active{display:flex;}
.kalo-faq-wrap .qa{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .18s,box-shadow .18s;}
.kalo-faq-wrap .qa:hover{border-color:var(--line-2);}
.kalo-faq-wrap .qa.is-open{border-color:var(--brand-100);box-shadow:0 8px 24px rgba(91,70,229,.06);}
.kalo-faq-wrap .qa__q{width:100%;border:0;background:transparent;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;font-size:15px;font-weight:600;color:var(--ink-900);text-align:left;}
.kalo-faq-wrap .qa__ic{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--ink-300);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;transition:transform .22s,border-color .18s,color .18s,background .18s;}
.kalo-faq-wrap .qa.is-open .qa__ic{background:var(--brand);border-color:var(--brand);color:#fff;transform:rotate(45deg);}
.kalo-faq-wrap .qa__a{max-height:0;overflow:hidden;transition:max-height .26s ease,padding .26s ease;padding:0 20px;color:var(--ink-600);font-size:13.5px;line-height:1.6;}
.kalo-faq-wrap .qa.is-open .qa__a{max-height:900px;padding:0 20px 18px;}
.kalo-faq-wrap .qa__a a{color:var(--brand);font-weight:600;text-decoration:none;border-bottom:1px solid var(--brand-100);}
.kalo-faq-wrap .qa__a a:hover{border-bottom-color:var(--brand);}
.kalo-faq-wrap .qa__more{margin-top:16px;}
.kalo-faq-wrap .qa__more-prompt{font-size:13px;font-weight:700;color:var(--ink-800);margin:0 0 8px;}
.kalo-faq-wrap .qa__more-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.kalo-faq-wrap .qa__more-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--brand);text-decoration:none;border:0;}
.kalo-faq-wrap .qa__more-link:hover{color:var(--brand-600);border:0;}
.kalo-faq-wrap .qa__more-link svg{width:14px;height:14px;}
.kalo-faq-wrap .qa__signup{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#0F172A !important;background:var(--amber);padding:10px 16px;border-radius:9px;text-decoration:none;border:0;white-space:nowrap;line-height:1;}
.kalo-faq-wrap .qa__signup:hover{background:#E5A912;border:0;color:#0F172A !important;}
.kalo-faq-wrap .qa__signup svg{width:15px;height:15px;flex-shrink:0;}
.kalo-faq-wrap .qa__sep{color:var(--ink-300);font-size:13px;}
  /* inline price highlight */
  
.kalo-faq-wrap .pr{font-weight:700;color:var(--ink-900);background:#F1F5F9;padding:1px 7px;border-radius:6px;white-space:nowrap;}
.kalo-faq-wrap .pr-low{background:#D1FAE5;color:#0f7a52;}
  @media (max-width:560px){
.kalo-faq-wrap .faq__tabs{gap:0;}
.kalo-faq-wrap .faq__tab{padding:11px 10px;font-size:12.5px;}
.kalo-faq-wrap .qa__q{font-size:14px;padding:16px;}
  }


/* ===== image slot fallbacks (show styled placeholder if external image fails to load) ===== */
.avatar { background-color:#E3DDFF; }
.article__img { background-color:#1B2A4A; background-size:cover; background-position:center; }
.creator-card__img { background-color:#E2E8F0; background-size:cover; background-position:center; }
.testi__avatar { background-color:#E3DDFF; background-size:cover; background-position:center; }
.float-av { background-color:#EDE9FE; background-size:cover; background-position:center; }

.widget-label{font-size:13px;font-weight:700;color:#0F172A;letter-spacing:.01em;}

/* sidebar logo (added) */
.sidebar__top{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;}
.sidebar__home{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;min-width:0;}
.sidebar__logo{width:30px;height:30px;flex:0 0 30px;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.sidebar__logo svg{width:30px;height:30px;display:block;}
.sidebar__brand-name{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.01em;white-space:nowrap;}
.sidebar.is-collapsed .sidebar__brand-name{display:none;}
.sidebar.is-collapsed .sidebar__menu{display:none;}
.sidebar.is-collapsed .sidebar__top{justify-content:center;padding-left:0;padding-right:0;}
.sidebar.is-collapsed .sidebar__home{justify-content:center;gap:0;width:100%;}

/* Top Niches subline spacing (#3) */
.rail-card .widget-label{margin-bottom:4px;}
.rail-sub{font-size:12px;color:#64748B;margin:0 0 14px;line-height:1.4;}

/* #4: lb-promo banner is purple bg - make headline + body visible (not white per request) */
.lb-promo__text .widget-label{color:#FBBF24;}
.lb-promo__text p{color:#E9E4FF;}

/* #5: article cards are now links */
a.article{display:block;text-decoration:none;color:inherit;}

/* #11 fix: initials inside avatars so they read as intentional, not empty */
.avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;}
.avatar__ini{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;letter-spacing:.02em;pointer-events:none;}
.avatar--lg .avatar__ini{font-size:15px;}
.testi__avatar{position:relative;}
.testi__avatar .avatar__ini{font-size:16px;}
.creator-card__img{position:relative;}
.creator-card__mono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);font-weight:800;font-size:64px;letter-spacing:.02em;pointer-events:none;}
