
/* ═══════════════════════════════════════════════════════════════
   درب الزهراء للختمات — Main Stylesheet
   Clean rewrite: single implementation per component, no patches.
   ═══════════════════════════════════════════════════════════════ */


/* ─── 1. CSS Variables ─── */
:root {
  color-scheme: light;
  --bg: #f5f0e6;
  --bg2: #eaf2ec;
  --surface: #fffaf0;
  --card: rgba(255,252,244,.82);
  --card-solid: #fffaf0;
  --text: #12231d;
  --muted: #6d7b72;
  --line: rgba(35,64,51,.13);
  --primary: #0f5f45;
  --primary2: #083b2d;
  --primary-soft: rgba(15,95,69,.1);
  --gold: #c99a3e;
  --gold2: #f2d486;
  --danger: #9d3f3f;
  --shadow: 0 24px 72px rgba(24,54,42,.12);
  --shadow-soft: 0 12px 34px rgba(24,54,42,.09);
  --radius: 30px;
  --input-bg: rgba(255,255,255,.72);
  --select-bg: #fffaf0;
  --option-bg: #fffaf0;
  --option-text: #12231d;
  --btn-radius: 18px;
  --premium-border: rgba(15,95,69,.16);
  --premium-wash: linear-gradient(145deg,rgba(255,255,255,.52),rgba(255,248,229,.30));
  --danger-soft: rgba(157,63,63,.11);
  --danger-line: rgba(157,63,63,.24);
}

[data-theme="dark"] {
  color-scheme: dark;
  --bg: #06130f;
  --bg2: #11281f;
  --surface: #0c1f19;
  --card: rgba(13,31,25,.86);
  --card-solid: #0f251e;
  --text: #f6f1e4;
  --muted: #b5c2b9;
  --line: rgba(244,229,178,.14);
  --primary: #5bd19a;
  --primary2: #1d7d5c;
  --primary-soft: rgba(91,209,154,.13);
  --gold: #e7bf63;
  --gold2: #8a6723;
  --danger: #ef8e8e;
  --shadow: 0 30px 90px rgba(0,0,0,.42);
  --shadow-soft: 0 14px 42px rgba(0,0,0,.32);
  --input-bg: #102a22;
  --select-bg: #102a22;
  --option-bg: #102a22;
  --option-text: #f7f0df;
  --premium-border: rgba(231,191,99,.18);
  --premium-wash: linear-gradient(145deg,rgba(255,255,255,.08),rgba(231,191,99,.045));
  --danger-soft: rgba(255,107,107,.11);
  --danger-line: rgba(255,107,107,.26);
}


/* ─── 2. Base Reset ─── */
* { box-sizing: border-box }
html { scroll-behavior: smooth }
body {
  margin: 0;
  font-family: Tajawal, system-ui, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 82% 0%, rgba(201,154,62,.22), transparent 34%),
    radial-gradient(circle at 7% 18%, rgba(15,95,69,.16), transparent 30%),
    linear-gradient(135deg, var(--bg), var(--bg2));
  min-height: 100vh;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(201,154,62,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,154,62,.04) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.7), transparent 72%);
}
a { color: inherit; text-decoration: none }
button, input, select, textarea { font: inherit }


/* ─── 3. Layout ─── */
.app-shell {
  width: min(1180px, calc(100% - 28px));
  margin: auto;
  padding: 18px 0 36px;
  position: relative;
}
.glass {
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}


/* ─── 4. Hidden Utilities ─── */
/* Global [hidden] must win over any display rule. */
[hidden] { display: none !important }
.hidden { display: none !important }

/* Specificity-beating overrides for elements JS toggles with [hidden] */
.topbar .user-dropdown[hidden],
.topbar .user-menu[hidden],
.topbar #userPill[hidden],
.topbar #loginNav[hidden],
.topbar #ownerNav[hidden],
.topbar #mobileUserNav[hidden],
.topbar #mobileLogoutNav[hidden],
.topbar .user-dropdown a[hidden],
.collapsible-owner-form[hidden],
#createInviteForm[hidden] { display: none !important }


/* ─── 5. Topbar ─── */
/* Base shell — shared across breakpoints */
.topbar {
  position: sticky;
  top: 12px;
  z-index: 100;
  border-radius: 26px;
  overflow: visible;
}

/* Desktop (>820px): flex row — brand | nav (centered) | user-menu | theme-toggle */
@media (min-width: 821px) {
  .topbar {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 16px;
    min-height: 82px;
  }

  /* Brand */
  .topbar .brand {
    order: 1;
    flex: 0 0 auto;
    min-width: 210px;
    max-width: 260px;
  }

  /* Nav — centered */
  .topbar .nav {
    order: 2;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-width: 0;
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
  }
  .topbar .nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 11px;
    border-radius: 15px;
    white-space: nowrap;
    font-size: 14px;
    font-weight: 900;
    color: var(--muted);
    border: 1px solid transparent;
    background: transparent;
    transition: .18s ease;
  }
  .topbar .nav a:hover {
    color: var(--primary);
    background: var(--primary-soft);
    border-color: var(--line);
  }

  /* Mobile-only nav links — completely hidden on desktop */
  .topbar .nav a.mobile-user-nav,
  .topbar .nav a.mobile-logout-nav {
    display: none;
    visibility: hidden;
    width: 0;
    height: 0;
    padding: 0;
    margin: 0;
    overflow: hidden;
    pointer-events: none;
  }

  /* User-menu pill + dropdown */
  .topbar .user-menu {
    order: 3;
    flex: 0 0 auto;
    position: relative;
    display: flex;
    align-items: center;
    z-index: 500;
  }
  .topbar #userPill.user-pill-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 46px;
    min-width: 150px;
    max-width: 235px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: var(--primary-soft);
    color: var(--primary);
    font-weight: 900;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.16);
  }
  .topbar #userPill.user-pill-btn::after {
    content: "⌄";
    font-size: 12px;
    margin-inline-start: 8px;
    color: var(--muted);
  }
  .topbar .user-dropdown {
    position: absolute;
    top: calc(100% + 12px);
    inset-inline-end: 0;
    display: grid;
    gap: 6px;
    min-width: 210px;
    padding: 10px;
    border-radius: 22px;
    border: 1px solid var(--line);
    background: var(--card-solid);
    box-shadow: 0 24px 70px rgba(24,54,42,.22);
    z-index: 999;
  }
  [data-theme="dark"] .topbar .user-dropdown {
    box-shadow: 0 26px 80px rgba(0,0,0,.42);
  }
  .topbar .user-dropdown a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border-radius: 15px;
    font-weight: 900;
    color: var(--text);
    background: transparent;
    border: 0;
    white-space: nowrap;
  }
  .topbar .user-dropdown a:hover {
    background: var(--primary-soft);
    color: var(--primary);
  }
  .topbar .user-dropdown .logout-link { color: var(--danger) }

  /* Theme toggle */
  .topbar .theme-toggle {
    order: 4;
    flex: 0 0 46px;
    width: 46px;
    height: 46px;
  }

  /* Hamburger hidden on desktop */
  .topbar .menu-toggle { display: none }
}

/* Tablet (820px–980px): tighter spacing */
@media (min-width: 821px) and (max-width: 980px) {
  .topbar { gap: 10px; padding: 12px }
  .topbar .brand { min-width: 0; flex: 0 0 auto }
  .topbar .nav a { font-size: 13px; padding: 9px }
  .topbar #userPill.user-pill-btn { max-width: 150px; padding-inline: 10px }
}

