/* =====================================================
   Bayut Ajmal — Components: top strip, header, dropdowns, overlay, buttons, cards, forms, footer
   ===================================================== */

/* ---------- Top utility strip ---------- */
.top-strip {
  position: fixed;
  inset-inline: 0;
  top: 0;
  z-index: var(--z-strip);
  height: var(--top-strip-h);
  background:
    radial-gradient(circle at 1px 1px, rgba(250,246,238,.075) 1px, transparent 1.4px),
    linear-gradient(135deg, rgba(193,139,98,.1) 0 1px, transparent 1px 18px),
    linear-gradient(45deg, rgba(250,246,238,.045) 0 1px, transparent 1px 18px),
    linear-gradient(90deg, rgba(193,139,98,.18), transparent 24%, transparent 72%, rgba(91,96,72,.16)),
    #100f0c;
  background-size: 18px 18px, 36px 36px, 36px 36px, 100% 100%, auto;
  background-position: 0 0, 0 0, 18px 18px, 0 0, 0 0;
  color: rgba(250,246,238,.82);
  font-size: 0.78rem;
  letter-spacing: 0;
  border-block-end: 1px solid rgba(250,246,238,.1);
  transition: transform var(--t-base) var(--ease-out);
  overflow: hidden;
}
.top-strip::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 72px),
    linear-gradient(180deg, rgba(250,246,238,.08), transparent 42%, rgba(0,0,0,.18));
  opacity: .8;
}
.top-strip.is-hidden { transform: translateY(-100%); }
.top-strip__inner {
  position: relative;
  z-index: 1;
  max-width: none;
  margin-inline: auto;
  height: 100%;
  padding-inline: clamp(32px, 4vw, 76px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(16px, 3vw, 44px);
  direction: ltr;
}
.top-strip__status {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: rgba(250,246,238,.78);
  font-size: .75rem;
  font-weight: 600;
  white-space: nowrap;
  direction: rtl;
  order: 4;
}
.ts-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #54d68a;
  box-shadow: 0 0 0 5px rgba(84,214,138,.12), 0 0 18px rgba(84,214,138,.45);
}
.top-strip__contact,
.top-strip__meta,
.top-strip__right {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.top-strip__meta {
  justify-content: flex-end;
  min-width: 0;
  color: rgba(250,246,238,.58);
  direction: rtl;
  order: 3;
}
.top-strip__contact {
  justify-content: flex-start;
  direction: ltr;
  order: 1;
}
.top-strip__right {
  justify-content: flex-end;
  gap: var(--sp-3);
  display: flex;
  order: 2;
}
.ts-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: inherit;
  white-space: nowrap;
  transition: color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out);
}
.ts-link--phone,
.ts-link--email {
  min-height: 26px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(250,246,238,.88);
  font-weight: 600;
}
.ts-link--phone:hover,
.ts-link--email:hover {
  background: transparent;
  border-color: transparent;
}
.ts-link--location {
  max-width: min(48vw, 620px);
  overflow: hidden;
  text-overflow: ellipsis;
}
.ts-link--location span {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ts-link svg, .ts-link i {
  width: 14px;
  min-width: 14px;
  height: 14px;
  display: inline-grid;
  place-items: center;
  font-size: 12px;
  color: var(--c-clay);
}
.ts-link:hover { color: var(--c-cream); }
.top-socials {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.top-socials:empty { display: none; }
.top-socials a {
  width: 26px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: rgba(250,246,238,.76);
  border: 0;
  background: transparent;
  transition: color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.top-socials a:hover {
  color: var(--c-cream);
  background: transparent;
  border-color: transparent;
  transform: translateY(-1px);
}
.top-socials i { font-size: 12px; }
.u-ltr {
  direction: ltr;
  unicode-bidi: isolate;
  font-variant-numeric: tabular-nums;
}
.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  min-height: 28px;
  padding: 3px;
  border: 1px solid rgba(250,246,238,.14);
  border-radius: var(--radius-pill);
  background: rgba(250,246,238,.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 28px rgba(0,0,0,.16);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  direction: ltr;
}
.lang-switch__icon {
  width: 22px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: var(--c-clay);
  background: rgba(250,246,238,.08);
}
.lang-switch__icon i {
  font-size: 11px;
}
.lang-switch a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 22px;
  padding-inline: 10px;
  border-radius: var(--radius-pill);
  font-weight: 800;
  font-size: 0.68rem;
  letter-spacing: 0;
  line-height: 1;
  color: rgba(250,246,238,.72);
  transition: color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.lang-switch a:hover {
  color: var(--c-cream);
  background: rgba(250,246,238,.08);
}
.lang-switch a.is-active {
  background: var(--c-clay);
  color: #14130f;
  box-shadow: 0 8px 18px rgba(193,139,98,.24);
}
.lang-switch a:focus-visible {
  outline: 2px solid rgba(250,246,238,.72);
  outline-offset: 2px;
}
@media (max-width: 1180px) {
  .top-strip__status { display: none; }
  .top-strip__meta { justify-content: flex-end; }
  .top-strip__contact { justify-content: flex-start; }
}
@media (max-width: 900px) {
  .top-strip__meta { display: none; }
  .top-strip__inner { gap: 12px; padding-inline: var(--gutter); }
}
@media (max-width: 768px) {
  :root { --top-strip-h: 36px; }
  .top-strip { display: block; }
  .top-strip__inner {
    justify-content: center;
    padding-inline: 12px;
  }
  .top-strip__contact,
  .top-socials {
    display: none;
  }
  .top-strip__right {
    width: 100%;
    justify-content: center;
  }
  .lang-switch {
    min-height: 28px;
    background: rgba(250,246,238,.1);
  }
  .lang-switch a {
    min-width: 46px;
  }
}

/* ---------- Site header ---------- */
.site-header {
  position: fixed;
  inset-inline: 0;
  top: var(--top-strip-h);
  z-index: var(--z-nav);
  height: var(--header-h);
  display: flex; align-items: center;
  background: transparent;
  transition:
    background var(--t-base) var(--ease-out),
    box-shadow var(--t-base) var(--ease-out),
    border-color var(--t-base) var(--ease-out);
}
.site-header::before {
  content: ""; position: absolute; inset: 0;
  background: rgba(250, 246, 238, 0.95);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-block-end: 1px solid var(--c-line-soft);
  transition: background var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
  z-index: -1;
}
/* On the front page, header sits over a dark hero — use translucent dark glass until scroll */
.site-header.is-light::before {
  background: rgba(20, 19, 15, 0.55);
  border-block-end-color: rgba(250, 246, 238, 0.1);
}
.site-header.is-scrolled { box-shadow: 0 4px 24px -12px rgba(20, 19, 15, 0.18); }
.site-header.is-scrolled::before {
  background: rgba(250, 246, 238, 0.95);
  border-block-end-color: var(--c-line-soft);
}

.site-header .nav-link,
.site-header .menu-toggle { color: var(--c-ink); }
.site-header.is-light .nav-link,
.site-header.is-light .menu-toggle { color: var(--c-cream); }
.site-header.is-scrolled .nav-link,
.site-header.is-scrolled .menu-toggle { color: var(--c-ink); }

.header-inner {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(180px, auto) minmax(0, 1fr) minmax(160px, auto);
  align-items: center;
  gap: clamp(14px, 2vw, 34px);
  max-width: none;
  margin-inline: auto;
  padding-inline: clamp(24px, 3vw, 58px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  font-weight: 700;
  position: relative;
}
.brand-logo {
  display: block;
  height: clamp(46px, 5.4vw, 62px);
  width: auto;
  max-width: 240px;
  object-fit: contain;
  transition: opacity var(--t-base) var(--ease-out);
}
.brand-logo--light { display: none; }
.brand-logo--dark  { display: block; }
.site-header.is-light .brand-logo--light { display: block; }
.site-header.is-light .brand-logo--dark  { display: none; }
.site-header.is-scrolled .brand-logo--light { display: none; }
.site-header.is-scrolled .brand-logo--dark  { display: block; }
@media (max-width: 768px) {
  .brand-logo { height: 44px; }
}

/* ---------- Primary nav (desktop dropdowns) ---------- */
.primary-nav { display: flex; justify-content: center; min-width: 0; }
.primary-menu {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.45vw, 28px);
  list-style: none;
  margin: 0; padding: 0;
}
.primary-menu > li { position: relative; }
.primary-menu .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 14px 3px;
  font-size: clamp(0.82rem, .74rem + .18vw, .94rem);
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.1;
  white-space: nowrap;
  color: var(--c-ink);
  position: relative;
  transition: color var(--t-fast) var(--ease-out);
}
html[lang^="en"] .primary-menu {
  gap: clamp(10px, 1.2vw, 22px);
}
html[lang^="en"] .primary-menu .nav-link {
  font-size: clamp(0.9rem, .84rem + .18vw, 1.04rem);
  font-weight: 600;
}
.primary-menu .nav-link::after {
  content: "";
  position: absolute;
  inset-inline: 4px;
  bottom: 8px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--t-base) var(--ease-out);
}
.is-rtl .primary-menu .nav-link::after { transform-origin: left; }
.primary-menu .nav-link:hover::after,
.primary-menu .current-menu-item > .nav-link::after,
.primary-menu .current-menu-ancestor > .nav-link::after { transform: scaleX(1); }
.primary-menu .caret {
  font-size: 0.7rem;
  margin-inline-start: 4px;
  transition: transform var(--t-base) var(--ease-out);
  display: inline-block;
}
.primary-menu li:hover > .nav-link .caret,
.primary-menu li:focus-within > .nav-link .caret,
.primary-menu li.is-open > .nav-link .caret { transform: rotate(180deg); }
.overlay-menu .caret { font-size: 0.78rem; transition: transform var(--t-base) var(--ease-out); display: inline-block; }
.overlay-menu li.is-open > .overlay-link .caret { transform: rotate(180deg); }

/* ---------- Dropdown sub-menu ---------- */
.primary-menu .sub-menu {
  position: absolute;
  top: calc(100% + 6px);
  inset-inline-start: -16px;
  min-width: 240px;
  background: rgba(250,246,238,.98);
  border: 1px solid rgba(193,139,98,.18);
  border-radius: var(--radius-md);
  box-shadow: 0 22px 52px rgba(20,19,15,.16);
  padding: var(--sp-3);
  list-style: none;
  margin: 0;
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition:
    opacity var(--t-base) var(--ease-out),
    transform var(--t-base) var(--ease-out),
    visibility 0s linear var(--t-base);
  z-index: 5;
}
.primary-menu .sub-menu li { position: relative; }
.primary-menu > .menu-item--mega > .sub-menu,
.primary-menu > .has-children > .sub-menu.depth-0 {
  min-width: min(740px, calc(100vw - (var(--gutter) * 2)));
  display: grid;
  grid-template-columns: repeat(2, minmax(240px, 1fr));
  gap: 12px;
  padding: 16px;
  backdrop-filter: blur(18px);
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu,
.primary-menu li.is-open > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition-delay: 0s;
}
/* Bridge — eliminates gap between trigger and dropdown */
.primary-menu li:hover > .sub-menu { animation: none; }
.primary-menu .sub-menu::before {
  content: "";
  position: absolute;
  top: -10px; inset-inline: 0;
  height: 10px;
}
.primary-menu .sub-menu .nav-link {
  display: flex;
  padding: 12px 16px;
  font-size: 0.95rem;
  border-radius: var(--radius-sm);
  color: var(--c-ink);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.primary-menu > .menu-item--mega > .sub-menu > li > .nav-link,
.primary-menu > .has-children > .sub-menu.depth-0 > li > .nav-link {
  position: relative;
  min-height: 86px;
  background: linear-gradient(145deg, rgba(255,255,255,.76), rgba(244,239,230,.72));
  justify-content: center;
  align-items: stretch;
  flex-direction: column;
  gap: 8px;
  border: 1px solid rgba(193,139,98,.16);
  box-shadow: 0 10px 24px rgba(20,19,15,.06);
  overflow: hidden;
  text-align: start;
}
.primary-menu > .menu-item--mega > .sub-menu > li > .nav-link::before,
.primary-menu > .has-children > .sub-menu.depth-0 > li > .nav-link::before {
  content: "";
  position: absolute;
  inset-block: 12px;
  inset-inline-start: 0;
  width: 3px;
  border-radius: 999px;
  background: var(--c-clay);
  opacity: .55;
  transform: scaleY(.45);
  transform-origin: center;
  transition: transform var(--t-fast) var(--ease-out), opacity var(--t-fast) var(--ease-out);
}
.primary-menu .sub-menu .nav-link--service strong {
  display: block;
  color: var(--c-ink);
  font-size: .98rem;
  line-height: 1.35;
}
.primary-menu .sub-menu .nav-link--service small {
  display: block;
  margin-block-start: 3px;
  color: var(--c-clay-deep);
  font-size: .64rem;
  letter-spacing: var(--tracking-widest);
  line-height: 1.2;
}
.primary-menu .sub-menu .nav-link--service em {
  display: block;
  color: var(--c-ink-mute);
  font-size: .78rem;
  font-style: normal;
  line-height: 1.6;
}
.primary-menu .sub-menu .nav-link::after { display: none; }
.primary-menu .sub-menu .nav-link:hover {
  background: #fffaf1;
  color: var(--c-clay-deep);
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(20,19,15,.1);
}
.primary-menu .sub-menu .nav-link:hover::before {
  opacity: 1;
  transform: scaleY(1);
}
/* Nested sub-menu */
.primary-menu .sub-menu .sub-menu {
  top: -8px;
  inset-inline-start: 100%;
  margin-inline-start: 8px;
}
.primary-menu > .menu-item--mega > .sub-menu > li > .sub-menu,
.primary-menu > .has-children > .sub-menu.depth-0 > li > .sub-menu {
  min-width: 220px;
}

.site-header.is-scrolled .primary-menu .sub-menu .nav-link { color: var(--c-ink); }

/* ---------- Header CTA group ---------- */
.header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
}

.site-header.is-light .header-cta .btn--primary {
  background: var(--c-cream);
  color: var(--c-ink);
}
.site-header.is-light .header-cta .btn--primary:hover {
  background: var(--c-clay);
  color: var(--c-cream);
}

/* ---------- Hamburger ---------- */
.menu-toggle {
  display: none;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
  border-radius: 50%;
  color: var(--c-ink);
  transition: background var(--t-fast) var(--ease-out);
}
.menu-toggle:hover { background: rgba(20,19,15,.06); }
.site-header.is-light .menu-toggle:hover { background: rgba(250,246,238,.12); }
.menu-toggle .bars { position: relative; width: 22px; height: 14px; display: block; }
.menu-toggle .bars span {
  position: absolute; inset-inline: 0; height: 1.5px;
  background: currentColor;
  transition: transform var(--t-base) var(--ease-out), opacity var(--t-fast) var(--ease-out), top var(--t-base) var(--ease-out);
}
.menu-toggle .bars span:nth-child(1) { top: 0; }
.menu-toggle .bars span:nth-child(2) { top: 50%; transform: translateY(-50%); }
.menu-toggle .bars span:nth-child(3) { top: 100%; transform: translateY(-100%); }
body.menu-open .menu-toggle .bars span:nth-child(1) { top: 50%; transform: translateY(-50%) rotate(45deg); }
body.menu-open .menu-toggle .bars span:nth-child(2) { opacity: 0; }
body.menu-open .menu-toggle .bars span:nth-child(3) { top: 50%; transform: translateY(-50%) rotate(-45deg); }

/* ---------- Mobile overlay (slide panel) ---------- */
.nav-overlay {
  position: fixed; inset: 0;
  z-index: var(--z-overlay);
  pointer-events: none;
}
.nav-overlay__backdrop {
  position: absolute; inset: 0;
  z-index: 1;
  background: rgba(20,19,15,.5);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease-out);
  pointer-events: none;
}
.nav-overlay__panel {
  position: absolute;
  top: 0; bottom: 0;
  inset-inline-end: 0;
  z-index: 2;
  width: min(420px, 92vw);
  background: var(--c-bone);
  display: flex; flex-direction: column;
  transform: translateX(102%);
  transition: transform var(--t-slow) var(--ease-out-smooth);
  box-shadow: var(--shadow-xl);
}
.is-rtl .nav-overlay__panel { inset-inline-end: 0; transform: translateX(-102%); }
body.menu-open .nav-overlay { pointer-events: auto; }
body.menu-open .nav-overlay__backdrop { opacity: 1; }
body.menu-open .nav-overlay__panel { transform: none; }

