/* ============================================================
   IMS — Ideas Management System · Redesign
   Design system: "Lumen"
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800&display=swap');

:root {
  /* ---- Brand (refined azure, evolved from #007DFC) ---- */
  --brand-50:  #eef5ff;
  --brand-100: #d9e8ff;
  --brand-200: #bcd7ff;
  --brand-300: #8ebdff;
  --brand-400: #599bff;
  --brand-500: #2f7bff;
  --brand-600: #0a66ff;   /* primary */
  --brand-700: #0a52d6;
  --brand-800: #0f45a8;
  --brand-900: #123c85;

  /* ---- Coral (kept "idea" accent, evolved from #F96332) ---- */
  --coral-50:  #fff3ee;
  --coral-100: #ffe2d5;
  --coral-400: #fb8a5c;
  --coral-500: #f4623a;   /* idea titles / secondary accent */
  --coral-600: #e14e29;

  /* ---- Ink / slate neutrals ---- */
  --ink-900: #0e1626;
  --ink-800: #1c2638;
  --ink-700: #313b4d;     /* primary text (was rgb 49,55,64) */
  --ink-600: #4a5468;
  --ink-500: #69748a;
  --ink-400: #9aa2b3;     /* muted text */
  --ink-300: #c2c8d4;
  --ink-200: #e2e6ee;
  --ink-100: #eef1f6;
  --ink-50:  #f6f8fb;

  /* ---- Semantic ---- */
  --success: #15a564;
  --success-bg: #e7f6ee;
  --warning: #e8930c;
  --warning-bg: #fdf1da;
  --danger:  #e23b56;
  --danger-bg: #fde7eb;
  --violet:  #6d5cf0;
  --violet-bg: #ecebfd;

  /* ---- Surfaces ---- */
  --bg: #f4f6fa;
  --surface: #ffffff;
  --surface-2: #f8fafc;
  --line: #e7ebf1;
  --line-strong: #d8dee8;
  --input-bg: #ffffff;
  --pop-bg: #ffffff;
  --on-accent: #ffffff;

  /* ---- Accent that Tweaks can override ---- */
  --accent: var(--brand-600);
  --accent-600: var(--brand-600);
  --accent-700: var(--brand-700);
  --accent-50: var(--brand-50);
  --accent-100: var(--brand-100);
  --accent-rgb: 10, 102, 255;

  /* ---- Radius ---- */
  --r-xs: 7px;
  --r-sm: 10px;
  --r:    13px;
  --r-lg: 17px;
  --r-xl: 22px;
  --r-pill: 999px;

  /* ---- Shadow ---- */
  --sh-xs: 0 1px 2px rgba(16,24,40,.05);
  --sh-sm: 0 1px 2px rgba(16,24,40,.04), 0 2px 6px rgba(16,24,40,.05);
  --sh-md: 0 4px 12px rgba(16,24,40,.07), 0 2px 4px rgba(16,24,40,.04);
  --sh-lg: 0 12px 32px rgba(16,24,40,.12), 0 4px 10px rgba(16,24,40,.06);
  --sh-xl: 0 24px 60px rgba(14,22,38,.22);

  /* ---- Density (Tweaks can override) ---- */
  --density: 1;
  --row-h: 64px;

  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--ink-700);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; }
::selection { background: var(--accent-100); color: var(--accent-700); }
.tnum { font-variant-numeric: tabular-nums; }

/* scrollbar */
*::-webkit-scrollbar { width: 11px; height: 11px; }
*::-webkit-scrollbar-thumb { background: var(--ink-200); border-radius: 99px; border: 3px solid transparent; background-clip: content-box; }
*::-webkit-scrollbar-thumb:hover { background: var(--ink-300); background-clip: content-box; }
*::-webkit-scrollbar-track { background: transparent; }

/* ============================================================
   App shell
   ============================================================ */
