/* ==========================================================
   HIJAMA-V3 · SHELL  —  Layer 3 of 5
   Structural: announcement-bar, header, trust-bar, footer, drawer.
   Depends on: tokens.css + base.css
   Mobile-first · RTL-safe (logical properties)
   ========================================================== */

/* ═══════════════════════════════════════════════════════════
   APP SHELL
   ═══════════════════════════════════════════════════════════ */

.app-shell {
  display: grid;
  /* minmax(0, 1fr) prevents grid items from exceeding viewport width via
     their intrinsic max-content size. Without this, a wide child (like the
     marquee carousel's max-content track) blows up every sibling to
     match — hero content ends up rendered thousands of pixels off-screen
     even though overflow:hidden visually contains it.
     Canonical CSS Grid safety rail — always pair auto-grid with minmax(0,…).  */
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto auto auto 1fr auto;
  min-block-size: 100svh;
}

/* ═══════════════════════════════════════════════════════════
   ANNOUNCEMENT BAR (conditional, dismissible, not sticky)
   ═══════════════════════════════════════════════════════════ */

.ann-bar {
  background: var(--brand-strong);
  color: var(--brand-on);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  transition: max-height var(--dur-slow) var(--ease-out), opacity var(--dur-base) var(--ease-out);
  overflow: hidden;
  max-block-size: var(--ann-bar-h);
}
.ann-bar[hidden],
.ann-bar.is-dismissed {
  max-block-size: 0;
  opacity: 0;
}
.ann-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  min-block-size: var(--ann-bar-h);
  padding-inline: var(--sp-4);
  max-inline-size: var(--container);
  margin-inline: auto;
  position: relative;
}
.ann-bar__dot {
  inline-size: 6px; block-size: 6px; border-radius: 50%;
  background: var(--c-gold-500);
  box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.6);
  animation: ann-pulse 2.4s var(--ease-out) infinite;
  flex-shrink: 0;
}
@keyframes ann-pulse {
  0%, 100% { box-shadow: 0 0 0 0   rgba(245, 158, 11, 0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(245, 158, 11, 0);   }
}
.ann-bar__text { font-weight: var(--fw-medium); }
.ann-bar__close {
  position: absolute;
  inset-inline-end: var(--sp-2);
  inline-size: 28px; block-size: 28px;
  display: grid; place-items: center;
  border-radius: 50%;
  color: var(--brand-on);
  opacity: 0.7;
  transition: opacity var(--dur-fast), background var(--dur-fast);
}
.ann-bar__close:hover { opacity: 1; background: rgba(255,255,255,0.1); }

/* ═══════════════════════════════════════════════════════════
   HEADER · sticky, backdrop-blur, shrink-on-scroll
   ═══════════════════════════════════════════════════════════ */

.site-header {
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-header);
  background: color-mix(in oklab, var(--bg) 85%, transparent);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  backdrop-filter: saturate(180%) blur(14px);
  border-block-end: 1px solid transparent;
  transition:
    background var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
}
.site-header.is-scrolled {
  background: color-mix(in oklab, var(--bg) 96%, transparent);
  border-block-end-color: var(--border);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  min-block-size: var(--header-h-mobile);
}
@media (min-width: 768px) {
  .site-header__inner { min-block-size: var(--header-h); }
}

/* ─── Brand ────────────────────────────────────────────── */
.site-header__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--text);
  text-decoration: none;
  flex-shrink: 0;
}
.site-header__brand:hover { color: var(--text); }
.site-header__brand__mark {
  inline-size: 32px; block-size: 32px;
  color: var(--brand);
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .site-header__brand__mark { inline-size: 40px; block-size: 40px; }
}
.site-header__brand__text {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-tight);
  line-height: 1;
  color: var(--text);
}
.site-header__brand__text strong { color: var(--brand); font-weight: 700; }
.site-header__brand__text span   { font-weight: var(--fw-regular); opacity: 0.85; }