.nav-overlay__head {
  padding: var(--sp-5) var(--sp-6);
  display: flex; align-items: center; justify-content: space-between;
  border-block-end: 1px solid var(--c-line-soft);
}
.nav-overlay__logo img { display: block; height: 44px; width: auto; }
.nav-overlay__close {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid var(--c-line);
  color: var(--c-ink);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.nav-overlay__close:hover { background: var(--c-ink); color: var(--c-cream); }
.nav-overlay__close svg { width: 18px; height: 18px; }
.nav-overlay__close i { font-size: 1.1rem; }

.nav-overlay__body { flex: 1; overflow-y: auto; padding: var(--sp-5) var(--sp-6); }
.overlay-menu {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 2px;
}
.overlay-menu .overlay-link {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 0;
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--c-ink);
  border-block-end: 1px solid var(--c-line-soft);
  transition: color var(--t-fast) var(--ease-out);
}
.overlay-menu .overlay-link:hover,
.overlay-menu li.is-open > .overlay-link { color: var(--c-clay-deep); }
.overlay-menu .caret { width: 12px; height: 8px; transition: transform var(--t-base) var(--ease-out); }
.overlay-menu li.is-open > .overlay-link .caret { transform: rotate(180deg); }
.overlay-menu .sub-menu {
  list-style: none; padding: 0; margin: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--t-base) var(--ease-out);
}
.overlay-menu li.is-open > .sub-menu { max-height: 500px; }
.overlay-menu .sub-menu .overlay-link {
  justify-content: flex-start;
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--c-ink-mute);
  padding: 10px 0 10px var(--sp-4);
  padding-inline-start: var(--sp-4);
  border-block-end: 0;
}
.overlay-menu .sub-menu .sub-menu {
  padding-inline-start: var(--sp-5);
}
.overlay-menu .sub-menu .overlay-link::before {
  content: ""; width: 18px; height: 1px; background: currentColor; margin-inline-end: 12px; opacity: .5;
}