/* Mobile (<820px): grid — theme-toggle col1 | hamburger col2 | brand col3 */
@media (max-width: 820px) {
  .topbar {
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: center;
    gap: 10px;
    padding: 10px;
    top: 8px;
  }

  /* Column assignments */
  .topbar .theme-toggle { grid-column: 1; grid-row: 1; justify-self: start }
  .topbar .menu-toggle  { grid-column: 2; grid-row: 1; justify-self: start }
  .topbar .brand        { grid-column: 3; grid-row: 1; justify-self: end }
  .topbar .user-menu    { display: none }

  /* Hamburger button */
  .topbar .menu-toggle {
    display: inline-flex;
    width: 46px;
    height: 46px;
    border-radius: 17px;
    background: linear-gradient(135deg, var(--primary), var(--primary2));
    color: #fff;
    border: 1px solid rgba(231,191,99,.25);
    box-shadow: 0 14px 32px rgba(15,95,69,.22);
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
  }
  /* 2-line hamburger: span 1 wide, span 2 narrow, span 3 hidden */
  .topbar .menu-toggle span {
    display: block;
    height: 2px;
    background: #fff;
    border-radius: 999px;
    transition: .18s ease;
  }
  .topbar .menu-toggle span:nth-child(1) { width: 22px }
  .topbar .menu-toggle span:nth-child(2) { width: 15px }
  .topbar .menu-toggle span:nth-child(3) { display: none }

  /* X animation when open */
  body.nav-open .topbar .menu-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg) }
  body.nav-open .topbar .menu-toggle span:nth-child(2) { opacity: 0 }

  /* Nav: hidden by default, full-width grid when open */
  body:not(.nav-open) .topbar .nav { display: none }
  body.nav-open .topbar .nav {
    display: grid !important;
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
    margin-top: 10px;
    padding: 10px;
    border-top: 1px solid var(--line);
    border-radius: 20px;
    background: rgba(255,255,255,.18);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
    animation: menuDrop .18s ease-out both;
  }
  [data-theme="dark"] body.nav-open .topbar .nav { background: rgba(0,0,0,.25) }

  /* Nav links in mobile panel */
  .topbar .nav a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.22);
    color: var(--text);
    font-size: 15px;
    font-weight: 900;
  }
  [data-theme="dark"] .topbar .nav a { background: rgba(255,255,255,.075) }
  .topbar .nav a:hover { background: var(--primary-soft); color: var(--primary) }

  /* Mobile-specific nav items shown/hidden by JS via [hidden] */
  .topbar .nav a.mobile-user-nav:not([hidden]) {
    display: flex !important;
    background: linear-gradient(135deg, var(--primary-soft), rgba(231,191,99,.12)) !important;
    color: var(--primary) !important;
    font-weight: 900 !important;
  }
  .topbar .nav a.mobile-logout-nav:not([hidden]) {
    display: flex !important;
    color: var(--danger) !important;
  }

  /* OwnerNav visible in mobile when not [hidden] */
  .topbar #ownerNav:not([hidden]),
  .topbar #mobileUserNav:not([hidden]),
  .topbar #mobileLogoutNav:not([hidden]) {
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    height: auto !important;
  }
}

/* Very small screens (<420px) */
@media (max-width: 420px) {
  .topbar .brand strong { font-size: 17px }
  .topbar .brand small  { display: none }
  .topbar .brand-mark,
  .topbar .theme-toggle,
  .topbar .menu-toggle  { width: 44px; height: 44px; border-radius: 16px }
}

/* Brand */
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: max-content;
}
.brand-mark {
  width: 48px;
  height: 48px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, #082c24, #124d3a);
  box-shadow: inset 0 0 0 1px rgba(231,191,99,.24), 0 14px 34px rgba(5,32,24,.25);
  overflow: hidden;
  flex: none;
}
.brand-mark img { width: 100%; height: 100%; display: block }
.brand strong { display: block; font-size: 18px; letter-spacing: -.01em }
.brand small  { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; font-weight: 700 }

/* Theme toggle */
.theme-toggle {
  border: 1px solid rgba(231,191,99,.22);
  background: linear-gradient(135deg, var(--primary2), var(--primary));
  color: #fff;
  width: 46px;
  height: 46px;
  border-radius: 17px;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 14px 34px rgba(15,95,69,.22);
}


/* ─── 6. Nav Groups (dropdown) ─── */
.nav-group { position: relative }
.nav-group-btn {
  padding: 10px 13px;
  border-radius: 14px;
  color: var(--muted);
  font-weight: 800;
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  transition: .18s;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.nav-group-btn:hover {
  background: var(--primary-soft);
  color: var(--text);
  box-shadow: inset 0 0 0 1px var(--line);
}
.nav-group-menu { display: none; flex-direction: column; gap: 3px }
.nav-group.open .nav-group-menu { display: flex }

@media (min-width: 821px) {
  .nav-group-menu {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 20px;
    padding: 8px;
    min-width: 190px;
    box-shadow: var(--shadow);
    z-index: 200;
  }
  .nav-group:hover .nav-group-menu { display: flex }
  .nav-group-menu a {
    padding: 10px 14px;
    border-radius: 13px;
    color: var(--text);
    font-weight: 800;
    display: block;
    white-space: nowrap;
    transition: .15s;
  }
  .nav-group-menu a:hover { background: var(--primary-soft) }
}

@media (max-width: 820px) {
  body.nav-open .nav-group { width: 100% }
  body.nav-open .nav-group-btn {
    width: 100%;
    text-align: right;
    color: var(--primary);
    padding: 10px 14px;
    pointer-events: none;
  }
  body.nav-open .nav-group-menu {
    display: flex !important;
    padding: 0 0 4px 16px;
  }
  body.nav-open .nav-group-menu a {
    color: var(--muted);
    padding: 8px 12px;
    font-weight: 800;
    border-radius: 12px;
  }
  body.nav-open .nav-group-menu a:hover { background: var(--primary-soft) }
}


/* ─── 7. Typography ─── */
.hero { padding: 82px 0 38px }
.grid-2 { display: grid; grid-template-columns: 1.08fr .92fr; gap: 30px; align-items: center }
.eyebrow {
  display: inline-flex;
  color: var(--primary);
  background: var(--primary-soft);
  border: 1px solid var(--line);
  padding: 8px 14px;
  border-radius: 999px;
  font-weight: 900;
}
.hero h1, .page-head h1 {
  font-size: clamp(36px, 5vw, 68px);
  line-height: 1.1;
  margin: 21px 0 16px;
  letter-spacing: -.035em;
}
.hero p, .page-head p {
  font-size: 19px;
  color: var(--muted);
  line-height: 1.95;
  max-width: 760px;
}
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px }
.centered { justify-content: center }
.page-head { padding: 56px 0 22px }


/* ─── 8. Buttons ─── */
.btn {
  border: 0;
  border-radius: var(--btn-radius);
  padding: 14px 21px;
  font-weight: 900;
  cursor: pointer;
  font-size: 16px;
  transition: .18s;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  line-height: 1.2;
  box-shadow: 0 10px 26px rgba(15,95,69,.07);
  position: relative;
  overflow: hidden;
}
.btn:hover  { transform: translateY(-1px) }
.btn:active { transform: translateY(0) scale(.99) }