/* ─── Primary nav (desktop) ────────────────────────────── */
.site-nav { display: none; }
@media (min-width: 1024px) {
  .site-nav {
    display: block;
    flex: 1;
    margin-inline: var(--sp-6);
  }
}
.site-nav__list {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}
.site-nav__item { position: relative; }

.site-nav__trigger,
.site-nav__link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--text-soft);
  background: transparent;
  border-radius: var(--r-md);
  cursor: pointer;
  transition:
    color var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out);
  position: relative;
}
.site-nav__trigger:hover,
.site-nav__link:hover,
.site-nav__trigger[aria-expanded='true'] {
  color: var(--brand);
  background: var(--brand-weak);
}
/* Huidige pagina · sterk zichtbaar */
.site-nav__link[aria-current='page'],
.site-nav__link.is-active,
.site-nav__trigger.is-active-parent {
  color: var(--brand);
  font-weight: var(--fw-semi);
  background: var(--brand-weak);
}
.site-nav__link[aria-current='page']::before,
.site-nav__link.is-active::before,
.site-nav__trigger.is-active-parent::before {
  content: '';
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: var(--sp-3);
  inset-inline-end: var(--sp-3);
  block-size: 3px;
  background: var(--brand);
  border-radius: 2px 2px 0 0;
}
/* Active in drawer (mobile) */
.drawer__link[aria-current='page'],
.drawer__link.is-active,
.drawer__group-items a.is-active {
  color: var(--brand);
  font-weight: var(--fw-semi);
  background: var(--brand-weak);
  border-inline-start: 3px solid var(--brand);
}
.site-nav__chevron {
  inline-size: 14px; block-size: 14px;
  transition: transform var(--dur-fast) var(--ease-out), opacity var(--dur-fast);
  color: currentColor;
  opacity: 1;                           /* ALTIJD zichtbaar */
  stroke-width: 3;                      /* Dikker voor duidelijkheid */
  margin-inline-start: 4px;
}
.site-nav__trigger:hover .site-nav__chevron,
.site-nav__link:hover + .site-nav__chevron {
  opacity: 1;
  animation: chevron-bob 0.6s ease-in-out;
}
.site-nav__trigger[aria-expanded='true'] .site-nav__chevron {
  transform: rotate(180deg);
  opacity: 1;
}
@keyframes chevron-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(2px); }
}
/* Subtiele onderlijn bij hover — duidelijker dropdown-signaal */
.site-nav__trigger::after {
  content: '';
  position: absolute;
  inset-block-end: 4px;
  inset-inline-start: var(--sp-3);
  inset-inline-end: var(--sp-3);
  block-size: 2px;
  background: var(--brand);
  border-radius: 1px;
  opacity: 0;
  transform: scaleX(0);
  transition: opacity var(--dur-fast), transform var(--dur-fast);
}
.site-nav__trigger:hover::after,
.site-nav__trigger[aria-expanded='true']::after {
  opacity: 1;
  transform: scaleX(1);
}

/* ─── Mega-menu (Behandelingen) ────────────────────────── */
.mega-menu {
  position: absolute;
  inset-block-start: calc(100% + 8px);
  inset-inline-start: 0;
  inline-size: 720px;
  max-inline-size: calc(100vw - var(--sp-8));
  padding: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition:
    opacity var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
  z-index: var(--z-drawer);
}
.mega-menu--pillars { inline-size: 920px; }
.mega-menu__pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
}
.mega-pillar h4 {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--brand);
  margin-block-end: var(--sp-2);
  padding-block-end: var(--sp-2);
  border-block-end: 1px solid var(--border);
}
.mega-menu[hidden] { display: none; }
.site-nav__item[data-open='true'] .mega-menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.mega-menu__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-2);
}
.mega-menu__footer {
  margin-block-start: var(--sp-4);
  padding-block-start: var(--sp-4);
  border-block-start: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--text-sm);
}
.mega-menu__footer a {
  color: var(--brand);
  font-weight: var(--fw-semi);
}