#root { height: 100%; }
.app {
  display: grid;
  grid-template-columns: 264px 1fr;
  height: 100%;
  overflow: hidden;
}
.app.rail-collapsed { grid-template-columns: 84px 1fr; }

/* ---- Sidebar ---- */
.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  min-height: 0;
  position: relative;
  z-index: 30;
}
.brand {
  display: flex; align-items: center; gap: 12px;
  padding: 22px 22px 18px;
  height: 72px;
}
.brand-mark {
  width: 40px; height: 40px; border-radius: 12px; flex: none;
  background: linear-gradient(145deg, var(--accent-600), var(--accent-700));
  display: grid; place-items: center;
  box-shadow: 0 6px 16px rgba(var(--accent-rgb), .35);
}
.brand-mark svg { width: 22px; height: 22px; }
.brand-text { display: flex; flex-direction: column; line-height: 1; white-space: nowrap; }
.brand-text b { font-size: 19px; font-weight: 800; color: var(--ink-900); letter-spacing: -.02em; }
.brand-text span { font-size: 10.5px; font-weight: 600; color: var(--ink-400); letter-spacing: .14em; text-transform: uppercase; margin-top: 4px; }
.rail-collapsed .brand-text { display: none; }
.rail-collapsed .brand { padding: 22px 0; justify-content: center; }

.nav { padding: 8px 16px; flex: 1; min-height: 0; overflow-y: auto; }
.nav-label {
  font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-400); padding: 16px 12px 8px;
}
.rail-collapsed .nav-label { opacity: 0; height: 8px; padding: 0; }
.nav-item {
  display: flex; align-items: center; gap: 13px;
  width: 100%; padding: 11px 12px; border-radius: var(--r-sm);
  color: var(--ink-600); font-size: 14.5px; font-weight: 600; white-space: nowrap;
  position: relative; transition: background .15s, color .15s; text-align: left;
  margin-bottom: 2px;
}
.nav-item svg { width: 21px; height: 21px; flex: none; }
.nav-item:hover { background: var(--ink-50); color: var(--ink-800); }
.nav-item.active { background: var(--accent-50); color: var(--accent-700); }
.nav-item.active::before {
  content: ''; position: absolute; left: -16px; top: 50%; transform: translateY(-50%);
  width: 4px; height: 22px; border-radius: 0 4px 4px 0; background: var(--accent-600);
}
.rail-filled .nav-item.active { background: var(--accent-600); color: var(--on-accent); box-shadow: 0 6px 16px rgba(var(--accent-rgb),.32); }
.rail-filled .nav-item.active::before { display: none; }
.nav-item .badge {
  margin-left: auto; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 99px;
  background: var(--coral-500); color: #fff;
}
.rail-collapsed .nav-item { justify-content: center; padding: 11px 0; }
.rail-collapsed .nav-item span, .rail-collapsed .nav-item .badge { display: none; }
.rail-collapsed .nav-item.active::before { display: none; }

.sidebar-foot { padding: 16px; border-top: 1px solid var(--line); }
.balance-card {
  border-radius: var(--r); padding: 14px 16px;
  background: linear-gradient(135deg, var(--ink-900), #232f47);
  color: #fff; position: relative; overflow: hidden;
}
.balance-card::after {
  content: ''; position: absolute; right: -30px; top: -30px; width: 110px; height: 110px;
  border-radius: 50%; background: radial-gradient(circle, rgba(var(--accent-rgb),.5), transparent 70%);
}
.balance-card .lbl { font-size: 11.5px; font-weight: 600; color: rgba(255,255,255,.6); letter-spacing: .04em; }
.balance-card .amt { font-size: 24px; font-weight: 800; letter-spacing: -.02em; margin-top: 3px; display: flex; align-items: baseline; gap: 4px; }
.balance-card .amt small { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.6); }
.balance-card .trade {
  margin-top: 12px; width: 100%; padding: 9px; border-radius: var(--r-sm);
  background: rgba(255,255,255,.13); color: #fff; font-weight: 700; font-size: 13px; white-space: nowrap;
  display: flex; align-items: center; justify-content: center; gap: 7px; transition: background .15s;
}
.balance-card .trade:hover { background: rgba(255,255,255,.22); }
.rail-collapsed .sidebar-foot { padding: 12px 10px; }
.rail-collapsed .balance-card { padding: 12px 8px; display: grid; place-items: center; }
.rail-collapsed .balance-card .lbl, .rail-collapsed .balance-card .amt small, .rail-collapsed .balance-card .trade span { display: none; }
.rail-collapsed .balance-card .amt { font-size: 15px; }

