* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans-en);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: 14px;
  line-height: 1.5;
  min-height: 100vh;
}
html[dir="rtl"] body { font-family: var(--font-sans-ar); }

a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-hover); }

/* Layout — grid columns flow LTR physically; when direction: rtl is set on <html>,
   CSS Grid reverses the inline axis automatically, placing the 260px track on
   the right and the 1fr main track on the left. No RTL override needed. */
.app { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; transition: grid-template-columns 220ms ease; }
.app.sidebar-collapsed { grid-template-columns: 68px 1fr; }

.sidebar {
  background: linear-gradient(180deg, var(--stc-purple-700) 0%, var(--stc-purple-900) 100%);
  color: var(--stc-white);
  padding: 28px 20px;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow: hidden;
}
.sidebar-collapse-btn {
  all: unset; cursor: pointer;
  position: absolute;
  top: 18px; inset-inline-end: 10px;
  width: 26px; height: 26px;
  border-radius: 8px;
  background: rgba(255,255,255,0.10);
  color: var(--stc-white);
  display: grid; place-items: center;
  font-size: 12px;
  transition: background 120ms ease;
}
.sidebar-collapse-btn:hover { background: rgba(255,255,255,0.2); }
.app.sidebar-collapsed .sidebar { padding: 16px 10px; }
.app.sidebar-collapsed .sidebar-collapse-btn { position: static; margin: 0 auto; }
.app.sidebar-collapsed .brand > div:last-child { display: none; }
.app.sidebar-collapsed .brand-mark { margin: 0 auto; }
.app.sidebar-collapsed .nav button { justify-content: center; padding: 10px 0; }
.app.sidebar-collapsed .nav button span:not(.nav-icon) { display: none; }
.app.sidebar-collapsed .sidebar .footer .lang-switch button {
  padding: 4px 6px; font-size: 10px;
}
.app.sidebar-collapsed .sidebar .footer > div:not(.lang-switch) { display: none; }
.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 18px; letter-spacing: 0.01em;
}
img.brand-mark {
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain;
}
.app.sidebar-collapsed img.brand-mark { height: 28px; }
.nav { display: flex; flex-direction: column; gap: 4px; margin-top: 8px; }
.nav button {
  all: unset;
  cursor: pointer;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  color: rgba(255,255,255,0.78);
  font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  transition: background 120ms ease, color 120ms ease;
}
.nav button:hover { background: rgba(255,255,255,0.08); color: var(--stc-white); }
.nav button.active { background: rgba(255,255,255,0.16); color: var(--stc-white); }
.nav .nav-icon { width: 18px; height: 18px; display: inline-grid; place-items: center; }

.sidebar .footer {
  margin-top: auto;
  font-size: 12px;
  color: rgba(255,255,255,0.6);
}
/* Sidebar footer row: lang switch on the start, sync icon on the end. */
.sidebar .footer-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
.sidebar .sync-btn {
  all: unset;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--stc-coral);
  color: var(--stc-white);
  font-weight: 600; font-size: 12px;
  cursor: pointer;
  transition: filter 120ms ease, transform 120ms ease;
}
.sidebar .sync-btn:hover { filter: brightness(1.08); }
.sidebar .sync-btn:active { transform: translateY(1px); }
.sidebar .sync-btn[disabled] { opacity: 0.6; cursor: progress; }
.sidebar .sync-btn .sync-label { display: none; }   /* default: icon-only */
.sidebar .sync-btn:hover .sync-label { display: inline; }   /* show label on hover */
.sidebar .sync-spinner {
  display: inline-block;
  width: 11px; height: 11px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: var(--stc-white);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.app.sidebar-collapsed .sidebar .footer-row { flex-direction: column; gap: 6px; }
.app.sidebar-collapsed .sidebar .sync-btn { padding: 0; width: 28px; }
.lang-switch {
  display: inline-flex; background: rgba(255,255,255,0.1); border-radius: 999px; padding: 3px;
}
.lang-switch button {
  all: unset; cursor: pointer;
  padding: 4px 12px; border-radius: 999px; font-size: 12px;
  color: rgba(255,255,255,0.8);
}
.lang-switch button.active { background: var(--stc-white); color: var(--stc-purple-700); font-weight: 600; }

/* Main */
main { padding: 28px 36px; }
.page-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 22px; flex-wrap: wrap; gap: 16px;
}
.page-header h1 { margin: 0; font-size: 24px; font-weight: 700; }
.page-header p { margin: 4px 0 0; color: var(--color-text-muted); }