.nav-card {
  display: block;
  padding: var(--sp-3);
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--text);
  transition:
    background var(--dur-fast) var(--ease-out),
    transform var(--dur-fast) var(--ease-out);
}
.nav-card:hover {
  background: var(--brand-weak);
  color: var(--brand);
  transform: translateY(-1px);
}
.nav-card__label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--fw-semi);
  color: var(--text);
}
.nav-card:hover .nav-card__label { color: var(--brand); }
.nav-card__lead {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-dim);
  margin-block-start: 2px;
}

/* ─── Simple dropdown (Kennisbank) ─────────────────────── */
.dropdown {
  position: absolute;
  inset-block-start: calc(100% + 8px);
  inset-inline-start: 0;
  min-inline-size: 280px;
  padding: var(--sp-2);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition:
    opacity var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
  z-index: var(--z-drawer);
}
.dropdown[hidden] { display: none; }
.site-nav__item[data-open='true'] .dropdown {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.dropdown__item {
  display: block;
  padding: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--text);
  border-radius: var(--r-sm);
  text-decoration: none;
}
.dropdown__item:hover {
  background: var(--brand-weak);
  color: var(--brand);
}
.dropdown__item-title { display: block; font-weight: var(--fw-semi); }
.dropdown__item-lead  { display: block; font-size: var(--text-xs); color: var(--text-dim); margin-block-start: 2px; }

/* ─── Wide dropdown: 3-column (Kennisbank-uitbreiding) ─── */
.dropdown--wide {
  min-inline-size: 720px;
  inset-inline-start: auto;
  inset-inline-end: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-3);
  padding: var(--sp-4);
}
.dropdown__col { display: flex; flex-direction: column; gap: 2px; }
.dropdown__label {
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--text-dim);
  font-weight: var(--fw-semi);
  padding: 0 var(--sp-3);
  margin-block-end: var(--sp-2);
}
.dropdown--wide .dropdown__item { padding: var(--sp-2) var(--sp-3); }

@media (max-width: 1280px) {
  .dropdown--wide { min-inline-size: 560px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ─── Utility cluster (right side) ─────────────────────── */
.site-header__utility {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}

.icon-btn {
  inline-size: 40px; block-size: 40px;
  display: inline-grid; place-items: center;
  border-radius: var(--r-md);
  color: var(--text-soft);
  background: transparent;
  transition:
    color var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out);
}
.icon-btn:hover {
  color: var(--brand);
  background: var(--brand-weak);
}
.icon-btn svg { inline-size: 20px; block-size: 20px; }

.mobile-only  { display: inline-grid; }
.desktop-only { display: none; }
@media (min-width: 1024px) {
  .mobile-only  { display: none; }
  .desktop-only { display: inline-grid; }
}

/* ─── Primary CTA (header book) ────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  min-block-size: 44px;
  border-radius: var(--r-pill);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-wide);
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  transition:
    transform var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out);
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.btn:active { transform: scale(0.97); }
.btn svg { inline-size: 1em; block-size: 1em; flex-shrink: 0; }

.btn-primary {
  background: var(--brand);
  color: var(--brand-on);
  box-shadow: var(--shadow-md);
}
.btn-primary:hover {
  background: var(--brand-hover);
  color: var(--brand-on);
  box-shadow: var(--shadow-lg);
}
.btn-ghost {
  background: transparent;
  color: var(--text);
  border: 1.5px solid var(--border-strong);
}
.btn-ghost:hover { border-color: var(--brand); color: var(--brand); }
.btn-sm { padding: var(--sp-2) var(--sp-4); min-block-size: 40px; font-size: var(--text-sm); }
.btn-lg { padding: var(--sp-4) var(--sp-6); min-block-size: 56px; font-size: var(--text-md); }
.btn-block { inline-size: 100%; }

/* ═══════════════════════════════════════════════════════════
   TRUST BAR (below header, scrollable overflow on mobile)
   ═══════════════════════════════════════════════════════════ */

.trust-bar {
  background: linear-gradient(90deg, var(--bg-soft) 0%, var(--bg-muted) 50%, var(--bg-soft) 100%);
  border-block-end: 1px solid var(--border);
  font-size: var(--text-xs);
  color: var(--text-dim);
  overflow: hidden;
  position: relative;
}
/* Fade-edges voor seamless marquee */
.trust-bar::before,
.trust-bar::after {
  content: '';
  position: absolute;
  inset-block: 0;
  inline-size: 60px;
  z-index: 2;
  pointer-events: none;
}
.trust-bar::before { inset-inline-start: 0; background: linear-gradient(90deg, var(--bg-soft), transparent); }
.trust-bar::after  { inset-inline-end: 0;   background: linear-gradient(-90deg, var(--bg-soft), transparent); }

.trust-bar__marquee {
  overflow: hidden;
  min-block-size: var(--trust-bar-h);
  display: flex;
  align-items: center;
}
.trust-bar__track {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-4);
  white-space: nowrap;
  animation: trust-marquee 45s linear infinite;
  padding-inline-start: var(--sp-5);
}
.trust-bar:hover .trust-bar__track {
  animation-play-state: paused;
}
@keyframes trust-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.trust-bar__item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  letter-spacing: var(--tracking-wide);
  flex-shrink: 0;
  font-weight: var(--fw-medium);
}
.trust-bar__item svg {
  inline-size: 14px; block-size: 14px;
  color: var(--success);
  flex-shrink: 0;
}
.trust-bar__item--date svg,
.trust-bar__item--clock svg { color: var(--brand); }
.trust-bar__item--hijri svg,
.trust-bar__item--sunnah svg { color: var(--accent); }
.trust-bar__item--prayer svg { color: var(--c-gold-500); }