.btn.primary {
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  color: #fff;
  box-shadow: 0 16px 36px rgba(15,95,69,.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn.ghost {
  background: rgba(255,255,255,.36);
  border: 1px solid var(--line);
  color: var(--text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.24), 0 10px 24px rgba(15,95,69,.055);
}
.btn.ghost:hover { background: var(--primary-soft); border-color: rgba(15,95,69,.24) }
[data-theme="dark"] .btn.ghost { background: rgba(255,255,255,.06) }

.btn.wide { width: 100%; margin-top: 14px }

.danger-btn {
  background: linear-gradient(135deg, #b94b4b, #7d2f2f) !important;
  color: #fff !important;
  border-color: rgba(185,75,75,.45) !important;
  box-shadow: none !important;
}

.compact-btn {
  min-height: 38px;
  padding: 9px 13px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1.2;
  box-shadow: 0 8px 18px rgba(15,95,69,.06);
}

@media (max-width: 560px) { .btn { min-height: 46px } }


/* ─── 9. Cards ─── */
.khatma-card, .feature-card, .form-card, .zakat-card, .khatma-detail, .unit, .dev-card {
  border: 1px solid var(--premium-border);
  background: var(--premium-wash);
}
.feature-card, .khatma-card, .unit {
  border-radius: 26px;
  padding: 22px;
  box-shadow: var(--shadow-soft);
  transition: .18s;
}
.feature-card:hover, .khatma-card:hover { transform: translateY(-2px) }
.feature-card span { color: var(--gold); font-size: 24px; font-weight: 900 }
.feature-card h3 { font-size: 22px }
.feature-card p, .khatma-card p { color: var(--muted); line-height: 1.85 }

.form-card, .zakat-card, .khatma-detail {
  border-radius: var(--radius);
  padding: 26px;
  margin-top: 16px;
  position: relative;
  overflow: hidden;
}
.hero-card {
  border-radius: var(--radius);
  padding: 32px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hero-card::before, .form-card::before, .zakat-card::before, .khatma-detail::before {
  content: "";
  position: absolute;
  inset: -1px auto auto -1px;
  width: 160px;
  height: 160px;
  background: radial-gradient(circle, var(--gold), transparent 68%);
  opacity: .14;
  pointer-events: none;
}

.khatma-card { display: flex; flex-direction: column; gap: 10px }
.card-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto }

/* Premium user card */
.premium-user-card { min-height: 0; gap: 14px; padding: 24px; overflow: hidden }
.user-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 4px;
}
.premium-user-card h3 { margin: 4px 0 2px; font-size: 22px; line-height: 1.5 }
.premium-user-card p  { margin: 0; color: var(--muted); font-weight: 800; direction: ltr; text-align: right }
@media (max-width: 560px) { .premium-user-card { padding: 20px } }

/* Action sheet */
.action-sheet {
  width: 100%;
  margin-top: 10px;
  border-radius: 22px;
  padding: 16px;
  background: linear-gradient(145deg, rgba(255,255,255,.48), rgba(201,154,62,.07));
  border-color: var(--premium-border);
}
[data-theme="dark"] .action-sheet {
  background: linear-gradient(145deg, rgba(255,255,255,.07), rgba(231,191,99,.045));
}
.sheet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.sheet-head h3, .sheet-head h4 { margin: 0; line-height: 1.45 }
.sheet-head span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--premium-border);
  border-radius: 999px;
  padding: 7px 11px;
  color: var(--primary);
  background: var(--primary-soft);
  font-weight: 900;
  font-size: 13px;
  white-space: nowrap;
}
@media (max-width: 560px) {
  .sheet-head { align-items: flex-start; flex-direction: column }
}

/* Feature grids */
.features, .cards-grid, .units-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 17px;
  margin-top: 28px;
}
@media (min-width: 821px) and (max-width: 1100px) {
  .features, .cards-grid { grid-template-columns: repeat(2, 1fr) }
  .units-grid { grid-template-columns: repeat(4, 1fr) }
  .grid-2 { grid-template-columns: 1fr }
  .hero-card { max-width: 680px; margin: auto }
}

/* Dev card */
.dev-card {
  border-radius: 26px;
  padding: 19px 21px;
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 38px;
  overflow: hidden;
  position: relative;
}
.dev-card::before {
  content: "";
  position: absolute;
  inset: auto -80px -110px auto;
  width: 230px;
  height: 230px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--gold), transparent 68%);
  opacity: .22;
}
.dev-orb {
  width: 54px;
  height: 54px;
  border-radius: 19px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--gold), var(--primary));
  color: #fff;
  font-size: 25px;
  flex: none;
  box-shadow: 0 14px 32px rgba(201,154,62,.18);
}
.dev-card p   { margin: 0; color: var(--muted); font-weight: 800 }
.dev-card h3  { margin: 3px 0; font-size: 20px }
.dev-card span { color: var(--primary); font-weight: 900 }


/* ─── 10. Forms ─── */
.form-grid, .zakat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px }
label { display: block; font-weight: 900; color: var(--text); margin: 10px 0 }
.inline-label { display: grid; gap: 8px; margin-top: 12px; color: var(--text); font-weight: 800 }

input, select, textarea {
  width: 100%;
  margin-top: 8px;
  border: 1px solid var(--premium-border);
  border-radius: 17px;
  padding: 13px 14px;
  background: rgba(255,255,255,.54);
  color: var(--text);
  font-size: 16px;
  outline: none;
  transition: .18s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
}
textarea { resize: vertical; line-height: 1.75 }
input:focus, select:focus, textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(15,95,69,.13);
}
select {
  background-color: var(--select-bg);
  border-color: var(--line);
  accent-color: var(--primary);
  cursor: pointer;
}
select option              { background-color: var(--option-bg); color: var(--option-text) }
select option:checked      { background-color: var(--primary2); color: #fff }
select option:hover        { background-color: var(--primary); color: #fff }
input::placeholder, textarea::placeholder { color: color-mix(in srgb, var(--muted) 78%, transparent) }

[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: #102a22;
  color: #f7f0df;
  border-color: rgba(231,191,99,.22);
}
[data-theme="dark"] select option { background: #102a22; color: #f7f0df }
[data-theme="dark"] select:focus  { border-color: #e7bf63; box-shadow: 0 0 0 4px rgba(231,191,99,.15) }
.admin-danger-card input   { border-color: rgba(185,75,75,.35) }

.full { grid-column: 1 / -1 }
.form-actions-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 18px }
.form-actions-row .btn { width: 100% }
.create-preview { margin-top: 16px }
.quote-meta-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 10px }
.whatsapp-field-group { display: grid; grid-template-columns: minmax(145px, .42fr) 1fr; gap: 12px; align-items: end }

/* Unit toolbar */
.unit-toolbar {
  border-radius: 24px;
  padding: 16px;
  margin: 24px 0 8px;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 14px;
  align-items: end;
  box-shadow: var(--shadow-soft);
}
.unit-toolbar label { margin: 0 }
.unit-toolbar input, .unit-toolbar select { height: 48px }
[data-theme="dark"] .unit-toolbar input,
[data-theme="dark"] .unit-toolbar select { background: #102a22; color: var(--text) }


/* ─── 11. Components ─── */
/* Badge */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 900;
  background: var(--primary-soft);
  color: var(--primary);
}
.badge.closed { background: rgba(157,63,63,.12); color: var(--danger) }
.badge.done   { background: rgba(15,95,69,.14);  color: var(--primary) }

/* Status dot */
.status-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(255,255,255,.22);
  border: 1px solid var(--line);
  font-size: 13px;
  font-weight: 900;
  color: var(--muted);
}
[data-theme="dark"] .status-dot { background: rgba(255,255,255,.06) }

/* Status line */
.status-line { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-top: 14px }
.empty-state  { grid-column: 1 / -1 }
.mobile-actions { display: none }

/* Countdown card */
.countdown-card {
  margin-top: 18px;
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: 18px;
  background: linear-gradient(135deg, rgba(201,154,62,.14), rgba(15,95,69,.08));
  box-shadow: var(--shadow-soft);
}
.countdown-card.warning { background: linear-gradient(135deg, rgba(231,191,99,.22), rgba(157,63,63,.08)); border-color: rgba(231,191,99,.33) }
.countdown-card.expired { background: linear-gradient(135deg, rgba(157,63,63,.16), rgba(201,154,62,.08)); border-color: rgba(157,63,63,.26) }
.countdown-card span   { display: block; color: var(--muted); font-weight: 900; margin-bottom: 5px }
.countdown-card strong { font-size: clamp(22px, 4vw, 34px); letter-spacing: -.02em }
.countdown-card small  { display: block; color: var(--muted); font-weight: 800; margin-top: 8px; line-height: 1.7 }

/* Toast */
.toast {
  position: fixed;
  left: 20px;
  bottom: 20px;
  background: var(--text);
  color: var(--bg);
  padding: 14px 18px;
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
  z-index: 99;
  font-weight: 900;
}

/* Modal */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0,0,0,.42);
  backdrop-filter: blur(10px);
}
.modal-card {
  width: min(520px, 100%);
  border: 1px solid var(--line);
  border-radius: 26px;
  background: var(--card-solid);
  box-shadow: var(--shadow);
  padding: 22px;
}
.modal-card h3    { margin: 0 0 8px }
.modal-card p     { color: var(--muted); line-height: 1.8 }
.modal-actions    { display: flex; gap: 10px; justify-content: flex-end; flex-wrap: wrap; margin-top: 14px }