/* ---- Main column ---- */
.main { display: flex; flex-direction: column; min-width: 0; min-height: 0; }

/* ---- Topbar ---- */
.topbar {
  height: 72px; flex: none; background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 18px; padding: 0 28px; z-index: 20;
}
.rail-toggle {
  width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center;
  color: var(--ink-500); flex: none; transition: background .15s, color .15s;
}
.rail-toggle:hover { background: var(--ink-50); color: var(--ink-800); }
.search {
  flex: 1; max-width: 520px; height: 44px; display: flex; align-items: center; gap: 11px;
  padding: 0 16px; border-radius: var(--r-pill); background: var(--ink-50);
  border: 1.5px solid transparent; transition: border .15s, background .15s;
}
.search:focus-within { background: var(--input-bg); border-color: var(--accent-300, var(--accent-600)); box-shadow: 0 0 0 4px var(--accent-50); }
.search svg { width: 19px; height: 19px; color: var(--ink-400); flex: none; }
.search input { border: none; outline: none; background: none; flex: 1; font-size: 14.5px; color: var(--ink-800); }
.search input::placeholder { color: var(--ink-400); }
.search kbd {
  font-family: var(--font); font-size: 11px; font-weight: 700; color: var(--ink-400);
  background: var(--surface); border: 1px solid var(--line); border-radius: 6px; padding: 2px 7px;
}
.top-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.icon-btn {
  width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  color: var(--ink-500); position: relative; transition: background .15s, color .15s;
}
.icon-btn:hover { background: var(--ink-50); color: var(--ink-800); }
.icon-btn .dot { position: absolute; top: 9px; right: 10px; width: 8px; height: 8px; border-radius: 50%; background: var(--coral-500); border: 2px solid var(--surface); }
.balance-pill {
  display: flex; align-items: center; gap: 9px; height: 42px; padding: 0 14px 0 11px;
  border-radius: var(--r-pill); background: var(--success-bg); color: #0c7a48; font-weight: 700; font-size: 14px;
}
.balance-pill .coin { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(145deg,#ffd66b,#f5a623); display: grid; place-items: center; color: #7a4a00; font-size: 13px; font-weight: 800; }
.lang { display: flex; align-items: center; gap: 8px; height: 42px; padding: 0 12px; border-radius: 12px; color: var(--ink-600); font-weight: 600; font-size: 14px; transition: background .15s; }
.lang:hover { background: var(--ink-50); }
.lang img, .avatar { object-fit: cover; }
.divider-v { width: 1px; height: 28px; background: var(--line); }
.avatar { border-radius: 50%; background: var(--ink-200) center/cover; flex: none; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 44px; padding: 0 20px; border-radius: 12px; font-weight: 700; font-size: 14.5px;
  transition: filter .15s, background .15s, box-shadow .15s, transform .05s; white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--accent-600); color: var(--on-accent); box-shadow: 0 6px 16px rgba(var(--accent-rgb),.32); }
.btn-primary:hover { filter: brightness(1.06); }
.btn-dark { background: var(--ink-800); color: var(--bg); }
.btn-dark:hover { background: var(--ink-900); }
.btn-ghost { background: var(--ink-50); color: var(--ink-700); }
.btn-ghost:hover { background: var(--ink-100); }
.btn-outline { background: var(--surface); color: var(--ink-700); box-shadow: inset 0 0 0 1.5px var(--line-strong); }
.btn-outline:hover { background: var(--ink-50); }
.btn-sm { height: 38px; padding: 0 16px; font-size: 13.5px; border-radius: 10px; }

/* ---- Content area ---- */
.content { flex: 1; min-height: 0; overflow-y: auto; }
.page { max-width: 1320px; margin: 0 auto; padding: 30px 36px 60px; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 22px; gap: 16px; }
.page-title { font-size: 25px; font-weight: 800; color: var(--ink-900); letter-spacing: -.02em; }
.page-sub { font-size: 14px; color: var(--ink-400); margin-top: 5px; font-weight: 500; }
.section-label { font-size: 16px; font-weight: 700; color: var(--ink-900); letter-spacing: -.01em; white-space: nowrap; }

/* ---- Card primitive ---- */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); }

