/* Jalal admin panel — Metronic-inspired design system layered over
   Bootstrap 5. Light content surfaces, dark navigation rail, soft
   neutrals, generous radii, subtle shadows. RTL-aware via logical
   properties. No assets borrowed — visual likeness only. */

/* ─── Tokens ──────────────────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --jl-bg: #f4f6fa;
  --jl-surface: #ffffff;
  --jl-surface-2: #f9fafc;
  --jl-surface-hover: #f7f9fc;

  /* Text */
  --jl-heading: #181c32;
  --jl-text: #4b5675;
  --jl-text-strong: #252f4a;
  --jl-text-muted: #78829d;

  /* Borders */
  --jl-border: #f1f1f4;
  --jl-border-strong: #e4e6ef;

  /* Sidebar (dark rail) */
  --jl-sidebar-bg: #13141a;
  --jl-sidebar-bg-2: #0f1015;
  --jl-sidebar-text: #9b9da6;
  --jl-sidebar-text-strong: #d0d2db;
  --jl-sidebar-text-muted: #5e6173;
  --jl-sidebar-heading: #6c6e7e;
  --jl-sidebar-hover-bg: rgba(255, 255, 255, .04);
  --jl-sidebar-active-bg: rgba(27, 132, 255, .14);
  --jl-sidebar-active-text: #ffffff;
  --jl-sidebar-accent: #1b84ff;

  /* Brand */
  --jl-primary: #1b84ff;
  --jl-primary-hover: #056ee9;
  --jl-primary-active: #0061d3;
  --jl-primary-light: #eff6ff;
  --jl-primary-rgb: 27, 132, 255;

  /* Status */
  --jl-success: #17c653;
  --jl-success-light: #dfffea;
  --jl-danger: #f8285a;
  --jl-danger-light: #ffeef3;
  --jl-warning: #f6c000;
  --jl-warning-light: #fff8dd;
  --jl-info: #7239ea;
  --jl-info-light: #f1e8ff;

  /* Effects */
  --jl-shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);
  --jl-shadow: 0 4px 16px rgba(15, 23, 42, .04), 0 1px 2px rgba(15, 23, 42, .03);
  --jl-shadow-lg: 0 12px 30px rgba(15, 23, 42, .07);
  --jl-shadow-topbar: 0 1px 0 var(--jl-border);
  --jl-radius: 12px;
  --jl-radius-sm: 8px;
  --jl-radius-pill: 999px;

  /* Layout */
  --jl-sidebar-w: 245px;
  --jl-topbar-h: 64px;
}

/* ─── Base ────────────────────────────────────────────────────────────── */
html, body { height: 100%; }

body {
  background: var(--jl-bg);
  color: var(--jl-text);
  font-family: "Vazirmatn", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI",
               Roboto, Tahoma, sans-serif;
  font-size: 13px;
  line-height: 1.55;
  font-feature-settings: "ss01", "ss02";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5 { color: var(--jl-heading); font-weight: 600; }
a { color: var(--jl-primary); text-decoration: none; }
a:hover { color: var(--jl-primary-hover); }
code { color: var(--jl-text-strong); background: var(--jl-surface-2); padding: .1rem .35rem; border-radius: 4px; }

/* ─── Layout shell ────────────────────────────────────────────────────── */
.jl-layout {
  display: flex;
  min-height: 100vh;
}

.jl-sidebar {
  width: var(--jl-sidebar-w);
  background: var(--jl-sidebar-bg);
  color: var(--jl-sidebar-text);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  bottom: 0;
  inset-inline-start: 0;
  z-index: 1030;
  transition: transform .25s ease;
}

.jl-sidebar__brand {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: 0 1.25rem;
  height: var(--jl-topbar-h);
  background: var(--jl-sidebar-bg-2);
  border-bottom: 1px solid rgba(255, 255, 255, .04);
  flex-shrink: 0;
}
.jl-sidebar__brand img {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  object-fit: cover;
}
.jl-sidebar__brand .jl-brand-name {
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.1;
}
.jl-sidebar__brand .jl-brand-sub {
  color: var(--jl-sidebar-text-muted);
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-top: 2px;
}

.jl-sidebar__nav {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 1rem .65rem 1rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.06) transparent;
}
.jl-sidebar__nav::-webkit-scrollbar { width: 6px; }
.jl-sidebar__nav::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.06);
  border-radius: 3px;
}