.trust-bar__sep {
  color: var(--brand);
  opacity: 0.4;
  font-size: 8px;
  flex-shrink: 0;
}

/* Pulse animatie op next-prayer om aandacht te trekken */
.trust-bar__item--prayer {
  animation: prayer-pulse 3s ease-in-out infinite;
}
@keyframes prayer-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.7; }
}

/* ═══════════════════════════════════════════════════════════
   MOBILE DRAWER
   ═══════════════════════════════════════════════════════════ */

.drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-drawer);
  visibility: hidden;
  pointer-events: none;
}
.drawer[aria-hidden='false'] {
  visibility: visible;
  pointer-events: auto;
}

.drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.5);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
}
.drawer[aria-hidden='false'] .drawer__backdrop { opacity: 1; }

.drawer__panel {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 0;
  inline-size: min(420px, 88vw);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--dur-slow) var(--ease-out-expo);
  box-shadow: var(--shadow-2xl);
}
html[dir='rtl'] .drawer__panel {
  inset-inline-end: auto;
  inset-inline-start: 0;
  transform: translateX(-100%);
}
.drawer[aria-hidden='false'] .drawer__panel { transform: translateX(0); }

.drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-5);
  border-block-end: 1px solid var(--border);
  min-block-size: var(--header-h-mobile);
  flex-shrink: 0;
}
.drawer__brand {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  color: var(--text);
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
}
.drawer__brand strong { color: var(--brand); }

.drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-3) var(--sp-5);
  overscroll-behavior: contain;
}