/* Progress ring */
.progress-ring {
  margin: auto;
  width: 182px;
  height: 182px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: conic-gradient(var(--primary) var(--pct, 0%), rgba(201,154,62,.18) 0);
  position: relative;
  box-shadow: inset 0 0 0 1px var(--line), 0 18px 44px rgba(15,95,69,.13);
}
.progress-ring::after {
  content: "";
  position: absolute;
  inset: 16px;
  background: var(--card-solid);
  border-radius: 50%;
  border: 1px solid var(--line);
}
.progress-ring span { position: relative; z-index: 1; font-size: 34px; font-weight: 900; color: var(--primary) }

/* Mini stats */
.mini-stats, .result-boxes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 22px;
}
.mini-stats div, .result-boxes div {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 15px;
  background: rgba(255,255,255,.3);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .mini-stats div,
[data-theme="dark"] .result-boxes div { background: rgba(255,255,255,.05) }
.mini-stats strong, .result-boxes strong { display: block; font-size: 25px }
.mini-stats span,   .result-boxes span   { color: var(--muted); font-weight: 800 }

/* Message preview */
.message-preview {
  white-space: pre-wrap;
  line-height: 1.95;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 19px;
  background: rgba(255,255,255,.25);
  margin-top: 16px;
  color: var(--text);
}
[data-theme="dark"] .message-preview { background: rgba(255,255,255,.05) }

/* Inline panel */
.inline-panel {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 14px;
  margin-top: 12px;
  background: rgba(255,255,255,.24);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .inline-panel { background: rgba(255,255,255,.06) }
.inline-panel h4 { margin: 0 0 6px; font-size: 18px }
.inline-panel p  { margin: 0 0 10px; color: var(--muted); line-height: 1.8 }
.danger-inline {
  border-color: var(--danger-line);
  background: linear-gradient(145deg, var(--danger-soft), rgba(201,154,62,.045));
}

/* Signature */
.signature { text-align: center; color: var(--muted); font-weight: 800; margin-top: 20px }


/* ─── 12. Units ─── */
.unit {
  cursor: pointer;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
}
.unit:hover { transform: translateY(-2px) }
.unit.available  { border-color: rgba(15,95,69,.28) }
.unit.reserved   { background: rgba(201,154,62,.15) }
.unit.reading    { background: linear-gradient(135deg, rgba(201,154,62,.18), rgba(15,95,69,.10)); border-color: rgba(201,154,62,.28) }
.unit.completed  { background: rgba(15,95,69,.16) }
.unit small { display: block; color: var(--muted); margin-top: 2px; line-height: 1.6 }
.unit .btn  { padding: 10px 12px; border-radius: 14px; font-size: 14px }
.unit-inline {
  border-top: 1px solid var(--line);
  padding-top: 12px;
  margin-top: 4px;
  text-align: right;
}
.unit-inline input { margin-top: 0 }
.unit-actions { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 10px }
.unit-actions.two   { grid-template-columns: repeat(2, 1fr) }
.unit-actions.three { grid-template-columns: repeat(3, 1fr) }

/* Custom units picker */
.custom-units-picker {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 16px;
  background: rgba(255,255,255,.22);
  margin-top: 4px;
}
[data-theme="dark"] .custom-units-picker { background: rgba(255,255,255,.05) }
.custom-units-toolbar { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 10px 0 4px }
.custom-units-grid    { display: grid; gap: 8px; margin-top: 10px }
.unit-pick-label {
  display: flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 13px;
  padding: 9px 11px;
  cursor: pointer;
  background: rgba(255,255,255,.3);
  font-weight: 900;
  font-size: 13px;
  transition: .18s;
  user-select: none;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
}
[data-theme="dark"] .unit-pick-label { background: rgba(255,255,255,.06) }
.unit-pick-label:hover { background: var(--primary-soft); border-color: rgba(15,95,69,.24) }
.unit-pick-label:has(input:checked) { background: var(--primary-soft); border-color: rgba(15,95,69,.32); color: var(--primary) }
[data-theme="dark"] .unit-pick-label:has(input:checked) { background: rgba(91,209,154,.12); color: var(--primary) }
.unit-pick-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--primary); cursor: pointer; flex-shrink: 0; pointer-events: none }
.unit-pick-label.busy-unit { opacity: .65; cursor: default }
.unit-pick-label.busy-unit:hover { background: rgba(255,255,255,.3); border-color: var(--line) }
[data-theme="dark"] .unit-pick-label.busy-unit:hover { background: rgba(255,255,255,.06) }
.units-picker-note { margin: 8px 0 0; color: var(--muted); font-weight: 800; font-size: 13px; line-height: 1.6 }


/* ─── 13. Admin / Owner ─── */
.admin-note, .admin-panel {
  border: 1px solid rgba(201,154,62,.28);
  border-radius: 24px;
  padding: 16px;
  background: linear-gradient(135deg, rgba(201,154,62,.12), rgba(15,95,69,.06));
  color: var(--text);
  line-height: 1.9;
  margin-top: 14px;
}
.admin-note strong { color: var(--primary) }
.admin-panel {
  border: 1px solid var(--line);
  border-radius: 26px;
  padding: 18px;
  margin-top: 18px;
  background: rgba(255,255,255,.22);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .admin-panel { background: rgba(255,255,255,.05) }
.admin-panel h3 { margin: 0 0 8px }
.admin-panel p  { margin: 0 0 12px; color: var(--muted); line-height: 1.8 }
.admin-actions  { display: flex; gap: 9px; flex-wrap: wrap }
.premium-admin-panel { padding: 20px; border-radius: 28px; background: var(--premium-wash); border-color: var(--premium-border) }

.admin-code-card {
  display: grid;
  gap: 12px;
  margin: 12px 0;
  border: 1px solid var(--premium-border);
  border-radius: 22px;
  padding: 14px;
  background: rgba(255,255,255,.26);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .admin-code-card { background: rgba(255,255,255,.055) }
.admin-code-card span { color: var(--muted); font-weight: 900 }
.admin-code {
  font-weight: 900;
  color: var(--primary);
  letter-spacing: .08em;
}
.admin-code.status-dot {
  width: max-content;
  max-width: 100%;
  letter-spacing: 0;
  font-size: 14px;
  margin: 0;
  direction: rtl;
  text-align: right;
}

.share-link {
  direction: rtl;
  text-align: right;
  display: grid;
  gap: 4px;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.share-link strong { color: var(--primary) }
.share-link span {
  direction: ltr;
  text-align: left;
  word-break: break-all;
  color: var(--muted);
  font-weight: 800;
  background: rgba(255,255,255,.25);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 9px 10px;
}
[data-theme="dark"] .share-link span { background: rgba(255,255,255,.055) }

/* User card actions grids */
.user-card-actions, .tidy-admin-actions, .compact-actions {
  display: grid;
  gap: 10px;
  width: 100%;
  align-items: stretch;
}
.user-card-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 8px;
}
.premium-user-card .user-card-actions:has(.danger-btn) { grid-template-columns: 1fr 1fr 1fr }
.tidy-admin-actions {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 14px;
}
.compact-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}
.user-card-actions .btn,
.tidy-admin-actions .btn,
.compact-actions .btn {
  width: 100%;
  padding: 12px 14px;
  white-space: normal;
  text-align: center;
}
.user-card-actions .danger-btn,
.tidy-admin-actions .danger-btn {
  background: rgba(151,38,38,.10) !important;
  border-color: rgba(151,38,38,.25) !important;
  color: #972626 !important;
}
[data-theme="dark"] .user-card-actions .danger-btn,
[data-theme="dark"] .tidy-admin-actions .danger-btn {
  background: rgba(255,107,107,.10) !important;
  border-color: rgba(255,107,107,.28) !important;
  color: #ffb2b2 !important;
}

/* Khatma admin actions */
.khatma-admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  margin-top: 12px;
}
.khatma-admin-actions .btn  { width: auto; flex: 0 0 auto }
.khatma-share-actions        { gap: 9px; align-items: center }
.khatma-share-actions .btn   { width: auto }
.update-khatma-form          { margin-top: 14px; text-align: initial }
.update-khatma-form .form-grid { margin-top: 10px }
.update-khatma-form textarea   { min-height: 92px }