/* ---- Stat cards ---- */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.stat {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 20px; box-shadow: var(--sh-sm); position: relative; overflow: hidden;
  transition: box-shadow .18s, transform .18s, border-color .18s;
}
.stat:hover { box-shadow: var(--sh-md); transform: translateY(-2px); border-color: var(--line-strong); }
.stat-top { display: flex; align-items: center; justify-content: space-between; }
.stat-ic { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; }
.stat-ic svg { width: 23px; height: 23px; }
.stat-trend { display: inline-flex; align-items: center; gap: 4px; font-size: 12.5px; font-weight: 700; padding: 4px 9px; border-radius: 99px; }
.stat-trend svg { width: 13px; height: 13px; }
.trend-up { color: var(--success); background: var(--success-bg); }
.trend-down { color: var(--danger); background: var(--danger-bg); }
.stat-num { font-size: 33px; font-weight: 800; color: var(--ink-900); letter-spacing: -.025em; margin-top: 16px; }
.stat-lbl { font-size: 13.5px; color: var(--ink-500); font-weight: 600; margin-top: 3px; }

/* ---- Tables ---- */
.table-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); overflow: hidden; }
.table-head-row {
  display: flex; align-items: center; gap: 16px; padding: 16px 22px; border-bottom: 1px solid var(--line);
}
.table-tools { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.tbl { width: 100%; }
.tbl thead th {
  text-align: left; font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: var(--ink-400); padding: 13px 18px; background: var(--surface-2); border-bottom: 1px solid var(--line);
}
.tbl tbody td { padding: calc(13px * var(--density)) 18px; border-bottom: 1px solid var(--line); font-size: 14px; color: var(--ink-700); vertical-align: middle; }
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr { transition: background .12s; }
.tbl tbody tr:hover { background: var(--accent-50); }
.tbl tbody tr.clickable { cursor: pointer; }
.user-cell { display: flex; align-items: center; gap: 11px; }
.user-cell .avatar { width: 38px; height: 38px; }
.user-cell b { font-weight: 600; color: var(--ink-800); font-size: 14px; white-space: nowrap; }
.rank { color: var(--ink-400); font-weight: 700; font-size: 13.5px; }
.idea-link { color: var(--coral-500); font-weight: 700; cursor: pointer; }
.idea-link:hover { text-decoration: underline; }
.cat-chip { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--ink-600); font-weight: 600; }
.cat-dot { width: 8px; height: 8px; border-radius: 3px; }
.desc-cell { color: var(--ink-500); max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 13.5px; }

.stat-chips { display: flex; align-items: center; gap: 7px; }
.schip { display: inline-flex; align-items: center; gap: 5px; padding: 5px 9px; border-radius: 9px; font-size: 12.5px; font-weight: 700; background: var(--ink-50); color: var(--ink-500); transition: background .12s, color .12s; }
.schip svg { width: 15px; height: 15px; }
.schip.up.on { background: var(--accent-50); color: var(--accent-700); }
.schip.down.on { background: var(--danger-bg); color: var(--danger); }
.schip.comment { color: var(--violet); }
.schip.up { cursor: pointer; }
.schip.up:hover { background: var(--accent-50); color: var(--accent-700); }
.schip.down { cursor: pointer; }
.schip.down:hover { background: var(--danger-bg); color: var(--danger); }

