/* Start custom CSS for html, class: .elementor-element-954e1d0 *//* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Almarai:wght@300;400;700&family=Cormorant+Garamond:wght@300;400&display=swap');

/* Elementor header wrapper */
.elementor-location-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}
.admin-bar .elementor-location-header {
  top: 32px !important;
}

/* Elementor inner wrappers — remove all default spacing */
.elementor-location-header .elementor-section,
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-widget-wrap,
.elementor-location-header .elementor-widget,
.elementor-location-header .elementor-widget-html {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  background: transparent !important;
}

/* NAVBAR — force horizontal grid layout */
#cpNav {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
  width: 100% !important;
  height: 80px !important;
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
  align-items: center !important;
  padding: 0 40px !important;
  background: rgba(0,0,0,0.55) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  transition: background 0.4s, height 0.3s !important;
  box-sizing: border-box !important;
  list-style: none !important;
}
#cpNav.scrolled {
  background: rgba(0,0,0,0.88) !important;
  height: 65px !important;
}

/* Left links — force horizontal */
#cpNav .cp-nav__left {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 28px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Right links — force horizontal */
#cpNav .cp-nav__right {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 28px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Hide bullet points Elementor adds */
#cpNav li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: none !important;
}
#cpNav li::before,
#cpNav li::after {
  display: none !important;
}

/* Nav links */
#cpNav .cp-nav__left a,
#cpNav .cp-nav__right a {
  font-family: 'Almarai', sans-serif !important;
  font-size: 1.0rem !important;
  font-weight: 400 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.82) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  position: relative !important;
  padding-bottom: 2px !important;
  display: inline-block !important;
  transition: color 0.2s !important;
}
#cpNav .cp-nav__left a:hover,
#cpNav .cp-nav__right a:hover {
  color: #FF7D20 !important;
}

/* Logo center */
#cpNav .cp-nav__logo {
  display: flex !important;
  justify-content: Left !important;
  align-items: center !important;
  text-decoration: none !important;
}
#cpNav .cp-nav__logo img {
  height: 60px !important;
  width: auto !important;
  display: block !important;
  filter: brightness(0) invert !important;
}

/* Services dropdown */
#cpNav .cp-nav__item {
  position: relative !important;
}
#cpNav .cp-dropdown {
  position: absolute !important;
  top: calc(100% + 18px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(8px) !important;
  background: rgba(10,10,10,0.96) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  min-width: 200px !important;
  list-style: none !important;
  padding: 8px 0 !important;
  margin: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.22s, transform 0.22s !important;
  z-index: 10000 !important;
  display: block !important;
}
#cpNav .cp-nav__item:hover .cp-dropdown {
  opacity: 1 !important;
  pointer-events: all !important;
  transform: translateX(-50%) translateY(0) !important;
}
#cpNav .cp-dropdown li {
  display: block !important;
}
#cpNav .cp-dropdown li a {
  display: block !important;
  padding: 10px 20px !important;
  font-size: 0.66rem !important;
  letter-spacing: 1.6px !important;
  color: rgba(255,255,255,0.6) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  text-transform: uppercase !important;
}
#cpNav .cp-dropdown li a:hover {
  color: #FF7D20 !important;
  background: rgba(255,255,255,0.06) !important;
}

/* Hamburger — hidden desktop */
#cpNav .cp-burger {
  display: none !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 6px !important;
  width: 40px !important;
  height: 40px !important;
  cursor: pointer !important;
  background: none !important;
  border: none !important;
  padding: 2px !important;
}
#cpNav .cp-burger span {
  display: block !important;
  height: 2px !important;
  background: #FF7D20 !important;
  transition: transform 0.4s cubic-bezier(0.77,0,0.175,1), width 0.3s !important;
}
#cpNav .cp-burger span:nth-child(1) { width: 100% !important; }
#cpNav .cp-burger span:nth-child(2) { width: 65% !important; }
#cpNav .cp-burger.open span:nth-child(1) {
  transform: translateY(3.5px) rotate(45deg) !important;
  width: 100% !important;
}
#cpNav .cp-burger.open span:nth-child(2) {
  transform: translateY(-3.5px) rotate(-45deg) !important;
  width: 100% !important;
}

/* ── MOBILE ── */
@media (max-width: 860px) {
  #cpNav {
    grid-template-columns: 1fr auto !important;
    padding: 0 20px !important;
    height: 60px !important;
  }
  #cpNav .cp-nav__left { display: none !important; }
  #cpNav .cp-nav__right { display: none !important; }
  #cpNav .cp-burger { display: flex !important; }
}