/* Inline admin access */
.inline-admin-access { margin-top: 18px; border: 1px solid rgba(203,169,90,.28); background: rgba(255,255,255,.08) }
.inline-label input {
  width: 100%;
  border: 1px solid rgba(203,169,90,.35);
  border-radius: 16px;
  padding: 13px 14px;
  background: var(--input-bg, rgba(255,255,255,.08));
  color: var(--text);
  outline: none;
}
.inline-label input:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(203,169,90,.16) }

/* Owner toolbar */
.owner-toolbar {
  margin-top: 16px;
  border-radius: 24px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  box-shadow: var(--shadow-soft);
}
.owner-toolbar h3 { margin: 0 0 4px; font-size: 20px }
.owner-toolbar p  { margin: 0; color: var(--muted); font-weight: 800; line-height: 1.7 }

.compact-owner-section .sheet-head { align-items: center; gap: 14px }
.compact-owner-section .sheet-head .compact-btn { margin-inline-start: auto; white-space: nowrap }
.invite-list-head { margin-top: 16px }

/* Owner row */
.owner-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border: 1px solid var(--premium-border, var(--line));
  border-radius: 22px;
  padding: 14px 16px;
  background: var(--premium-wash, var(--card));
  box-shadow: var(--shadow-soft);
}
.owner-row-main    { min-width: 0; display: grid; gap: 4px }
.owner-row-title   { font-size: 18px; line-height: 1.5; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap }
.owner-row-meta    { color: var(--muted); font-weight: 800; line-height: 1.6; overflow: hidden; text-overflow: ellipsis; white-space: nowrap }
.owner-row-actions { display: flex; align-items: center; justify-content: flex-end; gap: 8px; flex-wrap: wrap }
.owner-row .inline-panel { grid-column: 1 / -1; margin-top: 4px }

/* Invites */
.invite-list-head { margin-top: 22px; display: flex; align-items: flex-end; justify-content: space-between; gap: 12px }
.invite-list-head h3 { margin: 0 0 5px; font-size: 20px }
.invite-list-head p  { margin: 0; color: var(--muted); line-height: 1.7 }
.invite-list-grid    { margin-top: 14px }
.invite-card         { position: relative; overflow: hidden }
.invite-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 130px;
  height: 130px;
  background: radial-gradient(circle, rgba(231,191,99,.22), transparent 66%);
  pointer-events: none;
}
.invite-code-text {
  direction: ltr;
  text-align: center;
  letter-spacing: .08em;
  font-size: clamp(22px, 3vw, 30px);
  background: var(--primary-soft);
  border: 1px dashed rgba(15,95,69,.25);
  border-radius: 20px;
  padding: 16px;
  margin: 14px 0;
  color: var(--primary);
}
.invite-usage        { color: var(--muted); font-weight: 800; text-align: center }
.invite-usage strong { color: var(--text) }
.invite-actions      { grid-template-columns: 1fr 1fr 1fr }

/* Auth grid */
.auth-grid { display: grid; grid-template-columns: minmax(0, 520px); gap: 18px; align-items: start; justify-content: center }
.auth-grid .form-card { margin-top: 0 }
.owner-section-card   { margin-top: 24px }

/* Invite form */
.invite-form-grid { display: grid; grid-template-columns: 1fr 180px auto; gap: 12px; align-items: end }
.invite-form-grid label { margin: 0 }
.invite-form-grid .btn  { height: 50px }
.invites-grid.cards-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) }

/* User/invite lists override */
#usersList.cards-grid,
#invitesList.cards-grid { grid-template-columns: 1fr; gap: 12px }

/* Compact khatma admin */
.compact-khatma-admin { padding: 18px }

/* Coordinator contact */
.coordinator-contact-card {
  margin-top: 16px;
  border: 1px solid rgba(201,154,62,.28);
  border-radius: 24px;
  padding: 16px;
  background: linear-gradient(135deg, rgba(201,154,62,.13), rgba(15,95,69,.08));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.coordinator-contact-card strong { display: block; color: var(--primary); font-size: 18px }
.coordinator-contact-card p      { margin: 3px 0 0; color: var(--muted); font-weight: 900 }

/* Zakat */
.zakat-card    { max-width: 680px; margin-inline: auto }
.zakat-title   { text-align: center; font-size: 27px; font-weight: 900; margin-bottom: 22px }


/* ─── 14. Khatma Lists (v32 — JS generates these class names) ─── */
.khatma-rows-list-v32 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 18px;
}
.khatma-list-toolbar.v32 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 15px;
  border-radius: 24px;
  border: 1px solid var(--premium-border);
  background: linear-gradient(135deg, rgba(255,255,255,.62), rgba(255,250,240,.42));
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .khatma-list-toolbar.v32 {
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(231,191,99,.045));
}
.khatma-list-toolbar-title h3 { margin: 0; font-size: 18px; line-height: 1.35; color: var(--text) }
.khatma-list-toolbar-title p  { margin: 3px 0 0; font-size: 13px; color: var(--muted); font-weight: 800 }

.khatma-list-row.v32 {
  border-radius: 22px;
  padding: 11px 14px;
  border: 1px solid var(--premium-border);
  background: linear-gradient(135deg, rgba(255,255,255,.66), rgba(255,250,240,.38));
  box-shadow: 0 12px 30px rgba(15,95,69,.06);
  overflow: hidden;
}
[data-theme="dark"] .khatma-list-row.v32 {
  background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(231,191,99,.04));
}

.khatma-list-main.v32 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}
.khatma-list-content.v32 { min-width: 0; display: grid; gap: 7px }
.khatma-list-badges.v32  { display: flex; gap: 7px; align-items: center; flex-wrap: wrap }