/* ---- Status badges ---- */
.badge-status { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 700; padding: 5px 11px; border-radius: 99px; }
.badge-status::before { content:''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.st-pending { color: var(--warning); background: var(--warning-bg); }
.st-published { color: var(--success); background: var(--success-bg); }
.st-rejected { color: var(--danger); background: var(--danger-bg); }
.st-review { color: var(--brand-600); background: var(--brand-50); }

/* ---- Pagination ---- */
.pager { display: flex; align-items: center; justify-content: space-between; padding: 16px 22px; }
.pager .per { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink-400); font-weight: 600; }
.pager .per select { height: 34px; border-radius: 8px; border: 1.5px solid var(--line); padding: 0 8px; color: var(--accent-700); font-weight: 700; background: var(--input-bg); }
.pages { display: flex; align-items: center; gap: 6px; }
.pages button { min-width: 34px; height: 34px; border-radius: 9px; font-weight: 700; font-size: 13.5px; color: var(--ink-500); transition: background .12s; padding: 0 10px; }
.pages button:hover { background: var(--ink-50); }
.pages button.active { background: var(--accent-600); color: var(--on-accent); }

/* ---- Filter chips / sort ---- */
.chip-row { display: flex; gap: 9px; flex-wrap: wrap; }
.chip {
  height: 36px; padding: 0 15px; border-radius: 99px; font-size: 13.5px; font-weight: 600;
  color: var(--ink-600); background: var(--surface); border: 1.5px solid var(--line);
  display: inline-flex; align-items: center; gap: 7px; transition: all .14s;
}
.chip:hover { border-color: var(--ink-300); }
.chip.active { background: var(--ink-900); color: var(--bg); border-color: var(--ink-900); }
.chip svg { width: 16px; height: 16px; }