.jl-sidebar__heading {
  padding: 1.1rem .85rem .45rem;
  font-size: 10px;
  text-transform: uppercase;
  color: var(--jl-sidebar-heading);
  letter-spacing: .08em;
  font-weight: 600;
}

.jl-nav-link {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .55rem .85rem;
  color: var(--jl-sidebar-text);
  text-decoration: none;
  font-size: 13px;
  border-radius: var(--jl-radius-sm);
  margin: 1px 0;
  position: relative;
  transition: background .15s ease, color .15s ease;
}
.jl-nav-link i {
  font-size: 1.05rem;
  width: 20px;
  text-align: center;
  color: var(--jl-sidebar-text-muted);
  transition: color .15s ease;
}
.jl-nav-link:hover {
  background: var(--jl-sidebar-hover-bg);
  color: var(--jl-sidebar-text-strong);
}
.jl-nav-link:hover i { color: var(--jl-sidebar-text-strong); }
.jl-nav-link.active {
  background: var(--jl-sidebar-active-bg);
  color: var(--jl-sidebar-active-text);
  font-weight: 500;
}
.jl-nav-link.active i { color: var(--jl-sidebar-accent); }
.jl-nav-link.active::before {
  content: "";
  position: absolute;
  inset-inline-start: -.65rem;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: var(--jl-sidebar-accent);
  border-start-end-radius: 3px;
  border-end-end-radius: 3px;
}

.jl-sidebar__footer {
  padding: .9rem 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, .04);
  font-size: 11px;
  color: var(--jl-sidebar-text-muted);
  flex-shrink: 0;
}

/* ─── Main column ─────────────────────────────────────────────────────── */
.jl-main {
  flex: 1 1 auto;
  margin-inline-start: var(--jl-sidebar-w);
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.jl-topbar {
  height: var(--jl-topbar-h);
  background: var(--jl-surface);
  border-bottom: 1px solid var(--jl-border);
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
  gap: 1rem;
  position: sticky;
  top: 0;
  z-index: 1020;
}
.jl-topbar--nonprod {
  background: #ff9800;
  border-bottom-color: #e08600;
}
.jl-topbar--nonprod .jl-topbar__title,
.jl-topbar--nonprod .jl-topbar__user > div > div,
.jl-topbar--nonprod .jl-topbar__user > div > small {
  color: #1f1300;
}
.jl-topbar__title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--jl-heading);
  margin: 0;
}
.jl-topbar__spacer { flex: 1 1 auto; }
.jl-topbar__user {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-size: 13px;
  padding: .35rem .55rem;
  border-radius: var(--jl-radius-sm);
}
.jl-topbar__user > div {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.jl-topbar__user > div > div { color: var(--jl-text-strong); font-weight: 500; }
.jl-topbar__user > div > small { color: var(--jl-text-muted); font-size: 11px; }
.jl-topbar__user .avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--jl-primary), #5b8def);
  color: #fff;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

/* ─── Sidebar toggle (mobile) ────────────────────────────────────────── */
.jl-sidebar-toggle {
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border-strong);
  width: 38px;
  height: 38px;
  border-radius: var(--jl-radius-sm);
  color: var(--jl-text-strong);
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
}
.jl-sidebar-toggle:hover { background: var(--jl-surface-hover); }

@media (max-width: 991.98px) {
  .jl-sidebar { transform: translateX(100%); }
  [dir="ltr"] .jl-sidebar { transform: translateX(-100%); }
  .jl-sidebar.is-open { transform: translateX(0); }
  .jl-main { margin-inline-start: 0; }
  .jl-sidebar-toggle { display: inline-flex; }
}

