/* Site-wide responsive + layout fixes (mobile, tablet, desktop) */

:root {
  --shpe-page-gutter: clamp(1rem, 4vw, 2rem);
  --shpe-header-offset-mobile: 90px;
  --shpe-header-offset-tablet: 110px;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  overflow-x: clip;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img,
video,
iframe,
svg,
canvas {
  max-width: 100%;
  height: auto;
}

.e-con,
.e-con-inner,
.elementor-widget-wrap,
.elementor-container {
  min-width: 0;
}

.elementor-widget-image img,
.elementor-widget-image-gallery img,
.elementor-gallery__container img {
  display: block;
}

/* ---------- Mobile / tablet nav (no Elementor device-mode dependency) ---------- */
@media (max-width: 1024px) {
  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-hamburger-menu {
    display: block !important;
    cursor: pointer;
    min-width: 44px;
    min-height: 44px;
    padding: 10px 12px;
    touch-action: manipulation;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu-wrapper {
    width: min(100%, 360px);
    max-width: 360px;
    border-radius: 0;
    background-color: #f7f7f7;
    position: fixed;
    top: 0;
    left: -110%;
    height: 100% !important;
    z-index: 999999;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-direction: column-reverse;
    justify-content: flex-end;
    transition: left 0.45s cubic-bezier(0.6, 0.1, 0.68, 0.53);
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu-wrapper.active {
    left: 0;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100%;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu > li {
    width: 100%;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu > li > a {
    display: block;
    padding: 14px 20px;
    min-height: 44px;
    line-height: 1.3;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu li > .sub-menu {
    position: static !important;
    display: none;
    box-shadow: none !important;
    background: rgba(0, 0, 0, 0.03);
    padding-left: 0;
    margin: 0;
    width: 100%;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu li.shpe-submenu-open > .sub-menu,
  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu li > .sub-menu.dropdown-open {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 999998;
    transition: opacity 0.3s ease, visibility 0.3s ease;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-menu-wrapper.active ~ .jkit-overlay,
  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet.active-overlay .jkit-overlay {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .jeg-elementor-kit.jkit-nav-menu.break-point-tablet .jkit-close-menu {
    min-width: 44px;
    min-height: 44px;
    touch-action: manipulation;
  }

  .elementor-location-header .elementor-element-1b62b851 {
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
  }

  .elementor-location-header .elementor-element-4b5a2682 img {
    max-height: 48px;
    width: auto;
  }

  .elementor-location-header .elementor-element-1d3be380 {
    --margin-bottom: -72px !important;
  }
}

@media (max-width: 767px) {
  .elementor-location-header .elementor-element-4b5a2682 img {
    max-height: 40px;
  }

  .elementor-location-header .elementor-element-1d3be380 {
    --margin-bottom: -56px !important;
  }

  .elementor-location-header .elementor-element-6348570e {
    --icon-size: 15px;
  }
}

body.shpe-nav-open {
  overflow: hidden;
  touch-action: none;
}

/* ---------- Homepage hero ---------- */
@media (max-width: 767px) {
  .elementor-466 .elementor-element.elementor-element-fe9ea7c {
    --padding-top: 6.5em !important;
    --padding-bottom: 2em !important;
    --padding-left: 1em !important;
    --padding-right: 1em !important;
  }

  .elementor-466 .elementor-element.elementor-element-8023ab7 .elementor-heading-title {
    font-size: clamp(1.65rem, 7vw, 2rem) !important;
    line-height: 1.15 !important;
  }

  .elementor-466 .elementor-element.elementor-element-42bc0d9 .elementor-headline {
    font-size: clamp(1.75rem, 8vw, 2.2rem) !important;
    line-height: 1.15 !important;
  }

  .elementor-466 .elementor-element.elementor-element-8446cc0 {
    width: 100% !important;
    max-width: 100% !important;
    --container-widget-width: 100% !important;
  }
}

@media (max-width: 1024px) and (min-width: 768px) {
  .elementor-466 .elementor-element.elementor-element-fe9ea7c {
    --padding-top: 8em !important;
    --padding-left: 1.5em !important;
    --padding-right: 1.5em !important;
  }

  .elementor-466 .elementor-element.elementor-element-8023ab7 .elementor-heading-title,
  .elementor-466 .elementor-element.elementor-element-42bc0d9 .elementor-headline {
    font-size: clamp(2rem, 5vw, 3rem) !important;
  }
}

/* ---------- Inner page heroes (portfolio, services, about) ---------- */
@media (max-width: 1024px) {
  .elementor-page:not(.home) [data-elementor-type="wp-page"] > .e-con.e-parent:first-of-type,
  .elementor-page:not(.home) main > .elementor > .e-con.e-parent:first-of-type,
  .elementor-page:not(.home) #content > .elementor > .e-con.e-parent:first-of-type {
    --padding-top: var(--shpe-header-offset-tablet) !important;
    --padding-left: var(--shpe-page-gutter) !important;
    --padding-right: var(--shpe-page-gutter) !important;
  }
}

@media (max-width: 767px) {
  .elementor-page:not(.home) [data-elementor-type="wp-page"] > .e-con.e-parent:first-of-type,
  .elementor-page:not(.home) main > .elementor > .e-con.e-parent:first-of-type,
  .elementor-page:not(.home) #content > .elementor > .e-con.e-parent:first-of-type {
    --padding-top: var(--shpe-header-offset-mobile) !important;
  }

  .elementor-page .elementor-heading-title {
    word-wrap: break-word;
    overflow-wrap: anywhere;
  }
}

/* ---------- Columns & grids ---------- */
@media (max-width: 1024px) {
  .elementor-column,
  .elementor-col-50,
  .elementor-col-33,
  .elementor-col-25 {
    min-width: 0;
  }

  .e-con.e-parent > .e-con-inner {
    padding-left: var(--shpe-page-gutter);
    padding-right: var(--shpe-page-gutter);
  }
}

@media (max-width: 767px) {
  .elementor-widget-text-editor,
  .elementor-widget-heading {
    max-width: 100%;
  }

  .elementor-button,
  .elementor-button-link,
  .jkit-hamburger-menu,
  .jkit-close-menu {
    touch-action: manipulation;
  }
}

/* ---------- Footer ---------- */
@media (max-width: 767px) {
  .elementor-location-footer .e-con-inner {
    text-align: center;
  }

  .elementor-location-footer .elementor-widget-wrap {
    justify-content: center;
  }
}

/* ---------- Forms & contact ---------- */
@media (max-width: 767px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="url"],
  textarea,
  select {
    font-size: 16px;
    max-width: 100%;
  }

  .metform-form-main-wrapper,
  .mf-form-wrapper {
    padding-left: var(--shpe-page-gutter);
    padding-right: var(--shpe-page-gutter);
  }
}

/* ---------- Lightbox on touch devices ---------- */
@media (hover: none) and (pointer: coarse) {
  .elementor-gallery__container .e-gallery-item:hover,
  .elementor-image-gallery .gallery-item:hover .gallery-icon {
    transform: none;
    box-shadow: none;
  }
}

/* ---------- Smoother scrolling on supported browsers ---------- */
@supports (scrollbar-gutter: stable) {
  html {
    scrollbar-gutter: stable;
  }
}