.nav-overlay__foot {
  border-block-start: 1px solid var(--c-line-soft);
  padding: var(--sp-5) var(--sp-6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
.ovf-link {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-sm);
  background: var(--c-cream);
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.ovf-link:hover { border-color: var(--c-clay); }
.ovf-link i { font-size: 1.2rem; color: var(--c-clay); }
.ovf-link--wa i { color: #25D366; }
.ovf-link span { display: flex; flex-direction: column; gap: 2px; }
.ovf-link small { font-size: .7rem; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--c-ink-mute); }
.ovf-link strong { font-size: .9rem; color: var(--c-ink); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 16px 28px;
  font-family: var(--ff-arabic);
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  border-radius: var(--radius-pill);
  transition:
    transform var(--t-base) var(--ease-out),
    background var(--t-base) var(--ease-out),
    color var(--t-base) var(--ease-out),
    box-shadow var(--t-base) var(--ease-out),
    border-color var(--t-base) var(--ease-out);
  white-space: nowrap;
  line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
}
.btn,
.btn:visited {
  color: var(--btn-color, currentColor);
}
.btn > *,
.btn svg,
.btn i {
  color: inherit;
  fill: currentColor;
  stroke: currentColor;
}
.btn svg { width: 16px; height: 16px; }
.btn i { font-size: 14px; }
.btn .arrow {
  order: 2;
}
html[dir="ltr"] .btn .arrow,
html[lang^="en"] .btn .arrow,
[dir="ltr"] i.arrow {
  transform: scaleX(-1);
}
.is-rtl .btn .arrow,
html[dir="rtl"] .btn .arrow {
  order: 2;
  transform: none;
}
.btn:hover { transform: translateY(-2px); }
.btn--sm { padding: 12px 22px; font-size: 0.85rem; }
.btn--lg { padding: 20px 34px; font-size: 1rem; }

.btn--primary { --btn-color: var(--c-cream); background: var(--c-ink); color: var(--c-cream); }
.btn--primary:hover { --btn-color: var(--c-cream); background: var(--c-clay-deep); color: var(--c-cream); box-shadow: var(--shadow-md); }

.btn--clay { --btn-color: var(--c-cream); background: var(--c-clay); color: var(--c-cream); }
.btn--clay:hover { --btn-color: var(--c-cream); background: var(--c-clay-deep); color: var(--c-cream); box-shadow: var(--shadow-md); }

.btn--ghost { --btn-color: var(--c-ink); background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn--ghost:hover { --btn-color: var(--c-cream); background: var(--c-ink); color: var(--c-cream); }
.is-light .btn--ghost { --btn-color: var(--c-cream); color: var(--c-cream); border-color: var(--c-cream); }
.is-light .btn--ghost:hover { --btn-color: var(--c-ink); background: var(--c-cream); color: var(--c-ink); }

.btn--white { --btn-color: var(--c-ink); background: var(--c-cream); color: var(--c-ink); }
.btn--white:hover { --btn-color: var(--c-ink); background: var(--c-white); color: var(--c-ink); box-shadow: var(--shadow-md); }

.btn-link {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--c-ink);
  letter-spacing: var(--tracking-wide);
  position: relative;
  padding-bottom: 4px;
  transition: gap var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.btn-link::after {
  content: ""; position: absolute; inset-inline: 0; bottom: 0; height: 1px; background: currentColor;
  transform: scaleX(1); transform-origin: right;
  transition: transform var(--t-base) var(--ease-out);
}
.is-rtl .btn-link::after { transform-origin: left; }
.btn-link:hover { gap: var(--sp-3); color: var(--c-clay-deep); }
.btn-link:hover::after { transform: scaleX(0); }
.btn-link svg, .btn-link i { width: 16px; height: 16px; font-size: 14px; }
.is-rtl .btn-link svg.arrow { transform: scaleX(-1); }

/* ---------- Card ---------- */
.card {
  background: var(--c-cream);
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: var(--c-line);
}
.card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--c-sand);
}
.card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-out-smooth);
}
.card:hover .card__media img { transform: scale(1.06); }
.card__body { padding: var(--sp-5) var(--sp-5) var(--sp-6); }
.card__title { font-size: 1.4rem; margin-block-end: var(--sp-2); }
.card__sub { color: var(--c-ink-mute); font-size: .82rem; letter-spacing: var(--tracking-widest); text-transform: uppercase; }