/* ─── Content ─────────────────────────────────────────────────────────── */
.jl-content {
  padding: 1.5rem;
  flex: 1 1 auto;
  max-width: 1500px;
  width: 100%;
  margin: 0 auto;
}

.jl-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
.jl-page-header h1 {
  font-size: 1.35rem;
  font-weight: 600;
  margin: 0;
  color: var(--jl-heading);
}
.jl-page-header__sub {
  color: var(--jl-text-muted);
  font-size: 13px;
  margin-top: .15rem;
}
.jl-page-header__actions { display: flex; gap: .5rem; }

/* ─── Cards ───────────────────────────────────────────────────────────── */
.jl-card {
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius);
  box-shadow: var(--jl-shadow);
  overflow: hidden;
}
.jl-card + .jl-card { margin-top: 1rem; }

.jl-card__header {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--jl-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.jl-card__title {
  font-weight: 600;
  font-size: .95rem;
  margin: 0;
  color: var(--jl-heading);
}
.jl-card__sub {
  display: block;
  color: var(--jl-text-muted);
  font-size: 12px;
  font-weight: 400;
  margin-top: .15rem;
}
.jl-card__body { padding: 1.25rem; }
.jl-card__body.p-0 { padding: 0; }

/* ─── Stat tiles ──────────────────────────────────────────────────────── */
.jl-stat {
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius);
  box-shadow: var(--jl-shadow);
  padding: 1.1rem 1.25rem;
  display: flex;
  align-items: flex-start;
  gap: .9rem;
  height: 100%;
}
.jl-stat__icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  flex-shrink: 0;
  background: var(--jl-primary-light);
  color: var(--jl-primary);
}
.jl-stat__icon--success { background: var(--jl-success-light); color: var(--jl-success); }
.jl-stat__icon--warning { background: var(--jl-warning-light); color: #b58200; }
.jl-stat__icon--info    { background: var(--jl-info-light);    color: var(--jl-info); }
.jl-stat__icon--danger  { background: var(--jl-danger-light);  color: var(--jl-danger); }

.jl-stat__body { flex: 1 1 auto; min-width: 0; }
.jl-stat__label {
  font-size: 12px;
  color: var(--jl-text-muted);
  margin-bottom: .15rem;
}
.jl-stat__value {
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--jl-heading);
  line-height: 1.1;
  letter-spacing: -.01em;
}
.jl-stat__link {
  display: inline-block;
  margin-top: .35rem;
  font-size: 12px;
  color: var(--jl-primary);
}
.jl-stat__link:hover { color: var(--jl-primary-hover); }

/* ─── Tables ──────────────────────────────────────────────────────────── */
.jl-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.jl-table thead th {
  background: var(--jl-surface-2);
  color: var(--jl-text-muted);
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
  border-bottom: 1px solid var(--jl-border);
  padding: .85rem 1.1rem;
  text-align: start;
  white-space: nowrap;
}
.jl-table thead th:first-child { padding-inline-start: 1.25rem; }
.jl-table thead th:last-child  { padding-inline-end: 1.25rem; }

.jl-table tbody td {
  padding: .9rem 1.1rem;
  border-bottom: 1px solid var(--jl-border);
  vertical-align: middle;
  color: var(--jl-text);
}
.jl-table tbody td:first-child { padding-inline-start: 1.25rem; }
.jl-table tbody td:last-child  { padding-inline-end: 1.25rem; }
.jl-table tbody tr:last-child td { border-bottom: 0; }
.jl-table tbody tr:hover { background: var(--jl-surface-hover); }
.jl-table .jl-actions { white-space: nowrap; text-align: end; }
.jl-table .jl-actions .btn { padding: .3rem .55rem; }
.jl-table .jl-actions .btn + .btn,
.jl-table .jl-actions .btn + form { margin-inline-start: .25rem; }