/* ── OVERLAY ── */
#cpOverlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9998 !important;
  background: #0d0d0d !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 90px 48px 48px !important;
  clip-path: inset(0 0 100% 0) !important;
  transition: clip-path 0.6s cubic-bezier(0.77,0,0.175,1) !important;
  overflow-y: auto !important;
}
#cpOverlay.open {
  clip-path: inset(0 0 0% 0) !important;
}

#cpOverlay .cp-overlay__nav {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  justify-content: center !important;
}
#cpOverlay .cp-overlay__nav li {
  list-style: none !important;
  overflow: hidden !important;
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  padding: 0 !important;
  margin: 0 !important;
}
#cpOverlay .cp-overlay__nav li:first-child {
  border-top: 1px solid rgba(255,255,255,0.07) !important;
}
#cpOverlay .cp-overlay__nav li a {
  display: block !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2rem, 7vw, 4rem) !important;
  font-weight: 300 !important;
  color: #fff !important;
  text-decoration: none !important;
  padding: 10px 0 !important;
  transform: translateY(110%) !important;
  transition: transform 0.5s cubic-bezier(0.77,0,0.175,1), color 0.2s !important;
  line-height: 1.2 !important;
}
#cpOverlay.open .cp-overlay__nav li a {
  transform: translateY(0) !important;
}
#cpOverlay.open .cp-overlay__nav li:nth-child(1) a { transition-delay: 0.08s !important; }
#cpOverlay.open .cp-overlay__nav li:nth-child(2) a { transition-delay: 0.13s !important; }
#cpOverlay.open .cp-overlay__nav li:nth-child(3) a { transition-delay: 0.18s !important; }
#cpOverlay.open .cp-overlay__nav li:nth-child(4) a { transition-delay: 0.23s !important; }
#cpOverlay.open .cp-overlay__nav li:nth-child(5) a { transition-delay: 0.28s !important; }
#cpOverlay.open .cp-overlay__nav li:nth-child(6) a { transition-delay: 0.33s !important; }
#cpOverlay .cp-overlay__nav li a:hover { color: rgba(255,255,255,0.35) !important; }

/* Services sub inside overlay */
#cpOverlay .cp-overlay__sub {
  list-style: none !important;
  padding: 0 0 10px 4px !important;
  margin: 0 !important;
  display: none !important;
  flex-direction: column !important;
}
#cpOverlay .cp-overlay__sub.open { display: flex !important; }
#cpOverlay .cp-overlay__sub li { border: none !important; }
#cpOverlay .cp-overlay__sub li a {
  font-family: 'Almarai', sans-serif !important;
  font-size: 0.7rem !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.38) !important;
  padding: 6px 0 !important;
  transform: none !important;
  transition: color 0.2s !important;
}
#cpOverlay .cp-overlay__sub li a:hover { color: rgba(255,255,255,0.8) !important; }

#cpOverlay .cp-overlay__toggle {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  cursor: pointer !important;
}
#cpOverlay .cp-overlay__toggle.open svg { transform: rotate(180deg) !important; }

/* Overlay bottom */
#cpOverlay .cp-overlay__bottom {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 20px !important;
  padding-top: 32px !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  opacity: 0 !important;
  transform: translateY(14px) !important;
  transition: opacity 0.4s ease 0.42s, transform 0.4s ease 0.42s !important;
}
#cpOverlay.open .cp-overlay__bottom {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
#cpOverlay .cp-overlay__email span {
  display: block !important;
  font-family: 'Almarai', sans-serif !important;
  font-size: 1.0rem !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.25) !important;
  margin-bottom: 4px !important;
}
#cpOverlay .cp-overlay__email a {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.58rem !important;
  color: rgba(255,255,255,0.6) !important;
  text-decoration: none !important;
}
#cpOverlay .cp-overlay__email a:hover { color: #fff !important; }

#cpOverlay .cp-overlay__social {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}
#cpOverlay .cp-overlay__social a {
  color: rgba(255,255,255,0.35) !important;
  text-decoration: none !important;
  display: flex !important;
  transition: color 0.2s, transform 0.2s !important;
}
#cpOverlay .cp-overlay__social a:hover {
  color: #fff !important;
  transform: translateY(-2px) !important;
}

#cpOverlay .cp-overlay__cta {
  font-family: 'Almarai', sans-serif !important;
  font-size: 1.0rem !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: #0d0d0d !important;
  background: #fff !important;
  text-decoration: none !important;
  padding: 11px 24px !important;
  border: 1px solid transparent !important;
  display: inline-block !important;
  white-space: nowrap !important;
  transition: background 0.2s, color 0.2s, border-color 0.2s !important;
}
#cpOverlay .cp-overlay__cta:hover {
  background: transparent !important;
  color: #fff !important;
  border-color: rgba(255,255,255,0.35) !important;
}

body.menu-open { overflow: hidden !important; }/* End custom CSS */