.controls { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  padding: 7px 14px;
  border-radius: 999px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  cursor: pointer;
  font-size: 13px;
  color: var(--color-text-muted);
  font-weight: 500;
  transition: all 120ms ease;
}
.chip:hover { border-color: var(--stc-purple-300); color: var(--color-text); }
.chip.active { background: var(--color-primary); border-color: var(--color-primary); color: var(--stc-white); }

.btn {
  padding: 9px 18px;
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: var(--stc-white);
  border: 0; cursor: pointer;
  font-weight: 600; font-size: 13px;
  transition: background 120ms ease, transform 120ms ease;
}
.btn:hover { background: var(--color-primary-hover); }
.btn:active { transform: translateY(1px); }
.btn.ghost { background: var(--color-surface); color: var(--color-text); border: 1px solid var(--color-border); }
.btn.danger { background: var(--color-danger); }

/* Cards */
.card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: 20px;
}
.card-title {
  font-size: 13px; font-weight: 600; color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 12px;
}

.kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.kpi {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
  transition: box-shadow 160ms ease, transform 160ms ease;
}
.kpi:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }
.kpi .platform-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--color-text-muted);
}
.platform-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.kpi .handle { font-size: 13px; color: var(--color-text-muted); margin-top: 3px; }
.kpi .value { font-size: 26px; font-weight: 700; margin-top: 12px; letter-spacing: -0.01em; }
.kpi .deltas { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; font-size: 12px; }
.kpi .delta { display: inline-flex; align-items: center; gap: 3px; }
.delta.up    { color: var(--color-success); }
.delta.down  { color: var(--color-danger); }
.delta.flat  { color: var(--color-text-muted); }
.kpi.competitor { border: 1px dashed var(--stc-purple-300); background: var(--stc-purple-50); }

.kpi .stripe {
  position: absolute; top: 0; inset-inline-start: 0;
  width: 4px; height: 100%;
}

/* Chart container */
.chart-wrap { position: relative; height: 320px; }
.chart-wrap.tall { height: 420px; }