.jl-empty {
  padding: 3rem 1rem;
  color: var(--jl-text-muted);
  text-align: center;
  font-size: 13px;
}
.jl-empty i {
  display: block;
  font-size: 2rem;
  color: var(--jl-border-strong);
  margin-bottom: .5rem;
}

/* ─── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  border-radius: var(--jl-radius-sm);
  font-weight: 500;
  font-size: 13px;
  padding: .5rem .95rem;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  line-height: 1.4;
  border-width: 1px;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease;
}
.btn-sm { padding: .4rem .75rem; font-size: 12px; }
.btn-lg { padding: .65rem 1.25rem; font-size: 14px; }
.btn:focus, .btn.focus { box-shadow: 0 0 0 3px rgba(var(--jl-primary-rgb), .15); }

.btn-primary {
  background-color: var(--jl-primary);
  border-color: var(--jl-primary);
  color: #fff;
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--jl-primary-hover);
  border-color: var(--jl-primary-hover);
  color: #fff;
}
.btn-primary:active, .btn-primary.active {
  background-color: var(--jl-primary-active) !important;
  border-color: var(--jl-primary-active) !important;
}

.btn-outline-secondary {
  color: var(--jl-text-strong);
  border-color: var(--jl-border-strong);
  background: var(--jl-surface);
}
.btn-outline-secondary:hover, .btn-outline-secondary:focus {
  background: var(--jl-surface-hover);
  color: var(--jl-text-strong);
  border-color: var(--jl-border-strong);
}

.btn-outline-danger {
  color: var(--jl-danger);
  border-color: var(--jl-border-strong);
  background: var(--jl-surface);
}
.btn-outline-danger:hover, .btn-outline-danger:focus {
  background: var(--jl-danger);
  color: #fff;
  border-color: var(--jl-danger);
}

.btn-link { color: var(--jl-primary); text-decoration: none; padding: .3rem .5rem; }
.btn-link:hover { color: var(--jl-primary-hover); text-decoration: underline; }

/* ─── Forms ───────────────────────────────────────────────────────────── */
.form-label {
  font-weight: 500;
  font-size: 12px;
  color: var(--jl-text-strong);
  margin-bottom: .35rem;
}
.form-text { font-size: 12px; color: var(--jl-text-muted); }

.form-control, .form-select {
  border: 1px solid var(--jl-border-strong);
  border-radius: var(--jl-radius-sm);
  padding: .55rem .85rem;
  font-size: 13px;
  color: var(--jl-text-strong);
  background-color: var(--jl-surface);
  transition: border-color .15s ease, box-shadow .15s ease;
}

/* RTL: chevron sits on the physical left; reserve padding on the left
   (inline-end in RTL) so the dropdown text doesn't collide with it. */
.form-select {
  padding-inline-start: .85rem;
  padding-inline-end: 2.25rem;
  background-position: left .75rem center;
}
.form-select-sm {
  padding-inline-start: .65rem;
  padding-inline-end: 1.85rem;
  background-position: left .55rem center;
}
.form-control:focus, .form-select:focus {
  border-color: var(--jl-primary);
  box-shadow: 0 0 0 3px rgba(var(--jl-primary-rgb), .12);
  color: var(--jl-text-strong);
  outline: none;
}
.form-control::placeholder { color: #a1a5b7; }
.form-control[readonly] { background: var(--jl-surface-2); }
.form-control.is-invalid, .form-select.is-invalid {
  border-color: var(--jl-danger);
}
.form-control.is-invalid:focus {
  box-shadow: 0 0 0 3px rgba(248, 40, 90, .12);
}
.form-control-sm, .form-select-sm {
  padding: .4rem .65rem;
  font-size: 12px;
  border-radius: 6px;
}
textarea.form-control { line-height: 1.55; }

.invalid-feedback { color: var(--jl-danger); font-size: 12px; }

.form-check-input:checked {
  background-color: var(--jl-primary);
  border-color: var(--jl-primary);
}
.form-check-input:focus {
  box-shadow: 0 0 0 3px rgba(var(--jl-primary-rgb), .12);
  border-color: var(--jl-primary);
}

/* ─── Login screen ────────────────────────────────────────────────────── */
.jl-login {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 20% 20%, rgba(27,132,255,.12), transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(114,57,234,.10), transparent 40%),
    linear-gradient(135deg, #0f1015 0%, #1a1d29 100%);
  padding: 1.5rem;
}
.jl-login__card {
  width: 100%;
  max-width: 420px;
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: 18px;
  padding: 2.25rem;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .35);
}
.jl-login__brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.75rem;
}
.jl-login__brand img {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  object-fit: cover;
  box-shadow: var(--jl-shadow);
}
.jl-login__brand h1 {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0;
  color: var(--jl-heading);
}
.jl-login__brand p {
  color: var(--jl-text-muted);
  font-size: 12px;
  margin: 0;
  text-align: center;
}