.drawer__nav {
  display: flex;
  flex-direction: column;
}
.drawer__link,
.drawer__group > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-2);
  border-block-end: 1px solid var(--border);
  font-size: var(--text-md);
  font-weight: var(--fw-medium);
  color: var(--text);
  text-decoration: none;
  cursor: pointer;
  list-style: none;
}
.drawer__link[aria-current='page'] {
  color: var(--brand);
  font-weight: var(--fw-semi);
}
.drawer__group > summary::-webkit-details-marker { display: none; }
.drawer__group > summary::after {
  content: '';
  inline-size: 10px; block-size: 10px;
  border-inline-end: 2px solid var(--text-dim);
  border-block-end: 2px solid var(--text-dim);
  transform: rotate(45deg);
  transition: transform var(--dur-base) var(--ease-out);
  margin-inline-end: var(--sp-2);
}
.drawer__group[open] > summary::after {
  transform: rotate(-135deg);
}
.drawer__group-items {
  display: flex;
  flex-direction: column;
  padding-inline-start: var(--sp-4);
  padding-block: var(--sp-2);
}
.drawer__group-items a {
  display: block;
  padding: var(--sp-3) var(--sp-2);
  font-size: var(--text-sm);
  color: var(--text-soft);
  text-decoration: none;
  border-radius: var(--r-sm);
  transition: color var(--dur-fast), background var(--dur-fast);
}
.drawer__group-items a:hover {
  color: var(--brand);
  background: var(--brand-weak);
}

.drawer__footer {
  padding: var(--sp-4) var(--sp-5);
  border-block-start: 1px solid var(--border);
  background: var(--bg-soft);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  flex-shrink: 0;
}
.drawer__utility {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.drawer__utility button {
  padding: var(--sp-1) var(--sp-3);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-pill);
  color: var(--text-soft);
  font-size: var(--text-xs);
  cursor: pointer;
}
.drawer__utility button[aria-current='true'] {
  background: var(--brand);
  color: var(--brand-on);
  border-color: var(--brand);
}

.drawer__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  background: var(--brand);
  color: var(--brand-on);
  font-weight: var(--fw-semi);
  text-decoration: none;
  min-block-size: 56px;
  flex-shrink: 0;
  box-shadow: 0 -4px 12px rgba(30, 64, 175, 0.1);
}

/* Body-scroll-lock when drawer open */
html.drawer-open,
html.drawer-open body {
  overflow: hidden;
  overscroll-behavior: contain;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */

.site-footer {
  margin-block-start: var(--sp-24);
  background: var(--bg-soft);
  border-block-start: 1px solid var(--border);
  color: var(--text-soft);
}

/* ─── Newsletter band ──────────────────────────────────── */
.site-footer__newsletter {
  padding-block: var(--sp-10);
  background: linear-gradient(135deg, var(--bg-muted) 0%, var(--bg-soft) 100%);
  border-block-end: 1px solid var(--border);
}
.site-footer__newsletter-inner {
  display: grid;
  gap: var(--sp-5);
  align-items: center;
}
@media (min-width: 768px) {
  .site-footer__newsletter-inner {
    grid-template-columns: 1fr auto;
    gap: var(--sp-8);
  }
}
.site-footer__newsletter h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--text);
  letter-spacing: var(--tracking-tight);
}
.site-footer__newsletter p {
  font-size: var(--text-sm);
  color: var(--text-soft);
  margin-block-start: var(--sp-1);
}
.newsletter-form {
  display: flex;
  gap: var(--sp-2);
  min-inline-size: min(100%, 360px);
}
.newsletter-form input {
  flex: 1;
  padding: var(--sp-3) var(--sp-4);
  min-block-size: 48px;
  font-size: 16px;
  background: var(--surface);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-md);
  color: var(--text);
}
.newsletter-form input:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px var(--brand-weak);
}
.newsletter-form button {
  inline-size: 48px; block-size: 48px;
  display: inline-grid; place-items: center;
  background: var(--brand);
  color: var(--brand-on);
  border-radius: var(--r-md);
  transition: background var(--dur-fast);
}
.newsletter-form button:hover { background: var(--brand-hover); }

/* ─── Footer main grid ─────────────────────────────────── */
.site-footer__main {
  padding-block: var(--sp-12);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}
@media (min-width: 640px) {
  .site-footer__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .site-footer__grid {
    grid-template-columns: 1.4fr repeat(4, 1fr);
    gap: var(--sp-10);
  }
}