/* ---------- Forms ---------- */
.form-stack { display: grid; gap: var(--sp-5); }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
@media (max-width: 600px) { .form-grid-2 { grid-template-columns: 1fr; } }

.field input,
.field textarea,
.field select,
.frm_form_field input[type="text"],
.frm_form_field input[type="email"],
.frm_form_field input[type="tel"],
.frm_form_field input[type="url"],
.frm_form_field input[type="number"],
.frm_form_field textarea,
.frm_form_field select {
  width: 100%;
  background: var(--c-cream);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-sm);
  padding: 18px 18px;
  font-size: 1rem;
  color: var(--c-ink);
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.field input:focus,
.field textarea:focus,
.field select:focus,
.frm_form_field input:focus,
.frm_form_field textarea:focus,
.frm_form_field select:focus {
  outline: none;
  border-color: var(--c-ink);
  background: var(--c-white);
  box-shadow: 0 0 0 4px rgba(193,139,98,.18);
}
.field textarea, .frm_form_field textarea { min-height: 140px; resize: vertical; }
.field label,
.frm_form_field > label,
.frm_primary_label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  color: var(--c-ink-mute);
  text-transform: uppercase;
  margin-block-end: var(--sp-2);
}

.frm_button_submit, .frm_form_field input[type="submit"], .frm_submit button {
  display: inline-flex;
  align-items: center; justify-content: center;
  padding: 18px 36px;
  background: var(--c-ink);
  color: var(--c-cream) !important;
  border: 0;
  border-radius: var(--radius-pill);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  cursor: pointer;
  transition: background var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.frm_button_submit:hover, .frm_form_field input[type="submit"]:hover, .frm_submit button:hover {
  background: var(--c-clay-deep);
  transform: translateY(-2px);
}
.frm_message, .frm_success_style {
  background: var(--c-cream);
  border: 1px solid var(--c-olive);
  color: var(--c-olive);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--radius-sm);
}
.frm_error, .frm_error_style {
  background: #fbf2ec;
  border: 1px solid var(--c-clay-deep);
  color: var(--c-clay-deep);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-sm);
  font-size: .9rem;
  margin-block-start: var(--sp-2);
}