.mini-pill.v32 {
  min-height: 28px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 900;
  color: var(--primary);
  background: var(--primary-soft);
  border: 1px solid var(--line);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.mini-pill.v32.closed { color: var(--danger);  background: rgba(157,63,63,.10) }
.mini-pill.v32.done   { color: var(--primary); background: rgba(15,95,69,.14) }

.khatma-list-titleline.v32 { min-width: 0; text-align: right }
.khatma-list-titleline.v32 h3 {
  margin: 0 0 3px;
  font-size: 18px;
  line-height: 1.35;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.khatma-list-titleline.v32 p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.khatma-list-side.v32 {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}
.khatma-list-progress.v32 {
  min-width: 122px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 8px 11px;
  background: rgba(255,255,255,.32);
  display: grid;
  place-items: center;
  text-align: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}
[data-theme="dark"] .khatma-list-progress.v32 { background: rgba(255,255,255,.055) }
.khatma-list-progress.v32 strong { font-size: 20px; line-height: 1; color: var(--primary); font-weight: 900 }
.khatma-list-progress.v32 span   { font-size: 11px; color: var(--muted); font-weight: 900; line-height: 1.35; white-space: nowrap }

.khatma-list-actions.v32, .icon-action-group.v32 {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 7px;
  flex-wrap: nowrap;
}

.mini-icon-btn.v32, .icon-action.v32 {
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 38px;
  border-radius: 15px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.42);
  color: var(--text);
  padding: 8px 12px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(15,95,69,.055);
  transition: .18s ease;
  text-decoration: none;
  line-height: 1;
}
[data-theme="dark"] .mini-icon-btn.v32,
[data-theme="dark"] .icon-action.v32 { background: rgba(255,255,255,.065) }
.mini-icon-btn.v32:hover,
.icon-action.v32:hover { transform: translateY(-1px); background: var(--primary-soft); color: var(--primary) }
.mini-icon-btn.primary.v32 { background: linear-gradient(135deg, var(--primary), var(--primary2)); color: #fff; border-color: rgba(231,191,99,.22) }
.mini-icon-btn.v32 span, .icon-action.v32 span   { font-size: 15px; line-height: 1; display: inline-flex }
.mini-icon-btn.v32 strong, .icon-action.v32 strong { font-size: 13px; line-height: 1; white-space: nowrap }

.khatma-tools-bar.v32 {
  margin: 16px 0 0;
  padding: 12px 0 0;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: flex-end;
}
.khatma-tools-bar.v32 .icon-action.v32 {
  background: linear-gradient(135deg, rgba(15,95,69,.10), rgba(201,154,62,.08));
  color: var(--primary);
}

/* Also preserve the non-v32 compact list classes used by older views */
.khatma-rows-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 20px;
}
.khatma-row-item {
  display: grid;
  grid-template-columns: 1fr 150px auto;
  gap: 14px;
  align-items: center;
  border-radius: 22px;
  padding: 14px 16px;
  box-shadow: var(--shadow-soft);
  background: var(--premium-wash);
  border: 1px solid var(--premium-border);
}
.khatma-row-info h3    { margin: 7px 0 3px; font-size: 20px; line-height: 1.45 }
.khatma-row-info p     { margin: 0; color: var(--muted); font-weight: 800; line-height: 1.5 }
.khatma-row-badges     { display: flex; gap: 7px; align-items: center; flex-wrap: wrap }
.soft-badge            { padding: 6px 10px; font-size: 13px }
.khatma-row-progress {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 10px 12px;
  text-align: center;
  background: rgba(255,255,255,.26);
  min-width: 140px;
}
.khatma-row-progress strong { display: block; color: var(--primary); font-size: 24px; line-height: 1 }
.khatma-row-progress span,
.khatma-row-progress small  { display: block; color: var(--muted); font-weight: 900; line-height: 1.5 }
.khatma-row-progress small  { font-size: 12px }
.khatma-row-actions         { display: flex; gap: 8px; align-items: center; justify-content: flex-end }
.khatma-row-actions .btn    { min-height: 42px; padding: 10px 15px; border-radius: 15px }


/* ─── 15. Managed Khatmas Table ─── */
.managed-table { display: grid; gap: 10px }
.managed-table-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr 150px 1fr auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--premium-border, var(--line));
  border-radius: 20px;
  padding: 12px;
  background: rgba(255,255,255,.24);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .managed-table-row { background: rgba(255,255,255,.055) }
.managed-table-row label { margin: 0 }
.managed-table-row .btn  { min-height: 48px }

.managed-assignments-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 10px;
  margin-top: 10px;
  max-height: 560px;
  overflow: auto;
  padding-inline-end: 4px;
}
.managed-assignment-item {
  margin: 0;
  border: 1px solid var(--premium-border, var(--line));
  border-radius: 18px;
  padding: 10px;
  background: rgba(255,255,255,.24);
  color: var(--text);
  box-shadow: var(--shadow-soft);
}
[data-theme="dark"] .managed-assignment-item { background: rgba(255,255,255,.055) }
.managed-assignment-item select { margin-top: 7px; min-height: 44px; border-radius: 14px }
.managed-assignment-title { display: block; margin-bottom: 8px; color: var(--primary); font-size: 13px }
.managed-assignment-options { display: grid; gap: 7px }
.managed-assignment-choice {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 7px 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,.22);
  font-size: 13px;
  line-height: 1.4;
}
[data-theme="dark"] .managed-assignment-choice { background: rgba(255,255,255,.045) }
.managed-assignment-choice input { width: auto; min-height: 0; margin: 0; accent-color: var(--primary) }
.managed-assignment-choice span { min-width: 0; display: grid; gap: 1px }
.managed-assignment-choice small,
.managed-assignment-empty { color: var(--muted); font-size: 11px; line-height: 1.4 }
/* ── Assignment Picker (compact chip + dropdown) ── */
.managed-assignment-options { overflow: visible; position: relative }
.managed-assignment-summary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  min-height: 30px;
}
.managed-assignment-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  flex: 1;
  min-width: 0;
  align-items: center;
}
.managed-assignment-chip {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--primary);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  max-width: 80px;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.5;
}
.managed-assignment-extra {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 20px;
  background: var(--line);
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.5;
}
.managed-assignment-open-btn {
  font-size: 11px !important;
  padding: 3px 9px !important;
  white-space: nowrap;
  flex-shrink: 0;
}
.managed-assignment-menu {
  margin-top: 8px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 8px;
  background: var(--glass-bg, rgba(255,255,255,.97));
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
  display: grid;
  gap: 6px;
}
[data-theme="dark"] .managed-assignment-menu { background: #1a1a2e }
.managed-assignment-search {
  width: 100%;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  font-size: 12px;
}
.managed-assignment-search:focus { outline: 2px solid var(--primary); outline-offset: -1px }
.managed-assignment-list {
  display: grid;
  gap: 4px;
  max-height: 180px;
  overflow-y: auto;
}
.managed-unit-reader-row {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 5px;
}
.managed-unit-reader-row span {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}
.managed-reader-action {
  min-height: 28px;
  padding: 3px 7px;
  border-radius: 10px;
  font-size: 11px;
}


/* ─── 16. Reports & Templates ─── */
.reports-grid       { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 16px }
.report-section     { margin-top: 0 }
.report-controls    { display: grid; grid-template-columns: minmax(260px, 1fr) auto auto; gap: 12px; align-items: end }
.report-controls label { margin: 0 }
.report-output      { margin-top: 14px }
.report-table-wrap  { overflow: auto; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.18) }
.report-table       { width: 100%; border-collapse: collapse; min-width: 680px }
.report-table th,
.report-table td    { padding: 10px 12px; border-bottom: 1px solid var(--line); text-align: right; vertical-align: top; font-size: 14px }
.report-table th    { color: var(--primary); background: var(--primary-soft); font-weight: 900; white-space: nowrap }
.empty-report       { margin: 0; color: var(--muted); font-weight: 800; line-height: 1.8 }

.template-modal-card  { width: min(760px, 100%) }
.template-save-row    { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: end; margin: 14px 0 }
.template-list        { display: grid; gap: 10px; max-height: 420px; overflow: auto; padding-inline-end: 2px }
.template-row         { border: 1px solid var(--line); border-radius: 18px; padding: 12px; background: rgba(255,255,255,.22) }