/* Tables */
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { text-align: start; padding: 12px 14px; border-bottom: 1px solid var(--color-border); }
th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); font-weight: 600; }
tbody tr:hover { background: var(--color-surface-alt); }
.caption-cell { max-width: 420px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Forms */
input, select {
  font: inherit;
  padding: 9px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
input:focus, select:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(26,108,176,0.12);
}
label { font-size: 12px; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.06em; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.grid-3 { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
@media (max-width: 1100px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .app, .app.sidebar-collapsed { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; overflow: visible; }
  .sidebar-collapse-btn { display: none; }
  main { padding: 20px; }
}

.pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px; font-weight: 600;
  background: var(--stc-purple-100); color: var(--stc-purple-700);
}
.pill.competitor { background: #FFE4E6; color: #9F1239; }
.pill.status-ok { background: #D1FAE5; color: #065F46; }
.pill.status-error { background: #FEE2E2; color: #991B1B; }

.badge-platform {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  background: var(--stc-ink-100);
}

.empty {
  text-align: center; padding: 48px 20px; color: var(--color-text-muted);
}
.empty h3 { color: var(--color-text); margin: 0 0 8px; }
.chart-empty {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px;
  color: var(--color-text-muted);
  pointer-events: none;
}
.chart-empty strong { color: var(--color-text); font-size: 14px; }
.chart-empty span { font-size: 12px; }

.toast {
  position: fixed; bottom: 24px; inset-inline-end: 24px;
  background: var(--stc-ink-900); color: var(--stc-white);
  padding: 12px 18px; border-radius: var(--radius-md);
  box-shadow: var(--shadow-hover);
  z-index: 50;
}

/* ------- Platform icon picker ------- */
.platform-picker { display: inline-flex; gap: 8px; flex-wrap: wrap; }
.platform-picker .platform-btn {
  all: unset;
  width: 44px; height: 44px;
  border-radius: 12px;
  display: inline-grid; place-items: center;
  cursor: pointer;
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  transition: all 140ms ease;
}
.platform-picker .platform-btn svg { width: 20px; height: 20px; display: block; }
.platform-picker .platform-btn:hover { border-color: var(--stc-purple-300); color: var(--color-text); transform: translateY(-1px); }
.platform-picker .platform-btn.active {
  background: var(--color-primary);
  color: var(--stc-white);
  border-color: var(--color-primary);
  box-shadow: 0 4px 12px rgba(26,108,176,0.25);
}
.platform-picker .platform-btn.active-brand.active {
  background: currentColor;
  border-color: currentColor;
}
.platform-picker .platform-btn.active-brand.active svg { color: var(--stc-white); }

/* Small version for inline badges */
.platform-ico { width: 14px; height: 14px; display: inline-block; vertical-align: -2px; }
.platform-ico svg { width: 100%; height: 100%; display: block; }

/* Platform-colored badge */
.badge-platform { color: var(--color-text); }
.badge-platform.plat-x        { color: var(--platform-x); }
.badge-platform.plat-instagram{ color: var(--platform-instagram); }
.badge-platform.plat-youtube  { color: var(--platform-youtube); }
.badge-platform.plat-tiktok   { color: var(--platform-tiktok); }
.badge-platform.plat-snapchat { color: var(--platform-snapchat); }
.badge-platform.plat-linkedin { color: var(--platform-linkedin); }
.badge-platform.plat-facebook { color: var(--platform-facebook); }

/* ------- Modal ------- */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(29,29,45,0.5);
  display: grid; place-items: center;
  z-index: 60;
  backdrop-filter: blur(3px);
}
.modal {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  width: min(560px, 92vw);
  max-height: 86vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(29,29,45,0.25);
  overflow: hidden;
}
.modal-head {
  padding: 18px 20px;
  border-bottom: 1px solid var(--color-border);
  display: flex; justify-content: space-between; align-items: center;
}
.modal-head h3 { margin: 0; font-size: 16px; }
.modal-body {
  padding: 16px 20px;
  overflow-y: auto;
  flex: 1;
}
.modal-foot {
  padding: 14px 20px;
  border-top: 1px solid var(--color-border);
  display: flex; justify-content: flex-end; gap: 10px;
  background: var(--stc-ink-50);
}
.icon-btn {
  all: unset; cursor: pointer;
  width: 32px; height: 32px;
  border-radius: 8px;
  display: inline-grid; place-items: center;
  color: var(--color-text-muted);
}
.icon-btn:hover { background: var(--stc-ink-100); color: var(--color-text); }

/* Account list inside modal */
.account-list { display: flex; flex-direction: column; gap: 6px; }
.account-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 120ms ease, border-color 120ms ease;
}
.account-row:hover { background: var(--stc-ink-50); }
.account-row.selected { background: var(--stc-purple-50); border-color: var(--stc-purple-300); }
.account-row .plat-ico {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--stc-ink-50); color: var(--color-text);
  flex-shrink: 0;
}
.account-row .plat-ico svg { width: 14px; height: 14px; }
.account-row .acc-meta { flex: 1; min-width: 0; }
.account-row .acc-name { font-weight: 600; font-size: 13px; }
.account-row .acc-sub { color: var(--color-text-muted); font-size: 12px; }
.account-row .acc-check {
  width: 20px; height: 20px; border-radius: 6px;
  border: 1.5px solid var(--color-border);
  display: grid; place-items: center; color: transparent;
  flex-shrink: 0;
}
.account-row.selected .acc-check {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--stc-white);
}

/* Selected-for-compare chips */
.compare-chip-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.compare-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px 6px 8px;
  border-radius: 999px;
  background: var(--stc-purple-50);
  color: var(--stc-purple);
  font-size: 13px; font-weight: 500;
}
.compare-chip .x-btn {
  all: unset; cursor: pointer;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(26,108,176,0.15);
  display: inline-grid; place-items: center;
  font-size: 11px; line-height: 1;
}
.compare-chip .x-btn:hover { background: rgba(26,108,176,0.3); }