/* ---------- Footer ---------- */
.site-footer {
  background:
    linear-gradient(180deg, rgba(20,19,15,.94) 0%, var(--c-ink) 34%),
    radial-gradient(80% 70% at 82% 0%, rgba(193,139,98,.22) 0%, transparent 60%);
  color: rgba(250,246,238,.85);
  padding-block: clamp(46px, 5vw, 72px) clamp(22px, 3vw, 34px);
  position: relative;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: 0;
  height: 10px;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0%, rgba(193,139,98,.68) 22%, rgba(191,163,121,.92) 50%, rgba(156,107,69,.68) 78%, transparent 100%);
  opacity: .95;
}
.site-footer h4 {
  color: rgba(250,246,238,.55);
  font-size: 0.78rem;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  font-weight: 600;
  margin-block-end: var(--sp-3);
}
.site-footer a { color: rgba(250,246,238,.85); }
.site-footer a:hover { color: var(--c-clay); }
.site-footer ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 8px; }

.footer-grid {
  display: grid;
  grid-template-columns: 1.35fr .85fr 1fr 1.15fr 1.2fr;
  gap: 0;
  position: relative;
}
.footer-col {
  position: relative;
  min-width: 0;
  padding-inline: clamp(16px, 2.2vw, 30px);
}
.footer-col:first-child {
  padding-inline-start: 0;
}
.footer-col:last-child {
  padding-inline-end: 0;
}
.footer-col + .footer-col::before {
  content: "";
  position: absolute;
  inset-block: 4px;
  inset-inline-start: 0;
  width: 1px;
  background: linear-gradient(180deg, transparent 0%, rgba(193,139,98,.52) 18%, rgba(250,246,238,.14) 50%, rgba(191,163,121,.44) 82%, transparent 100%);
}
@media (max-width: 1100px)  {
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: var(--sp-6); }
  .footer-col { padding-inline: 0 clamp(18px, 4vw, 34px); }
  .footer-col:nth-child(odd)::before { display: none; }
}
@media (max-width: 600px)  {
  .footer-grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  .footer-col { padding-inline: 0; padding-block-start: var(--sp-4); }
  .footer-col + .footer-col::before {
    inset-block: 0 auto;
    inset-inline: 0;
    width: auto;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(193,139,98,.52) 22%, rgba(250,246,238,.14) 58%, transparent 100%);
  }
}