/* ─── Dashboard ─── */
.dash-search-section  { margin-top: 0 }
.dash-search-box      { margin-top: 10px }
.dash-search-input    {
  width: 100%; padding: 14px 18px; border-radius: 20px;
  border: 1px solid var(--line); background: var(--input-bg);
  font-size: 16px; font-weight: 800; color: var(--text); outline: none; transition: .18s;
}
.dash-search-input:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(15,95,69,.13) }
.search-results-wrap  { margin-top: 12px }
.search-results-header{ color: var(--muted); font-weight: 800; font-size: 13px; margin-bottom: 10px }
.search-result-item   {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--line); border-radius: 18px; padding: 12px 14px;
  background: var(--premium-wash); margin-bottom: 8px;
}
.search-result-badge  { padding: 5px 10px; border-radius: 999px; font-size: 12px; font-weight: 900; white-space: nowrap; flex: 0 0 auto }
.reader-badge         { background: var(--primary-soft); color: var(--primary) }
.participant-badge    { background: rgba(201,154,62,.15); color: var(--gold) }
.search-result-main   { flex: 1; min-width: 0 }
.search-result-main strong { display: block; font-size: 15px }
.search-result-meta   { display: block; color: var(--muted); font-size: 13px; font-weight: 800; white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.search-loading, .search-empty { padding: 14px; text-align: center; color: var(--muted); font-weight: 800 }
.search-error         { padding: 14px; text-align: center; color: var(--danger); font-weight: 800 }

.dash-summary-grid    { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: 16px }
.dash-stat-card       {
  border-radius: 22px; padding: 18px 16px;
  border: 1px solid var(--premium-border); background: var(--premium-wash); box-shadow: var(--shadow-soft);
}
.dash-stat-card .stat-icon  { font-size: 22px; margin-bottom: 8px }
.dash-stat-card .stat-value { font-size: 38px; font-weight: 900; color: var(--primary); line-height: 1 }
.dash-stat-card .stat-label { font-size: 14px; font-weight: 900; margin-top: 4px }
.dash-stat-card .stat-sub   { font-size: 12px; color: var(--muted); font-weight: 800; margin-top: 6px; line-height: 1.5 }

.dash-charts-row      { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 16px }
.dash-donut-wrap      { display: flex; align-items: center; gap: 20px; padding: 12px 0 4px }
.dash-donut-legend    { display: grid; gap: 10px; flex: 1; min-width: 0 }
.dash-legend-item     { display: flex; align-items: center; gap: 8px; font-weight: 800; font-size: 14px }
.dash-legend-dot      { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 auto }
.dash-legend-val      { margin-inline-start: auto; font-weight: 900; color: var(--text) }

.chart-bar-wrap       { margin-top: 14px; padding-bottom: 4px }
.chart-empty          { text-align: center; color: var(--muted); font-weight: 800; padding: 24px 0 }

.top-readers-list     { display: grid; gap: 12px; margin-top: 14px }
.top-reader-row       { display: flex; align-items: center; gap: 12px }
.top-reader-rank      {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--primary-soft); color: var(--primary);
  font-weight: 900; font-size: 14px; display: flex; align-items: center; justify-content: center; flex: 0 0 auto;
}
.top-reader-info      { flex: 1; min-width: 0 }
.top-reader-name      { font-weight: 900; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.top-reader-bar-wrap  { height: 6px; background: var(--primary-soft); border-radius: 999px; margin-top: 6px; overflow: hidden }
.top-reader-bar       { height: 100%; background: var(--primary); border-radius: 999px; transition: width .6s ease }
.top-reader-count     { font-weight: 900; color: var(--primary); font-size: 20px; white-space: nowrap; flex: 0 0 auto }
.top-reader-count span{ color: var(--muted); font-size: 12px; font-weight: 800 }

@media(max-width:1100px){ .dash-charts-row{ grid-template-columns:1fr 1fr } }
@media(max-width:820px){
  .dash-summary-grid  { grid-template-columns: 1fr 1fr }
  .dash-charts-row    { grid-template-columns: 1fr }
  .dash-donut-wrap    { flex-direction: column; align-items: flex-start }
  .search-result-item { flex-wrap: wrap }
  .search-result-meta { white-space: normal }
}
@media(max-width:480px){
  .dash-summary-grid  { grid-template-columns: 1fr 1fr }
  .dash-stat-card .stat-value { font-size: 30px }
}


/* ─── 17. Miscellaneous ─── */
#usersList.cards-grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); align-items: start }

.compact-khatma-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 22px;
}
.khatma-list-item {
  border-radius: 24px;
  padding: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px auto;
  gap: 14px;
  align-items: center;
  box-shadow: var(--shadow-soft);
}
.khatma-list-main h3 { margin: 9px 0 4px; font-size: 22px; line-height: 1.45 }
.khatma-list-main p  { margin: 0; color: var(--muted); font-weight: 800; line-height: 1.7 }
.khatma-list-progress {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 12px;
  text-align: center;
  background: rgba(255,255,255,.26);
}
[data-theme="dark"] .khatma-list-progress { background: rgba(255,255,255,.055) }
.khatma-list-progress strong { display: block; font-size: 28px; color: var(--primary); line-height: 1 }
.khatma-list-progress span,
.khatma-list-progress small  { display: block; color: var(--muted); font-weight: 900; line-height: 1.6 }
.khatma-list-progress small  { font-size: 12px }
.khatma-list-actions         { display: flex; gap: 8px; align-items: center; justify-content: flex-end; flex-wrap: wrap }

/* Mini pill (non-v32 variant) */
.mini-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 13px;
  line-height: 1.2;
  font-weight: 900;
  color: var(--primary);
  background: var(--primary-soft);
  border: 1px solid var(--line);
  white-space: nowrap;
}
.mini-pill.closed { color: var(--danger); background: rgba(157,63,63,.10) }
.mini-pill.done   { color: var(--primary); background: rgba(15,95,69,.12) }