/* ---- Form fields ---- */
.fld {
  width: 100%; height: 48px; border-radius: var(--r-sm); border: 1.5px solid var(--line);
  padding: 0 14px; font-size: 14.5px; color: var(--ink-800); background: var(--input-bg); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
textarea.fld { height: auto; padding: 12px 14px; line-height: 1.55; }
.fld::placeholder { color: var(--ink-400); }
.fld:focus { border-color: var(--accent-600); box-shadow: 0 0 0 4px var(--accent-50); }

/* ---- Toast ---- */
.toast-wrap { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 200; display: flex; flex-direction: column; gap: 10px; align-items: center; }
.toast {
  display: flex; align-items: center; gap: 11px; background: var(--ink-900); color: var(--bg);
  padding: 13px 18px; border-radius: var(--r); box-shadow: var(--sh-lg); font-size: 14px; font-weight: 600;
  animation: toastIn .3s cubic-bezier(.3,1.3,.5,1) both;
}
.toast .tic { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; background: var(--success); flex: none; }
@keyframes toastIn { from { opacity: 0; transform: translateY(16px) scale(.96); } to { opacity: 1; transform: none; } }

/* utility */
.row { display: flex; align-items: center; }
.spread { display: flex; align-items: center; justify-content: space-between; }
.muted { color: var(--ink-400); }
.fade-in { animation: fadeIn .4s ease both; }
@keyframes fadeIn { from { transform: translateY(9px); } to { transform: none; } }
@keyframes spin { to { transform: rotate(360deg); } }
.no-anim, .no-anim * { transition: none !important; animation: none !important; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

@media (max-width: 1180px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 920px) {
  .app { grid-template-columns: 84px 1fr; }
  .brand-text { display: none; }
}

/* ============================================================
   Dark theme
   ============================================================ */
body.dark {
  --ink-900: #f2f5fa;
  --ink-800: #e3e8f1;
  --ink-700: #ccd3e0;
  --ink-600: #aab2c4;
  --ink-500: #8b94a8;
  --ink-400: #717a8e;
  --ink-300: #545d70;
  --ink-200: #353d4e;
  --ink-100: #262d3b;
  --ink-50:  #1d2431;

  --bg: #0d1117;
  --surface: #161b26;
  --surface-2: #1b2230;
  --line: #262d3b;
  --line-strong: #333b4b;
  --input-bg: #1b2230;
  --pop-bg: #1b2230;

  --success-bg: rgba(21,165,100,.16);
  --warning-bg: rgba(232,147,12,.16);
  --danger-bg: rgba(226,59,86,.16);
  --violet-bg: rgba(109,92,240,.18);
  --coral-50: rgba(244,98,58,.16);
  --coral-100: rgba(244,98,58,.24);

  --sh-xs: 0 1px 2px rgba(0,0,0,.4);
  --sh-sm: 0 1px 2px rgba(0,0,0,.35), 0 2px 6px rgba(0,0,0,.3);
  --sh-md: 0 4px 12px rgba(0,0,0,.4), 0 2px 4px rgba(0,0,0,.3);
  --sh-lg: 0 12px 32px rgba(0,0,0,.5), 0 4px 10px rgba(0,0,0,.35);
  --sh-xl: 0 24px 60px rgba(0,0,0,.6);
}
body.dark .balance-pill { background: var(--success-bg); color: #43d699; }
body.dark .search kbd { background: var(--surface-2); }
body, .app, .sidebar, .topbar, .stat, .card, .table-card, .chip, .fld, .btn-ghost, .icon-btn, .nav-item, .tbl tbody td, .schip, .badge-status, .balance-pill {
  transition: background-color .25s ease, border-color .25s ease, color .25s ease;
}

/* ── RTL / Arabic support ─────────────────────────────────── */
[dir="rtl"] .app           { direction: rtl; }
[dir="rtl"] .sidebar       { border-right: none; border-left: 1px solid var(--line); }
[dir="rtl"] .topbar        { flex-direction: row-reverse; }
[dir="rtl"] .top-actions   { flex-direction: row-reverse; }
[dir="rtl"] .search        { flex-direction: row-reverse; }
[dir="rtl"] .nav-item      { flex-direction: row-reverse; text-align: right; }
[dir="rtl"] .nav-item .badge { margin-left: 0; margin-right: auto; }
[dir="rtl"] .nav-label     { text-align: right; }
[dir="rtl"] .brand         { flex-direction: row-reverse; }
[dir="rtl"] .brand-text    { text-align: right; }
[dir="rtl"] .balance-card  { text-align: right; }
[dir="rtl"] .btn           { flex-direction: row-reverse; }
[dir="rtl"] .spread        { flex-direction: row-reverse; }
[dir="rtl"] .page-head     { flex-direction: row-reverse; }
[dir="rtl"] .page-title,
[dir="rtl"] .page-sub      { text-align: right; }
[dir="rtl"] .card          { text-align: right; }
[dir="rtl"] .tbl th,
[dir="rtl"] .tbl td        { text-align: right; }
[dir="rtl"] .stat          { flex-direction: row-reverse; }
[dir="rtl"] .stat-ic       { margin-left: 0; margin-right: 0; }
[dir="rtl"] .chip-row      { flex-direction: row-reverse; }
[dir="rtl"] .table-head-row { flex-direction: row-reverse; }
[dir="rtl"] .lang          { flex-direction: row-reverse; gap: 6px; }
[dir="rtl"] .section-label { text-align: right; }
[dir="rtl"] .muted         { text-align: right; }
[dir="rtl"] .rail-toggle svg { transform: rotate(180deg); }