.site-footer__col__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-dim);
  margin-block-end: var(--sp-4);
}
.site-footer__col ul {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.site-footer__col a {
  font-size: var(--text-sm);
  color: var(--text-soft);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.site-footer__col a:hover { color: var(--brand); }

/* Brand column */
.site-footer__brand-col {
  grid-column: 1 / -1;
}
@media (min-width: 1024px) {
  .site-footer__brand-col { grid-column: span 1; }
}
.site-footer__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--text);
  text-decoration: none;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--text-md);
  letter-spacing: var(--tracking-tight);
}
.site-footer__brand strong { color: var(--brand); }
.site-footer__tagline {
  font-size: var(--text-sm);
  color: var(--text-soft);
  line-height: var(--leading-body);
  max-inline-size: 32ch;
  margin-block-start: var(--sp-3);
}
.site-footer__nap {
  margin-block-start: var(--sp-4);
  font-size: var(--text-sm);
  color: var(--text-soft);
  line-height: 1.5;
}
.site-footer__nap dt {
  font-size: var(--text-xs);
  color: var(--text-dim);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-block-start: var(--sp-3);
}
.site-footer__nap dt:first-child { margin-block-start: 0; }
.site-footer__socials {
  display: flex;
  gap: var(--sp-2);
  margin-block-start: var(--sp-5);
}
.site-footer__social {
  inline-size: 40px; block-size: 40px;
  display: inline-grid; place-items: center;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--text-soft);
  transition:
    color var(--dur-fast),
    border-color var(--dur-fast),
    transform var(--dur-fast);
}
.site-footer__social:hover {
  color: var(--brand);
  border-color: var(--brand);
  transform: translateY(-2px);
}
.site-footer__social svg { inline-size: 18px; block-size: 18px; }

/* ─── Trust row (certifications) ───────────────────────── */
.site-footer__trust {
  padding-block: var(--sp-5);
  border-block: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-6);
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.site-footer__trust-item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  opacity: 0.8;
  transition: opacity var(--dur-fast);
}
.site-footer__trust-item:hover { opacity: 1; }
.site-footer__trust-item svg {
  inline-size: 14px; block-size: 14px;
  color: var(--brand);
}

/* ─── Bottom strip ─────────────────────────────────────── */
.site-footer__bottom {
  padding-block: var(--sp-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  justify-content: space-between;
  align-items: center;
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.site-footer__legal {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.site-footer__legal a {
  color: var(--text-dim);
  font-size: var(--text-xs);
  text-decoration: none;
}
.site-footer__legal a:hover { color: var(--brand); }

.site-footer__controls {
  display: flex;
  gap: var(--sp-4);
  align-items: center;
  flex-wrap: wrap;
}

/* Segmented theme toggle (3-way) */
.theme-toggle {
  display: inline-flex;
  padding: 3px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  gap: 2px;
}
.theme-toggle button {
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--text-xs);
  color: var(--text-soft);
  border-radius: var(--r-pill);
  transition:
    background var(--dur-fast),
    color var(--dur-fast);
  min-block-size: 28px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.theme-toggle button[aria-pressed='true'] {
  background: var(--brand);
  color: var(--brand-on);
}
.theme-toggle button svg {
  inline-size: 12px; block-size: 12px;
}

/* Inline language toggle */
.lang-toggle {
  display: inline-flex;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  color: var(--text-dim);
}
.lang-toggle button {
  color: var(--text-dim);
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-sm);
  transition: color var(--dur-fast);
}
.lang-toggle button[aria-pressed='true'] { color: var(--brand); }

/* ─── Bismillah band ───────────────────────────────────── */
.site-footer__bismillah {
  padding-block: var(--sp-5);
  background: var(--c-ink-900);
  color: rgba(255, 255, 255, 0.5);
  text-align: center;
  font-family: var(--font-arabic);
  font-size: var(--text-md);
  letter-spacing: 0;
}
[data-theme='dark'] .site-footer__bismillah { background: var(--c-ink-950); }