/* Mini icon btn (non-v32 variant) */
.mini-icon-btn, .icon-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 36px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.36);
  color: var(--text);
  padding: 7px 10px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(15,95,69,.055);
  transition: .18s ease;
}
[data-theme="dark"] .mini-icon-btn,
[data-theme="dark"] .icon-action { background: rgba(255,255,255,.065) }
.mini-icon-btn:hover,
.icon-action:hover { transform: translateY(-1px); background: var(--primary-soft); color: var(--primary) }
.mini-icon-btn.primary { background: linear-gradient(135deg, var(--primary), var(--primary2)); color: #fff; border-color: rgba(231,191,99,.20) }
.mini-icon-btn span, .icon-action span   { font-size: 15px; line-height: 1 }
.mini-icon-btn strong, .icon-action strong { font-size: 13px; line-height: 1 }
.icon-action strong { white-space: nowrap }
.icon-action-group  { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; justify-content: flex-end }

.khatma-tools-bar {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: flex-end;
}
.khatma-tools-bar .icon-action {
  background: linear-gradient(135deg, rgba(15,95,69,.10), rgba(201,154,62,.08));
  color: var(--primary);
}

/* Khatma rows list (non-v32) */
.khatma-rows-list-v3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 18px;
}
.khatma-list-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-radius: 24px;
  padding: 14px 16px;
  box-shadow: var(--shadow-soft);
}
.khatma-list-toolbar h3 { margin: 0; font-size: 18px; color: var(--text) }
.khatma-list-toolbar p  { margin: 3px 0 0; color: var(--muted); font-weight: 800 }
.khatma-list-row {
  border-radius: 22px;
  padding: 10px 14px;
  box-shadow: var(--shadow-soft);
  background: linear-gradient(135deg, rgba(255,255,255,.58), rgba(255,250,240,.38));
  border-color: var(--premium-border);
}
[data-theme="dark"] .khatma-list-row {
  background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(231,191,99,.04));
}
.khatma-list-main {
  display: grid;
  grid-template-columns: minmax(170px, .95fr) minmax(260px, 1.5fr) minmax(120px, .55fr) auto;
  gap: 12px;
  align-items: center;
}
.khatma-list-badges   { display: flex; gap: 7px; flex-wrap: wrap; align-items: center }
.khatma-list-titleline { min-width: 0; text-align: right }
.khatma-list-titleline h3 {
  margin: 0 0 4px;
  font-size: 18px;
  line-height: 1.35;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.khatma-list-titleline p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
  font-size: 13px;
  line-height: 1.5;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


/* ─── 18. Print ─── */
@media print {
  .topbar, nav, .card-actions, .btn, .toast, .admin-panel,
  body::before, .dev-card, .theme-toggle, .menu-toggle,
  .unit-toolbar, .khatma-tools-bar, .modal-backdrop { display: none !important }
  body { background: white; color: black }
  .app-shell { width: 100%; padding: 0 }
  .glass, .form-card, .khatma-detail, .feature-card, .unit {
    box-shadow: none !important;
    background: white !important;
    border-color: #d5d5d5 !important;
  }
  .khatma-detail, .units-grid { break-inside: avoid }
}


/* ─── 19. Responsive (non-topbar) ─── */
@media (max-width: 820px) {
  .grid-2, .form-grid, .zakat-grid, .features, .cards-grid {
    grid-template-columns: 1fr;
  }
  .units-grid          { grid-template-columns: repeat(2, 1fr) }
  .hero                { padding-top: 44px }
  .hero h1, .page-head h1 { font-size: 39px }
  .mini-stats, .result-boxes { grid-template-columns: 1fr }
  .dev-card            { align-items: flex-start }
  .app-shell           { width: min(100% - 18px, 1180px) }
  .brand strong        { font-size: 16px }
  .brand-mark          { width: 45px; height: 45px }
  .form-actions-row, .unit-toolbar { grid-template-columns: 1fr }
  .unit-toolbar        { padding: 14px }
  .quote-meta-row, .whatsapp-field-group { grid-template-columns: 1fr }
  .auth-grid, .invite-form-grid { grid-template-columns: 1fr }
  .invite-form-grid .btn { width: 100% }
  .invite-list-head    { align-items: flex-start; flex-direction: column }
  .invite-actions      { grid-template-columns: 1fr }
  .owner-toolbar       { align-items: stretch; flex-direction: column; padding: 15px }
  .owner-toolbar .btn  { width: 100% }
  .compact-owner-section .sheet-head { align-items: stretch; flex-direction: column }
  .compact-owner-section .sheet-head .compact-btn { margin-inline-start: 0; width: 100% }
  .owner-row           { grid-template-columns: 1fr; gap: 10px; padding: 14px }
  .owner-row-actions   { justify-content: stretch; display: grid; grid-template-columns: 1fr 1fr; gap: 8px }
  .owner-row-actions .btn { width: 100% }
  .owner-row-title, .owner-row-meta { white-space: normal }
  .khatma-admin-actions { display: grid; grid-template-columns: 1fr 1fr }
  .khatma-admin-actions .btn { width: 100% }
  .khatma-share-actions { display: grid; grid-template-columns: 1fr 1fr }
  .khatma-share-actions .btn { width: 100% }
  .tidy-admin-actions  { grid-template-columns: repeat(2, minmax(0, 1fr)) }
  .premium-user-card .user-card-actions:has(.danger-btn) { grid-template-columns: 1fr 1fr }
  .khatma-list-item    { grid-template-columns: 1fr; align-items: stretch }
  .khatma-list-progress { text-align: right }
  .khatma-list-actions { justify-content: stretch }
  .khatma-list-actions .btn { flex: 1 1 0 }
  .coordinator-contact-card { display: grid; grid-template-columns: 1fr }
  .coordinator-contact-card .btn { width: 100% }
  .khatma-row-item     { grid-template-columns: 1fr; gap: 10px; padding: 14px }
  .khatma-row-progress { text-align: right }
  .khatma-row-actions  { justify-content: stretch }
  .khatma-row-actions .btn { flex: 1 1 0 }
  .managed-table-row   { grid-template-columns: 1fr 1fr }
  .managed-table-row .btn { grid-column: 1 / -1; width: 100% }
  .report-controls, .template-save-row { grid-template-columns: 1fr }
  .report-controls .btn, .template-save-row .btn { width: 100% }
  .khatma-list-main    { grid-template-columns: 1fr; gap: 9px }
  .khatma-list-badges, .khatma-list-actions, .icon-action-group { justify-content: flex-start }
  .khatma-list-progress { align-items: flex-start; width: 100%; padding: 8px 11px }
  .khatma-list-titleline h3, .khatma-list-titleline p { white-space: normal }
  .khatma-list-toolbar { align-items: flex-start; flex-direction: column }
  .khatma-list-main.v32 { grid-template-columns: 1fr; gap: 10px }
  .khatma-list-side.v32 { justify-content: space-between; width: 100% }
  .khatma-list-progress.v32 { min-width: 112px }
}

@media (max-width: 620px) {
  .khatma-list-toolbar.v32 { align-items: stretch; flex-direction: column; padding: 12px }
  .icon-action-group.v32   { display: grid; grid-template-columns: 1fr 1fr; width: 100%; gap: 8px }
  .khatma-list-row.v32     { border-radius: 20px; padding: 11px }
  .khatma-list-side.v32    { display: grid; grid-template-columns: 1fr; gap: 8px; align-items: stretch }
  .khatma-list-progress.v32 {
    width: 100%;
    min-width: 0;
    justify-items: start;
    text-align: right;
    padding: 9px 12px;
  }
  .khatma-list-progress.v32 span { white-space: normal; text-align: right }
  .khatma-list-actions.v32  { display: grid; grid-template-columns: 1fr 1fr; width: 100%; gap: 8px }
  .mini-icon-btn.v32, .icon-action.v32 { width: 100%; min-height: 42px; padding: 9px 10px }
  .khatma-list-titleline.v32 h3,
  .khatma-list-titleline.v32 p { white-space: normal }
  .khatma-tools-bar.v32    { justify-content: stretch }
  .managed-table-row       { grid-template-columns: 1fr }
  .managed-assignments-grid { grid-template-columns: 1fr; max-height: none }
}

@media (max-width: 560px) {
  .hero-actions .btn, .card-actions .btn, .admin-actions .btn { width: 100%; text-align: center }
  .unit-actions.two, .unit-actions.three { grid-template-columns: 1fr }
  .units-grid          { grid-template-columns: 1fr 1fr; gap: 10px }
  .unit                { padding: 16px 10px }
  .form-card, .zakat-card, .khatma-detail { padding: 18px; border-radius: 24px }
  .hero-card           { padding: 24px }
  .progress-ring       { width: 154px; height: 154px }
  .dev-card            { padding: 16px }
  .dev-orb             { width: 46px; height: 46px }
  .page-head           { padding: 34px 0 14px }
  .hero p, .page-head p { font-size: 17px }
  .user-card-actions, .premium-user-card .user-card-actions:has(.danger-btn),
  .tidy-admin-actions, .compact-actions { grid-template-columns: 1fr }
  .unit-pick-label     { font-size: 12px; padding: 8px 9px }
  .mini-icon-btn, .icon-action { flex: 1 1 auto; padding: 8px 9px }
  .khatma-list-actions, .icon-action-group { width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 7px }
  .khatma-list-toolbar .icon-action-group  { grid-template-columns: 1fr 1fr }
  .khatma-tools-bar .icon-action-group     { grid-template-columns: 1fr 1fr }
  .mini-pill           { font-size: 12px; padding-inline: 9px }
  .khatma-list-row     { padding: 10px; border-radius: 20px }
}

@media (max-width: 520px) {
  .khatma-list-toolbar .icon-action,
  .khatma-tools-bar .icon-action { min-height: 42px; font-size: 13px }
}

@media (max-width: 480px) {
  .owner-row-actions, .khatma-admin-actions, .khatma-share-actions { grid-template-columns: 1fr }
}


/* ─── 20. Keyframes ─── */
@keyframes menuDrop {
  from { opacity: 0; transform: translateY(-8px) }
  to   { opacity: 1; transform: translateY(0) }
}