/* Utility */
.hstack { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.empty-slot {
  padding: 40px 20px; text-align: center;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  color: var(--color-text-muted);
}

/* ------- Export split-button ------- */
.export-wrap { position: relative; display: inline-block; }
.export-btn {
  padding: 9px 16px;
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: var(--stc-white);
  border: 0; cursor: pointer;
  font-weight: 600; font-size: 13px;
  display: inline-flex; align-items: center; gap: 6px;
}
.export-btn:hover { background: var(--color-primary-hover); }
.export-btn[disabled] { opacity: 0.6; cursor: progress; }
.export-menu {
  position: absolute;
  top: calc(100% + 8px);
  inset-inline-end: 0;
  z-index: 45;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 40px rgba(29,29,45,0.18);
  padding: 6px;
  min-width: 220px;
  border: 1px solid var(--color-border);
}
.export-menu button {
  all: unset; cursor: pointer;
  display: block; width: 100%;
  padding: 9px 12px;
  border-radius: 8px;
  font-size: 13px; color: var(--color-text);
}
.export-menu button:hover { background: var(--stc-purple-50); color: var(--stc-purple); }
.export-menu .divider {
  height: 1px; margin: 4px 6px; background: var(--color-border);
}

/* ------- Reports tab layout ------- */
.reports-layout { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; }
@media (max-width: 1100px) { .reports-layout { grid-template-columns: 1fr; } }
.sub-tabs { display: flex; gap: 6px; margin-bottom: 18px; border-bottom: 1px solid var(--color-border); }
.sub-tabs button {
  all: unset; cursor: pointer;
  padding: 10px 14px;
  font-weight: 600; font-size: 13px;
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.sub-tabs button.active { color: var(--stc-purple); border-bottom-color: var(--stc-purple); }
.field-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.checklist { display: flex; flex-wrap: wrap; gap: 8px; }
.checklist label {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 12px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  text-transform: none; letter-spacing: 0;
  cursor: pointer; font-weight: 500; font-size: 13px;
  color: var(--color-text-muted);
  transition: all 120ms ease;
}
.checklist label:has(input:checked) {
  background: var(--stc-purple);
  border-color: var(--stc-purple);
  color: var(--stc-white);
}
.checklist input { display: none; }
.radio-row { display: inline-flex; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 999px; padding: 3px; }
.radio-row label {
  padding: 6px 14px; border-radius: 999px; cursor: pointer;
  text-transform: none; letter-spacing: 0;
  font-weight: 500; font-size: 13px; color: var(--color-text-muted);
}
.radio-row input { display: none; }
.radio-row label:has(input:checked) {
  background: var(--stc-purple); color: var(--stc-white);
}
.template-card {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: 10px;
  background: var(--color-surface);
}
.template-card:hover { border-color: var(--stc-purple-300); }
.template-card .name { font-weight: 600; }
.template-card .meta { color: var(--color-text-muted); font-size: 12px; }
.template-card .actions { display: flex; gap: 6px; }

/* ------- KPI cards ------- */
.kpi-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-card);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-top: 4px solid var(--color-border);
}
.kpi-card.k-green { border-top-color: var(--stc-oasis); }
.kpi-card.k-amber { border-top-color: #F5A623; }
.kpi-card.k-red   { border-top-color: var(--stc-coral); }
.kpi-card.k-unknown { border-top-color: var(--stc-ink-300); }
.kpi-card .kpi-label {
  font-size: 11px; font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.06em;
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.kpi-card .kpi-label .kpi-period {
  font-weight: 500; text-transform: none; letter-spacing: 0;
  font-size: 11px;
}
.kpi-card .kpi-figure {
  display: flex; align-items: baseline; gap: 8px; margin-top: 4px;
}
.kpi-card .kpi-figure .actual {
  font-size: 36px; font-weight: 800; letter-spacing: -0.02em;
  color: var(--color-text);
  line-height: 1;
}
.kpi-card .kpi-figure .slash { color: var(--color-text-muted); font-size: 22px; }
.kpi-card .kpi-figure .target {
  font-size: 22px; font-weight: 600; color: var(--color-text-muted);
}
.kpi-card .kpi-figure .pct {
  font-size: 13px; color: var(--color-text-muted); margin-inline-start: auto;
}
.kpi-progress {
  width: 100%;
  height: 8px;
  background: var(--color-border);
  border-radius: 999px;
  overflow: hidden;
}
.kpi-progress > div {
  height: 100%;
  border-radius: 999px;
  transition: width 220ms ease;
}
.kpi-card.k-green  .kpi-progress > div { background: var(--stc-oasis); }
.kpi-card.k-amber  .kpi-progress > div { background: #F5A623; }
.kpi-card.k-red    .kpi-progress > div { background: var(--stc-coral); }
.kpi-card.k-unknown .kpi-progress > div { background: var(--stc-ink-300); }
.kpi-card .kpi-status {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 13px;
}
.kpi-card .kpi-status .status-pill {
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
}
.k-green  .status-pill { background: rgba(0,196,140,0.12);  color: #04734A; }
.k-amber  .status-pill { background: rgba(245,166,35,0.12); color: #8A5A00; }
.k-red    .status-pill { background: rgba(255,55,94,0.12);  color: #B40020; }
.k-unknown .status-pill { background: var(--stc-ink-100);   color: var(--color-text-muted); }
.kpi-card .kpi-edit-btn {
  position: absolute; top: 14px; inset-inline-end: 14px;
  background: transparent; border: 0; cursor: pointer;
  color: var(--color-text-muted); font-size: 16px;
}
.kpi-card .kpi-edit-btn:hover { color: var(--color-primary); }

.kpi-platform-block {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
  box-shadow: var(--shadow-card);
  display: grid;
  grid-template-columns: 180px 1fr 1fr;
  gap: 14px;
  align-items: stretch;
}
@media (max-width: 900px) {
  .kpi-platform-block { grid-template-columns: 1fr; }
}
.kpi-platform-block .platform-header {
  display: flex; flex-direction: column; gap: 6px;
  padding: 6px 0;
}
.kpi-platform-block .platform-header .name {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 17px;
}
.kpi-platform-block .platform-header .platform-ico { width: 22px; height: 22px; }
.kpi-platform-block .platform-header .handles {
  font-size: 12px; color: var(--color-text-muted);
}

/* ------- Creatives library grid ------- */
.creatives-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.creative-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  transition: box-shadow 160ms ease, transform 160ms ease;
  cursor: pointer;
}
.creative-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-2px); }
.creative-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--stc-ink-50);
  overflow: hidden;
}
.creative-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.creative-thumb .placeholder {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  color: var(--color-text-muted);
  font-size: 12px;
}
.creative-thumb .play-overlay {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  background: rgba(0,0,0,0.18);
  color: white; font-size: 32px;
  pointer-events: none;
  opacity: 0.85;
}
.creative-thumb .platform-badge {
  position: absolute;
  top: 8px; inset-inline-start: 8px;
  width: 26px; height: 26px;
  border-radius: 6px;
  background: rgba(255,255,255,0.92);
  display: grid; place-items: center;
}
.creative-thumb .platform-badge svg { width: 14px; height: 14px; }
.creative-thumb .cat-badge {
  position: absolute;
  top: 8px; inset-inline-end: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--stc-purple);
  color: white;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.creative-meta {
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.creative-meta .cap {
  font-size: 13px;
  line-height: 1.4;
  color: var(--color-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.creative-meta .stats {
  display: flex; gap: 12px;
  font-size: 11px; color: var(--color-text-muted);
}
.creative-meta .stats span { display: inline-flex; align-items: center; gap: 4px; }

.cat-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.cat-chips .chip { font-size: 12px; padding: 5px 12px; }
.cat-chips .chip .count {
  display: inline-block; margin-inline-start: 5px; opacity: 0.7;
  font-weight: 700;
}

/* ------- Custom date range popover ------- */
.range-wrap { position: relative; display: inline-block; }
.range-popover {
  position: absolute;
  top: calc(100% + 8px);
  inset-inline-end: 0;
  z-index: 40;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 40px rgba(29,29,45,0.18);
  padding: 14px;
  display: flex; flex-direction: column; gap: 10px;
  min-width: 280px;
  border: 1px solid var(--color-border);
}
.range-popover .row { display: flex; gap: 8px; }
.range-popover .row > div { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.range-popover label { font-size: 11px; }
.range-popover input[type="date"] { padding: 6px 8px; font-size: 13px; }
.range-popover .actions { display: flex; justify-content: flex-end; }

/* Clickable table rows */
table tbody tr.clickable { cursor: pointer; }
table tbody tr.clickable:hover a { text-decoration: underline; }

/* Post-detail modal — wider than compare */
.modal.wide { width: min(780px, 92vw); }
.post-meta {
  display: flex; align-items: center; gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 14px;
}
.post-meta .avatar {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--stc-ink-50); color: var(--color-text);
  display: grid; place-items: center; flex-shrink: 0;
}
.post-meta .avatar svg { width: 20px; height: 20px; }
.post-meta .who { flex: 1; min-width: 0; }
.post-meta .who .name { font-weight: 600; font-size: 14px; }
.post-meta .who .sub { color: var(--color-text-muted); font-size: 12px; }
.post-caption {
  padding: 12px 14px;
  background: var(--stc-ink-50);
  border-radius: var(--radius-md);
  font-size: 13px;
  line-height: 1.6;
  margin-bottom: 14px;
  white-space: pre-wrap;
  word-break: break-word;
}
.post-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 14px; }
.post-kpi {
  background: var(--stc-ink-50);
  border-radius: var(--radius-md);
  padding: 10px 12px;
}
.post-kpi .label {
  font-size: 10px; font-weight: 600; color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.06em;
}
.post-kpi .val { font-size: 20px; font-weight: 700; margin-top: 2px; letter-spacing: -0.01em; }

/* ------- RTL tweaks ------- */
html[dir="rtl"] .kpi .stripe { left: auto; right: 0; }
html[dir="rtl"] .page-header { text-align: right; }
html[dir="rtl"] .modal-foot { justify-content: flex-start; }
html[dir="rtl"] body, html[dir="rtl"] input, html[dir="rtl"] select, html[dir="rtl"] button,
html[dir="rtl"] .kpi .handle, html[dir="rtl"] table td, html[dir="rtl"] .account-row .acc-name,
html[dir="rtl"] .account-row .acc-sub, html[dir="rtl"] .brand, html[dir="rtl"] .page-header h1,
html[dir="rtl"] .page-header p, html[dir="rtl"] .card-title, html[dir="rtl"] .compare-chip {
  font-family: var(--font-sans-ar);
}
/* Keep brand handles & numbers in Latin script even in Arabic mode */
.latin { font-family: var(--font-sans-en) !important; direction: ltr; unicode-bidi: embed; display: inline-block; }

/* Force Arabic (Saudi) dates to show Gregorian calendar inline */
html[dir="rtl"] time { direction: rtl; }

/* The whole deltas row reads LTR because it contains numbers + icons */
html[dir="rtl"] .kpi .deltas { direction: ltr; justify-content: flex-end; }
html[dir="rtl"] .kpi .handle { direction: ltr; text-align: right; }
