/* Final cascade layer for Elementor wrapper behavior. */
.elementor .p33-card-grid,
.elementor .p33-facility-grid,
.elementor .p33-split-section,
.elementor .p33-service-main,
.elementor .p33-about-section,
.elementor .p33-footer,
.elementor .p33-service-row,
.elementor .p33-facility-card {
  display: block !important;
  gap: 0 !important;
  grid-template-columns: none !important;
  width: 100% !important;
}

.elementor .p33-card-grid > .e-con-inner,
.elementor .p33-facility-grid > .e-con-inner,
.elementor .p33-split-section > .e-con-inner,
.elementor .p33-service-main > .e-con-inner,
.elementor .p33-about-section > .e-con-inner,
.elementor .p33-footer > .e-con-inner,
.elementor .p33-service-row > .e-con-inner,
.elementor .p33-facility-card > .e-con-inner {
  display: grid !important;
  max-width: none !important;
  min-width: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

.elementor .p33-card-grid > .e-con-inner,
.elementor .p33-facility-grid > .e-con-inner {
  gap: 28px !important;
}

.elementor .p33-grid-2 > .e-con-inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.elementor .p33-grid-3 > .e-con-inner {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.elementor .p33-grid-4 > .e-con-inner {
  gap: 24px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.elementor .p33-split-section > .e-con-inner,
.elementor .p33-about-section > .e-con-inner {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.elementor .p33-service-main > .e-con-inner {
  gap: clamp(32px, 5vw, 64px) !important;
  grid-template-columns: 0.8fr 1.2fr !important;
}

.elementor .p33-footer > .e-con-inner {
  gap: 28px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.elementor .p33-service-row > .e-con-inner {
  gap: 16px !important;
  grid-template-columns: 74px 1fr !important;
}

.elementor .p33-facility-card > .e-con-inner {
  gap: 20px !important;
  grid-template-columns: 112px 1fr !important;
}

.elementor .p33-stats-strip {
  display: block !important;
  width: 100% !important;
}

.elementor .p33-stats-strip > .e-con-inner {
  align-items: stretch !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  max-width: none !important;
  padding: 0 !important;
  width: 100% !important;
}

.elementor .p33-stats-strip .p33-stat {
  display: block !important;
  width: auto !important;
}

.elementor .p33-stats-strip .p33-stat > .e-con-inner {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  justify-content: center !important;
  text-align: center !important;
}

@media (max-width: 1100px) {
  .elementor .p33-grid-4 > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  .elementor .p33-grid-2 > .e-con-inner,
  .elementor .p33-grid-3 > .e-con-inner,
  .elementor .p33-split-section > .e-con-inner,
  .elementor .p33-service-main > .e-con-inner,
  .elementor .p33-about-section > .e-con-inner,
  .elementor .p33-footer > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  .elementor .p33-stats-strip > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .elementor .p33-grid-4 > .e-con-inner,
  .elementor .p33-service-row > .e-con-inner,
  .elementor .p33-facility-card > .e-con-inner,
  .elementor .p33-stats-strip > .e-con-inner {
    grid-template-columns: 1fr !important;
  }
}

/* Elementor 4 may render text widgets without the legacy widget-container node. */
.elementor .p33-eyebrow,
.elementor .p33-eyebrow .elementor-widget-container {
  color: var(--p33-accent) !important;
}

.elementor .p33-hero .p33-hero-copy,
.elementor .p33-hero .p33-hero-copy .elementor-widget-container {
  color: rgba(255, 255, 255, 0.82) !important;
}

.elementor .p33-body-copy,
.elementor .p33-body-copy .elementor-widget-container,
.elementor .p33-strip-copy,
.elementor .p33-strip-copy .elementor-widget-container {
  color: var(--p33-muted) !important;
}

.elementor .p33-banner .p33-eyebrow,
.elementor .p33-banner .p33-eyebrow .elementor-widget-container {
  color: rgba(255, 255, 255, 0.55) !important;
}

/* Keep desktop navigation visually text-only while Elementor stores button controls. */
.elementor .p33-nav-items,
.elementor .p33-nav-items > .e-con-inner {
  background: transparent !important;
}

.elementor .p33-nav-link .elementor-button {
  background: transparent !important;
  color: var(--p33-fg) !important;
  padding: 0 !important;
}

.elementor .p33-nav-link.is-active .elementor-button,
.elementor .p33-nav-link .elementor-button:hover {
  color: var(--p33-accent-dark) !important;
}

/* Mobile navigation flyout. */
.elementor .p33-mobile-menu-toggle {
  display: none !important;
}

body.p33-mobile-menu-open {
  overflow: hidden;
}

body.p33-mobile-menu-open::before {
  background: rgba(26, 18, 8, 0.46);
  content: "";
  inset: 0;
  position: fixed;
  z-index: 899;
}

@media (max-width: 900px) {
  .elementor .p33-header,
  .elementor .p33-header > .e-con-inner {
    align-items: center !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    justify-content: space-between !important;
  }

  .elementor .p33-header {
    padding: 0 20px !important;
  }

  .elementor .p33-brand {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }

  .elementor .p33-nav-actions,
  .elementor .p33-nav-actions > .e-con-inner {
    align-items: center !important;
    display: flex !important;
    flex: 0 0 auto !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    justify-content: flex-end !important;
    min-width: 0 !important;
  }

  .elementor .p33-mobile-menu-toggle {
    display: block !important;
  }

  .elementor .p33-mobile-menu-toggle .elementor-button {
    background: var(--p33-accent) !important;
    border: 1px solid rgba(26, 18, 8, 0.18) !important;
    color: var(--p33-fg) !important;
    min-height: 42px !important;
    padding: 11px 14px !important;
  }

  .elementor .p33-phone-button {
    display: none !important;
  }

  .elementor .p33-nav-items {
    background: var(--p33-accent) !important;
    box-shadow: -28px 0 60px rgba(26, 18, 8, 0.28) !important;
    box-sizing: border-box !important;
    display: block !important;
    flex: none !important;
    height: 100dvh !important;
    inset: 0 0 0 auto !important;
    max-width: 360px !important;
    min-width: 0 !important;
    overflow-y: auto !important;
    padding: 96px 30px 34px !important;
    position: fixed !important;
    transform: translateX(105%) !important;
    transition: transform 220ms ease !important;
    width: calc(100vw - 48px) !important;
    z-index: 1200 !important;
  }

  .elementor .p33-nav-items > .e-con-inner {
    align-items: flex-start !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
    justify-content: flex-start !important;
    max-width: none !important;
    padding: 0 !important;
    width: 100% !important;
  }

  body.p33-mobile-menu-open .elementor .p33-nav-items {
    transform: translateX(0) !important;
  }

  .elementor .p33-nav-items .p33-nav-link,
  .elementor .p33-nav-items .p33-nav-link .elementor-button-wrapper,
  .elementor .p33-nav-items .p33-nav-link .elementor-button {
    width: 100% !important;
  }

  .elementor .p33-nav-items .p33-nav-link .elementor-button {
    align-items: center !important;
    background: transparent !important;
    border-bottom: 1px solid rgba(26, 18, 8, 0.22) !important;
    color: var(--p33-fg) !important;
    display: flex !important;
    font-size: 22px !important;
    justify-content: space-between !important;
    letter-spacing: 1.5px !important;
    padding: 14px 0 !important;
    text-align: left !important;
  }

  .elementor .p33-nav-items .p33-nav-link.is-active .elementor-button {
    color: #ffffff !important;
  }
}

@media (max-width: 460px) {
  .elementor .p33-button-dark .elementor-button {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .elementor .p33-mobile-menu-toggle .elementor-button {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}