.footer-brand { display: grid; gap: var(--sp-3); }
.footer-brand__logo {
  display: inline-flex; align-items: center; gap: var(--sp-3);
}
.footer-brand__logo { display: inline-block; margin-block-end: 4px; }
.footer-brand__logo img {
  display: block;
  height: 46px;
  width: auto;
  filter: brightness(0) invert(1);
  opacity: .92;
  transition: opacity var(--t-fast) var(--ease-out);
}
.footer-brand__logo:hover img { opacity: 1; }
.footer-brand h2 {
  color: var(--c-cream);
  font-size: 2.2rem;
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
.footer-brand p {
  color: rgba(250,246,238,.62);
  max-width: 42ch;
  line-height: 1.65;
  font-size: .92rem;
}
.footer-contact li {
  display: flex;
  align-items: center;
  gap: 8px;
}
.footer-contact li > i {
  width: 16px;
  color: var(--c-clay);
  font-size: 12px;
}
.footer-newsletter p {
  color: rgba(250,246,238,.62);
  line-height: 1.65;
  font-size: .9rem;
  margin-block-end: 12px;
}
.newsletter-form {
  display: flex;
  min-width: 0;
  overflow: hidden;
  border: 1px solid rgba(250,246,238,.18);
  border-radius: var(--radius-pill);
  background: rgba(250,246,238,.07);
}
.newsletter-form input {
  min-width: 0;
  flex: 1 1 auto;
  border: 0;
  background: transparent;
  color: var(--c-cream);
  padding: 12px 16px;
  font-family: var(--ff-arabic);
  font-size: .9rem;
  outline: 0;
}
.newsletter-form input::placeholder {
  color: rgba(250,246,238,.48);
}
.newsletter-form button {
  flex: 0 0 42px;
  display: grid;
  place-items: center;
  border: 0;
  background: var(--c-clay);
  color: var(--c-cream);
  cursor: pointer;
  transition: background-color var(--t-fast) var(--ease-out);
}
.newsletter-form button:hover {
  background: var(--c-clay-deep);
}
.newsletter-form button i {
  font-size: 12px;
}
[dir="ltr"] .newsletter-form button i { transform: scaleX(-1); }

.footer-bottom {
  margin-block-start: clamp(28px, 4vw, 48px);
  padding-block-start: 16px;
  border-block-start: 1px solid rgba(250,246,238,.1);
  display: flex; flex-wrap: wrap; gap: var(--sp-4); justify-content: space-between; align-items: center;
  font-size: .82rem;
  color: rgba(250,246,238,.5);
}

.social-links {
  display: flex; gap: 8px; list-style: none; padding: 0; margin-block-start: 4px;
}
.site-footer .social-links {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}
.social-links a {
  width: 36px; height: 36px;
  display: inline-grid; place-items: center;
  border: 1px solid rgba(250,246,238,.18);
  border-radius: 50%;
  transition: background var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.social-links a:hover { background: var(--c-clay); border-color: var(--c-clay); color: var(--c-cream); transform: translateY(-2px); }
.social-links svg, .social-links i { width: 16px; height: 16px; font-size: 16px; }

/* ---------- Mobile sticky action bar ---------- */
.mobile-actions {
  display: none;
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  z-index: var(--z-nav);
  background: var(--c-cream);
  border-top: 1px solid var(--c-line);
  padding: var(--sp-3);
  gap: var(--sp-2);
  box-shadow: 0 -8px 24px rgba(20,19,15,.08);
}
.mobile-actions a {
  flex: 1;
  display: inline-flex;
  align-items: center; justify-content: center;
  gap: var(--sp-2);
  padding: 14px;
  border-radius: var(--radius-sm);
  font-size: .88rem;
  font-weight: 600;
}
.mobile-actions .ma-call { background: var(--c-ink); color: var(--c-cream); }
.mobile-actions .ma-wa   { background: #25D366; color: #fff; }
.mobile-actions .ma-cta  { background: var(--c-clay); color: var(--c-cream); }
.mobile-actions svg, .mobile-actions i { width: 16px; height: 16px; font-size: 14px; }

/* ---------- Responsive nav switch ---------- */
@media (max-width: 1180px) {
  .primary-nav { display: none; }
  .menu-toggle { display: inline-flex; }
  .header-inner {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--sp-3);
  }
  .primary-nav {
    grid-column: auto;
  }
}
@media (max-width: 768px) {
  body { padding-bottom: 70px; }
  .mobile-actions { display: flex; }
  .header-cta .btn { display: none; }
  :root { --header-h: 72px; }
  .site-header {
    height: var(--header-h);
  }
  .header-inner {
    padding-inline: var(--gutter);
  }
  .brand-name { font-size: 1.1rem; }
  .brand-name small { display: none; }
  .brand-mark { width: 38px; height: 38px; font-size: 1rem; }
  .brand-logo {
    max-width: min(190px, 58vw);
  }
  .nav-overlay__panel {
    width: min(390px, 94vw);
    background: rgba(244,239,230,.98);
    color: var(--c-ink);
  }
  .nav-overlay__head,
  .nav-overlay__body,
  .nav-overlay__foot {
    padding-inline: var(--gutter);
  }
  .btn {
    min-width: 0;
    white-space: normal;
    line-height: 1.35;
    text-align: center;
  }
  .mobile-actions {
    padding: 8px;
    padding-bottom: max(8px, env(safe-area-inset-bottom));
  }
  .mobile-actions a {
    min-width: 0;
    padding: 10px 8px;
    gap: 6px;
    font-size: .78rem;
    line-height: 1.25;
  }
  .overlay-menu .sub-menu .overlay-link {
    padding-inline: 0;
    padding-block: 11px;
    justify-content: flex-start;
    text-align: start;
  }
  .overlay-menu .sub-menu .overlay-link::before {
    display: none;
  }
  .overlay-menu .sub-menu {
    padding-inline-start: 18px;
    border-block-end: 1px solid var(--c-line-soft);
  }
  .is-rtl .overlay-menu .sub-menu {
    padding-inline-start: 0;
    padding-inline-end: 18px;
  }
}
@media (max-width: 430px) {
  body { padding-bottom: 66px; }
  .brand-logo {
    max-width: min(165px, 54vw);
    height: 40px;
  }
  .menu-toggle {
    width: 40px;
    height: 40px;
  }
  .nav-overlay__foot {
    grid-template-columns: 1fr;
  }
}

/* ---------- Pagination ---------- */
.pagination {
  display: flex; gap: var(--sp-2); justify-content: center; padding-block: var(--sp-7);
}
.pagination .page-numbers {
  display: inline-grid; place-items: center;
  min-width: 44px; height: 44px;
  padding: 0 var(--sp-3);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-sm);
  font-size: .92rem;
  background: var(--c-cream);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.pagination .page-numbers:hover, .pagination .current { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }

/* ---------- Lightbox ---------- */
.lb-backdrop {
  position: fixed; inset: 0; z-index: var(--z-modal);
  background: rgba(15,14,12,.94);
  display: none;
  align-items: center; justify-content: center;
  padding: var(--sp-5);
}
.lb-backdrop.is-open { display: flex; animation: lbFade 220ms ease-out; }
@keyframes lbFade { from { opacity: 0 } to { opacity: 1 } }
.lb-img {
  max-width: min(1400px, 96vw);
  max-height: 86vh;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-xl);
  animation: lbScale 320ms var(--ease-out-smooth);
}
@keyframes lbScale { from { transform: scale(.96); opacity: 0 } to { transform: none; opacity: 1 } }
.lb-close, .lb-prev, .lb-next {
  position: absolute;
  top: 50%;
  width: 50px; height: 50px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease-out);
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover { background: rgba(255,255,255,.2); }
.lb-close { top: 24px; inset-inline-end: 24px; transform: none; }
.lb-prev  { inset-inline-start: 24px; transform: translateY(-50%); }
.lb-next  { inset-inline-end: 24px;   transform: translateY(-50%); }
.lb-prev svg, .lb-next svg, .lb-close svg,
.lb-prev i,   .lb-next i,   .lb-close i   { width: 22px; height: 22px; font-size: 18px; }
.is-rtl .lb-prev svg, .is-rtl .lb-next svg,
.is-rtl .lb-prev i, .is-rtl .lb-next i { transform: scaleX(-1); }

/* ---------- Body padding for fixed header ---------- */
body { padding-top: 0; }
/* No body padding — hero uses transparent header. Pages use page-hero which already has padding-top */

/* ---------- WhatsApp floating button (desktop only) ---------- */
.wa-float {
  display: inline-flex;
  position: fixed;
  bottom: 28px;
  inset-inline-end: 28px;
  z-index: var(--z-nav);
  width: 60px; height: 60px;
  background: #25D366;
  color: #fff;
  border-radius: 50%;
  align-items: center; justify-content: center;
  box-shadow: 0 12px 30px -8px rgba(37,211,102,.55), var(--shadow-md);
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
  animation: waPulse 2.4s ease-in-out infinite;
}
.wa-float:hover { transform: scale(1.06); }
.wa-float svg, .wa-float i { width: 28px; height: 28px; font-size: 28px; }
@keyframes waPulse {
  0%, 100% { box-shadow: 0 12px 30px -8px rgba(37,211,102,.55), 0 0 0 0 rgba(37,211,102,.5); }
  50%      { box-shadow: 0 12px 30px -8px rgba(37,211,102,.55), 0 0 0 18px rgba(37,211,102,0); }
}
@media (max-width: 768px) { .wa-float { display: none; } }