/* ─── Chips / badges ──────────────────────────────────────────────────── */
.jl-chip {
  display: inline-flex;
  align-items: center;
  padding: .2rem .55rem;
  border-radius: var(--jl-radius-pill);
  font-size: 11px;
  font-weight: 600;
  background: var(--jl-surface-2);
  color: var(--jl-text);
  border: 1px solid var(--jl-border-strong);
  margin-inline-end: .25rem;
  letter-spacing: .01em;
}
.jl-chip--admin { background: var(--jl-primary-light); color: var(--jl-primary); border-color: rgba(var(--jl-primary-rgb), .2); }
.jl-chip--good  { background: var(--jl-success-light); color: #0d8e3c; border-color: #b7f0c8; }
.jl-chip--warn  { background: var(--jl-warning-light); color: #ad8800; border-color: #f4dd87; }
.jl-chip--info  { background: var(--jl-info-light); color: var(--jl-info); border-color: #d8c5f5; }
.jl-chip--danger { background: var(--jl-danger-light); color: var(--jl-danger); border-color: #f9c2cf; }

/* ─── Linkable chip (used in tables to filter by value) ──────────────── */
a.jl-chip { transition: background-color .15s ease, color .15s ease, border-color .15s ease; }
a.jl-chip:hover { text-decoration: none; }
.jl-chip--link {
  cursor: pointer;
  gap: .25rem;
}
.jl-chip--link i { font-size: .85em; }
a.jl-chip--info:hover {
  background: var(--jl-info);
  color: #fff;
  border-color: var(--jl-info);
}

/* ─── Tag bar (settings list filter pills) ───────────────────────────── */
.jl-tagbar {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1rem;
  padding: .65rem .75rem;
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius);
  box-shadow: var(--jl-shadow-sm);
}
.jl-tag {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .7rem;
  border-radius: var(--jl-radius-pill);
  font-size: 12px;
  font-weight: 500;
  background: var(--jl-surface-2);
  color: var(--jl-text-strong);
  border: 1px solid var(--jl-border-strong);
  text-decoration: none;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.jl-tag:hover {
  background: var(--jl-primary-light);
  color: var(--jl-primary);
  border-color: rgba(var(--jl-primary-rgb), .25);
}
.jl-tag--active {
  background: var(--jl-primary);
  color: #fff;
  border-color: var(--jl-primary);
}
.jl-tag--active:hover {
  background: var(--jl-primary-hover);
  color: #fff;
  border-color: var(--jl-primary-hover);
}
.jl-tag__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.4rem;
  padding: 0 .4rem;
  border-radius: var(--jl-radius-pill);
  background: rgba(0, 0, 0, .06);
  color: inherit;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  font-feature-settings: "tnum";
}
.jl-tag--active .jl-tag__count { background: rgba(255, 255, 255, .22); }
.jl-tag--clear {
  background: transparent;
  color: var(--jl-text-muted);
  border-color: transparent;
}
.jl-tag--clear:hover {
  background: var(--jl-danger-light);
  color: var(--jl-danger);
  border-color: var(--jl-danger-light);
}

/* ─── Avatars ─────────────────────────────────────────────────────────── */
.jl-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1b84ff, #7239ea);
  color: #fff;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}
.jl-user-cell {
  display: flex;
  align-items: center;
  gap: .65rem;
}
.jl-user-cell__name { color: var(--jl-text-strong); font-weight: 500; }
.jl-user-cell__sub { color: var(--jl-text-muted); font-size: 11px; }

/* ─── Helpers ─────────────────────────────────────────────────────────── */
.jl-mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.jl-truncate {
  display: inline-block;
  max-width: 320px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
}
.jl-flash { margin-bottom: 1rem; }
.text-muted { color: var(--jl-text-muted) !important; }

/* ─── Alerts ──────────────────────────────────────────────────────────── */
.alert {
  border-radius: var(--jl-radius-sm);
  border: 1px solid transparent;
  padding: .75rem 1rem;
  font-size: 13px;
}
.alert-success { background: var(--jl-success-light); color: #0d8e3c; border-color: #b7f0c8; }
.alert-danger  { background: var(--jl-danger-light); color: var(--jl-danger); border-color: #f9c2cf; }
.alert-warning { background: var(--jl-warning-light); color: #ad8800; border-color: #f4dd87; }
.alert-info    { background: var(--jl-info-light); color: var(--jl-info); border-color: #d8c5f5; }

/* RTL: Bootstrap pins .btn-close to right:0; flip to start (left in RTL). */
.alert-dismissible {
  padding-inline-start: 1rem;
  padding-inline-end: 3rem;
}
.alert-dismissible .btn-close {
  right: auto;
  left: 0;
}

/* ─── Row-based JSON object editor ────────────────────────────────────── */
.jl-jsoneditor__rows {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.jl-jsoneditor__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 7.5rem minmax(0, 1.6fr) auto;
  gap: .5rem;
  align-items: center;
  padding: .5rem;
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
}
.jl-jsoneditor__row .jl-jsoneditor__value > * { width: 100%; }
.jl-jsoneditor__rm { line-height: 1; padding: .3rem .55rem; }
@media (max-width: 575.98px) {
  .jl-jsoneditor__row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "key   rm"
      "type  type"
      "value value";
  }
  .jl-jsoneditor__row .jl-jsoneditor__key   { grid-area: key; }
  .jl-jsoneditor__row .jl-jsoneditor__rm    { grid-area: rm; }
  .jl-jsoneditor__row .jl-jsoneditor__type  { grid-area: type; }
  .jl-jsoneditor__row .jl-jsoneditor__value { grid-area: value; }
}

/* ─── Boards "lists" editor ───────────────────────────────────────────── */
.jl-listseditor__rows {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.jl-listseditor__row {
  display: grid;
  grid-template-columns: minmax(0, .6fr) minmax(0, .9fr) minmax(0, 1.5fr) auto;
  gap: .5rem;
  align-items: center;
  padding: .5rem;
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
}
.jl-listseditor__ops .btn { line-height: 1; padding: .3rem .55rem; }
@media (max-width: 767.98px) {
  .jl-listseditor__row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "id      ops"
      "title   title"
      "purpose purpose";
  }
  .jl-listseditor__row .jl-listseditor__id      { grid-area: id; }
  .jl-listseditor__row .jl-listseditor__ops     { grid-area: ops; }
  .jl-listseditor__row .jl-listseditor__title   { grid-area: title; }
  .jl-listseditor__row .jl-listseditor__purpose { grid-area: purpose; }
}

/* ─── Settings JSON editor (object/array) ─────────────────────────────── */
.jl-settingsjson__shape {
  display: flex;
  gap: 1.25rem;
  align-items: center;
  padding: .5rem .75rem;
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
}
.jl-settingsjson__rows {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.jl-settingsjson__row {
  display: grid;
  gap: .5rem;
  align-items: start;
  padding: .55rem;
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
}
.jl-settingsjson__row--object {
  grid-template-columns: minmax(0, .5fr) 7.5rem minmax(0, 2fr) auto;
}
.jl-settingsjson__row--array {
  grid-template-columns: 3rem 7.5rem minmax(0, 1fr) auto;
}
.jl-settingsjson__row > * { min-width: 0; }
.jl-settingsjson__row .jl-settingsjson__value > * { width: 100%; }
.jl-settingsjson__index {
  align-self: center;
  text-align: center;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--jl-text-muted);
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: 6px;
  padding: .35rem 0;
  direction: ltr;
}
.jl-settingsjson__textarea { resize: vertical; min-height: 2.1rem; }
.jl-settingsjson__ops .btn { line-height: 1; padding: .3rem .55rem; }

/* Nested container — when a row's type is object/array, the value cell
   hosts another rows-editor at one indentation level deeper. The left
   accent bar makes depth visible at a glance; RTL-safe via logical
   `border-inline-start`. */
.jl-settingsjson__nested {
  padding: .4rem .55rem .55rem;
  background: var(--jl-surface);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
  border-inline-start: 3px solid var(--jl-primary-light);
}
.jl-settingsjson__nested .jl-settingsjson__rows {
  gap: .35rem;
}
.jl-settingsjson__nested .jl-settingsjson__row {
  padding: .4rem;
  background: var(--jl-surface-2);
}
.jl-settingsjson__nested--array { border-inline-start-color: #f1e8ff; }
.jl-settingsjson__nested--object { border-inline-start-color: var(--jl-primary-light); }
.jl-settingsjson__nested .jl-settingsjson__nested {
  /* Slightly stronger accent at deeper levels so 3+ levels stay legible. */
  border-inline-start-color: var(--jl-primary);
  background: var(--jl-surface-2);
}

@media (max-width: 767.98px) {
  .jl-settingsjson__row--object {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "key   rm"
      "type  type"
      "value value";
  }
  .jl-settingsjson__row--object .jl-settingsjson__key   { grid-area: key; }
  .jl-settingsjson__row--object .jl-settingsjson__type  { grid-area: type; }
  .jl-settingsjson__row--object .jl-settingsjson__value { grid-area: value; }
  .jl-settingsjson__row--object .jl-settingsjson__ops   { grid-area: rm; }

  .jl-settingsjson__row--array {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "idx   ops"
      "type  type"
      "value value";
  }
  .jl-settingsjson__row--array .jl-settingsjson__index { grid-area: idx; }
  .jl-settingsjson__row--array .jl-settingsjson__type  { grid-area: type; }
  .jl-settingsjson__row--array .jl-settingsjson__value { grid-area: value; }
  .jl-settingsjson__row--array .jl-settingsjson__ops   { grid-area: ops; }
}

/* The LTR-direction toggle on string textareas — line up the switch with
   the label and keep it tight. */
.jl-dir-textarea { transition: none; }

/* ─── Audit logs table ────────────────────────────────────────────────── */
.jl-audit-row:hover { background: var(--jl-surface-hover); }
.jl-card__footer {
  border-top: 1px solid var(--jl-border);
  background: var(--jl-surface-2);
}
.jl-pre {
  background: var(--jl-surface-2);
  border: 1px solid var(--jl-border);
  border-radius: var(--jl-radius-sm);
  padding: .6rem .75rem;
  font-size: 12px;
  white-space: pre-wrap;
  word-break: break-word;
  margin: 0;
  max-height: 260px;
  overflow: auto;
}
.jl-detail-label { color: var(--jl-text-muted); font-weight: 500; }

/* Force the modal close button to the visual left in our RTL admin —
   Bootstrap's default `.btn-close` uses physical `margin-left: auto`
   which fights with RTL flex placement. Override with logical margins. */
.jl-modal-header--close-start { gap: .75rem; }
.jl-modal-header--close-start .btn-close {
  margin: 0 !important;
  margin-inline-start: auto !important;
}
