/* Minimal Astro overrides — theme CSS from qshark-moving.com does the heavy lifting. */

/* Quote form fields — theme line-height: 18px clips descenders (e.g. "Moving size") */
.qs-main-screen__form__input,
.qs-popup .qs-main-screen__form__input {
  line-height: 1.5;
  padding: 18px 20px;
  height: auto;
  min-height: 60px;
}

select.qs-main-screen__form__input {
  padding-block: 19px 17px;
}

/*
 * Fixed header (.qs-header { position: fixed; z-index: 100 }).
 * Inner pages: full clearance on the hero; do not pad main (avoids a dead gap
 * where breadcrumbs sat under the bar).
 */
body:not(.home) main {
  padding-top: 0;
}

body:not(.home) .qs-main-screen {
  padding-top: 100px;
}

@media screen and (max-width: 768px) {
  body:not(.home) .qs-main-screen {
    padding-top: 84px;
  }
}

body:not(.home) .qs-main-screen__title {
  margin: 0 0 16px;
  font-size: 52px;
  line-height: 1.08;
}

@media screen and (max-width: 1450px) {
  body:not(.home) .qs-main-screen__title {
    font-size: 44px;
  }
}

@media screen and (max-width: 800px) {
  body:not(.home) .qs-main-screen__title {
    font-size: 36px;
  }
}

body:not(.home) .qs-main-screen__sub-title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.45;
  margin: 0 0 28px;
  max-width: 36rem;
}

body:not(.home) .qs-main-screen__txt {
  font-size: 14px;
  line-height: 1.4;
}

body:not(.home) .qs-main-screen__form-content {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

/* Inner-page hero (.qs-main) — tall banner, title centered above quote form */
body:not(.home) .qs-main {
  --qs-hero-min: clamp(600px, 65vh, 740px);
  --qs-hero-form-lift: 92px;
  display: block;
  min-height: var(--qs-hero-min);
  padding-top: 92px;
  padding-bottom: 40px;
}

body:not(.home) .qs-main > .container.qs-main__content {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  align-content: stretch;
  min-height: calc(var(--qs-hero-min) - 92px - 40px);
}

body:not(.home) .qs-main .text-container {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 0 !important;
  padding: 0 0 calc(var(--qs-hero-form-lift) * 0.45);
  min-height: 0;
}

body:not(.home) .qs-main .qs-main-screen__title {
  margin: 0 !important;
  width: 100%;
  line-height: 1.12;
}

body:not(.home) .qs-main .qs-main-screen__form-content {
  position: relative;
  z-index: 6;
  margin-top: calc(var(--qs-hero-form-lift) * -1);
  margin-bottom: 36px;
}

/* Tablet / narrow desktop — stack title + form, no overlap (long titles wrap) */
@media screen and (max-width: 1200px) {
  body:not(.home) .qs-main {
    --qs-hero-min: auto;
    --qs-hero-form-lift: 0px;
    min-height: 0;
    padding-bottom: 32px;
    overflow: visible;
  }

  body:not(.home) .qs-main > .container.qs-main__content {
    display: block;
    min-height: 0;
  }

  body:not(.home) .qs-main .text-container {
    display: block;
    padding: 16px 0 24px !important;
  }

  body:not(.home) .qs-main .qs-main-screen__form-content {
    margin-top: 0 !important;
    margin-bottom: 24px;
  }
}

@media screen and (max-width: 768px) {
  body:not(.home) .qs-main {
    padding-bottom: 40px;
  }

  body:not(.home) .qs-main .text-container {
    padding: 12px 0 20px !important;
  }

  body:not(.home) .qs-main .qs-main-screen__form-content {
    margin-bottom: 24px;
  }
}

/* Non-home: always show solid header (backup if markup misses darkHeader) */
body:not(.home) .qs-header {
  background: #fff;
  box-shadow: 0 9px 36px 0 rgba(0, 0, 0, 0.12);
}

/* Header logo — vertically centered with nav actions (all breakpoints) */
.qs-header .qs-nav__left {
  display: flex;
  align-items: center;
}

.qs-header .qs-nav__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 0;
}

.qs-header .qs-nav__logo .qs-nav__img {
  display: block;
  width: 50px;
  height: 50px;
  object-fit: contain;
}

/* Mobile nav — accordion drawer (paired with site.js) */
@media (max-width: 1200px) {
  .qs-header .container {
    flex-wrap: nowrap;
    gap: 8px;
    align-items: center;
  }

  .qs-header .qs-nav__left {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    align-self: center;
  }

  .qs-header .qs-nav__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    margin-right: 10px;
    line-height: 0;
  }

  .qs-header .qs-nav__logo .qs-nav__img {
    display: block;
    width: 44px;
    height: 44px;
    object-fit: contain;
  }

  .qs-header .qs-nav__links {
    display: none !important;
  }

  .qs-header .qs-nav__get-quote-wrap {
    flex-shrink: 0;
    margin-right: 8px;
    margin-left: 0;
    align-self: center;
  }

  .qs-header .qs-nav__phone {
    flex-shrink: 0;
    align-self: center;
  }

  .qs-header .qs-nav__menu-toggle,
  .qs-header .qs-header__toggle {
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: relative;
    top: 0 !important;
    margin-top: 0;
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    cursor: pointer;
    z-index: 103;
    transition: background-color 0.2s ease;
  }

  .qs-header.qs-nav-open .qs-nav__menu-toggle {
    background: rgba(0, 0, 0, 0.05);
  }

  .qs-header.qs-nav-open .qs-nav__menu-toggle svg {
    opacity: 0;
  }

  .qs-header.qs-nav-open .qs-nav__menu-toggle::before,
  .qs-header.qs-nav-open .qs-nav__menu-toggle::after {
    content: "";
    position: absolute;
    width: 20px;
    height: 2px;
    border-radius: 1px;
    background: #141414;
  }

  .qs-header.qs-nav-open .qs-nav__menu-toggle::before {
    transform: rotate(45deg);
  }

  .qs-header.qs-nav-open .qs-nav__menu-toggle::after {
    transform: rotate(-45deg);
  }

  .qs-header.qs-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 101;
    background: rgba(13, 13, 13, 0.42);
    pointer-events: none;
  }

  .qs-header.qs-nav-open .qs-nav__links {
    display: block !important;
    position: fixed;
    top: 72px;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 102;
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 12px 16px 32px;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    background: #f4f4f5;
    box-sizing: border-box;
    list-style: none;
    font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    animation: qs-nav-panel-in 0.24s ease;
  }

  @keyframes qs-nav-panel-in {
    from {
      opacity: 0;
      transform: translateY(-8px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  .qs-header.qs-nav-open .qs-nav__links::before {
    content: "Navigation";
    display: block;
    padding: 4px 4px 14px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #737373;
  }

  .qs-header.qs-nav-open .qs-nav__links > .menu-item,
  .qs-header.qs-nav-open .qs-nav__links > .nav-item {
    margin: 0 0 10px !important;
    padding: 0;
    text-align: left;
    list-style: none;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.07);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  }

  .qs-header.qs-nav-open .qs-nav__links > .menu-item > .nav-link,
  .qs-header.qs-nav-open .qs-nav__links .dropdown > a.dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 52px;
    padding: 14px 16px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 0;
    text-transform: none;
    text-align: left;
    color: #141414 !important;
    text-decoration: none;
    box-sizing: border-box;
    transition: background-color 0.18s ease;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown.show > a.dropdown-toggle,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu.show > a {
    background: linear-gradient(90deg, rgba(246, 177, 26, 0.14), rgba(246, 177, 26, 0.03));
    box-shadow: inset 3px 0 0 #f6b11a;
  }

  .qs-header.qs-nav-open .qs-nav__links .caret {
    display: none;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu {
    display: block !important;
    position: static;
    float: none;
    box-shadow: none;
    border: none;
    width: 100%;
    margin: 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    background: #fafafa;
    border-top: 0 solid rgba(0, 0, 0, 0.06);
    transition:
      max-height 0.34s ease,
      padding 0.28s ease,
      border-top-width 0.2s ease;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown.show > .dropdown-menu,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu.show > .dropdown-menu {
    max-height: 1200px;
    padding: 6px 0 10px;
    border-top-width: 1px;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu .menu-item,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu .nav-item {
    margin: 0 !important;
    padding: 0;
    text-align: left;
    list-style: none;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .menu-item > .nav-link,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .nav-item > .nav-link {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 10px 16px 10px 20px;
    font-size: 15px;
    font-weight: 600;
    text-transform: none;
    color: #262626 !important;
    text-decoration: none;
    transition: background-color 0.15s ease, color 0.15s ease;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .menu-item > .nav-link:active,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .nav-item > .nav-link:active,
  .qs-header.qs-nav-open .qs-nav__links > .menu-item > .nav-link:active {
    background: rgba(246, 177, 26, 0.12);
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .dropdown-submenu {
    margin: 6px 10px;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-menu > .dropdown-submenu > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 48px;
    padding: 12px 14px;
    font-size: 15px;
    font-weight: 700;
    color: #141414 !important;
    text-decoration: none;
    box-sizing: border-box;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown > a.dropdown-toggle::after,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu > a::after {
    content: "";
    flex-shrink: 0;
    width: 9px;
    height: 9px;
    margin-left: auto;
    border-right: 2px solid #737373;
    border-bottom: 2px solid #737373;
    transform: rotate(45deg);
    transition: transform 0.22s ease, border-color 0.2s ease;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown.show > a.dropdown-toggle::after,
  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu.show > a::after {
    transform: rotate(-135deg);
    border-color: #c88900;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu > .dropdown-menu {
    margin: 0;
    padding: 0;
    background: #f5f5f5;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu.show > .dropdown-menu {
    padding: 4px 0 8px;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu .dropdown-menu .nav-link {
    min-height: 42px;
    padding: 9px 14px 9px 18px;
    font-size: 14px;
    font-weight: 500;
    color: #404040 !important;
    opacity: 1;
  }

  .qs-header.qs-nav-open .qs-nav__links .dropdown-submenu .dropdown-menu .nav-link::before {
    content: "";
    display: inline-block;
    width: 5px;
    height: 5px;
    margin-right: 10px;
    border-radius: 50%;
    background: #d4d4d4;
    vertical-align: middle;
  }
}

body.qs-nav-locked {
  overflow: hidden;
}

/* Floating CTA — desktop/tablet only; overlaps content on phones */
@media (max-width: 782px) {
  .qs-floating-banner-wrap {
    display: none !important;
  }
}

/* Nested "Areas Served" flyouts (California / Florida) */
@media (min-width: 992px) {
  /*
   * Theme rule `.dropdown:hover .dropdown-menu { display: block }` opens every
   * nested menu at once. Hide nested panels unless their parent row is hovered.
   */
  .qs-nav__links .dropdown:hover > .dropdown-menu .dropdown-menu {
    display: none;
  }

  .qs-nav__links .dropdown-submenu {
    position: relative;
  }

  .qs-nav__links .dropdown-submenu > a {
    position: relative;
    padding-right: 2.5rem;
  }

  .qs-nav__links .dropdown-submenu > a::after {
    content: "";
    position: absolute;
    right: 20px;
    top: 50%;
    width: 0;
    height: 0;
    margin-top: -4px;
    border-color: transparent transparent transparent #333;
    border-style: solid;
    border-width: 5px 0 5px 5px;
  }

  .qs-nav__links .dropdown-submenu > .dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: 0;
  }

  .qs-nav__links .dropdown:hover > .dropdown-menu .dropdown-submenu:hover > .dropdown-menu {
    display: block;
  }
}

/* Quote form: second step visibility */
#formSecondStep[hidden] {
  display: none !important;
}

/* Yelp reviews carousel (site.js replaces bxSlider) */
.qs-yelp-reviews-viewport {
  overflow: hidden;
}

.qs-yelp-reviews .bx-prev,
.qs-yelp-reviews .bx-next {
  border: none;
  cursor: pointer;
}

.qs-yelp-reviews .bx-prev:disabled,
.qs-yelp-reviews .bx-next:disabled {
  opacity: 0.35;
  cursor: default;
  pointer-events: none;
}

/* Homepage section headings (inline CSS from WordPress was not migrated) */
.zk-header-homepage,
.z-header-homepage {
  font-size: 3em;
  font-weight: 900;
  text-align: center;
  max-width: 1000px;
  margin: 48px auto 24px;
  padding: 0 20px;
  line-height: 1.15;
}

@media (max-width: 670px) {
  .zk-header-homepage,
  .z-header-homepage {
    font-size: 1.7em;
  }
}

/* Floating estimate popup open state */
.qs-popup-wrap.is-open {
  display: block !important;
}

/*
 * Theme sets html { font-size: 10px }, so rem-based sizes are tiny unless scaled.
 * Use px (or rem × 10) for readable body copy on location heroes.
 */

/* Location intro — below hero, readable at html { font-size: 10px } sites */
.qs-location-intro-wrap {
  padding-top: 8px;
  padding-bottom: 8px;
}

.qs-location-intro {
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 1.65;
  color: #0d0d0d;
  max-width: 52rem;
}

.qs-location-intro a {
  color: #0d0d0d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* WordPress utility sizes (html root is 10px — rem classes render too small) */
.has-small-font-size {
  font-size: 15px !important;
  line-height: 1.6 !important;
}

.has-medium-font-size {
  font-size: 18px !important;
  line-height: 1.4 !important;
}

/*
 * "Why Choose Qshark" / "Why Should You Hire QShark Movers?" feature grids.
 * Legacy markup uses .whyQsharkColumnsWrapepr (330+ pages) or .zk-why-wrapper (~65).
 */
body:not(.home) main .container > .wp-block-columns.whyQsharkColumnsWrapper {
  display: block !important;
  margin: 48px 0 40px !important;
  max-width: 100%;
}

body:not(.home) main .container > .wp-block-columns.whyQsharkColumnsWrapper > .wp-block-column {
  flex: 1 1 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

body:not(.home) main .container h2.wp-block-heading.has-text-align-center + .whyQsharkColumnsWrapepr,
body:not(.home) main .container h2.wp-block-heading.has-text-align-center + .zk-why-wrapper {
  margin-top: 0;
}

body:not(.home) main .container .whyQsharkColumnsWrapper h2.wp-block-heading.has-text-align-center,
body:not(.home) main .container h2.wp-block-heading.has-text-align-center:has(+ .whyQsharkColumnsWrapepr),
body:not(.home) main .container h2.wp-block-heading.has-text-align-center:has(+ .zk-why-wrapper) {
  margin: 0 0 28px !important;
  padding: 0 8px;
  font-size: clamp(26px, 2.2vw, 32px) !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  color: #0d0d0d !important;
}

.whyQsharkColumnsWrapepr .wp-block-heading.has-medium-font-size,
.zk-why-wrapper .wp-block-heading.has-medium-font-size {
  margin: 0 0 12px !important;
  padding: 0;
  font-size: 17px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
  color: #0d0d0d !important;
  letter-spacing: 0.01em;
}

.whyQsharkColumnsWrapepr,
.zk-why-wrapper.whyQsharkColumnsWrapepr,
.zk-why-wrapper {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 18px 16px !important;
  margin: 0 0 40px !important;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.whyQsharkColumnsWrapepr > .wp-block-column,
.whyQsharkColumnsWrapepr > .singleColumn,
.zk-why-wrapper > .wp-block-column,
.zk-why-wrapper > .singleColumn {
  flex: unset !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 22px 18px 20px !important;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.98),
    rgba(255, 250, 240, 0.94)
  );
  border: 1px solid rgba(246, 177, 26, 0.24);
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
  box-sizing: border-box;
  word-break: normal !important;
  overflow-wrap: break-word !important;
}


.whyQsharkColumnsWrapepr p.has-small-font-size,
.zk-why-wrapper p.has-small-font-size {
  margin: 0 !important;
  padding: 0;
  font-size: 15px !important;
  line-height: 1.65 !important;
  letter-spacing: normal;
  color: #0d0d0d;
}

.whyQsharkColumnsWrapepr a,
.zk-why-wrapper a {
  color: #b8740a;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.whyQsharkColumnsWrapepr a:hover,
.zk-why-wrapper a:hover {
  color: #8f5a06;
}

@media (max-width: 1180px) {
  .whyQsharkColumnsWrapepr,
  .zk-why-wrapper.whyQsharkColumnsWrapepr,
  .zk-why-wrapper {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  }
}

@media (max-width: 782px) {
  .whyQsharkColumnsWrapepr,
  .zk-why-wrapper.whyQsharkColumnsWrapepr,
  .zk-why-wrapper {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px !important;
  }

  .whyQsharkColumnsWrapepr > .wp-block-column,
  .whyQsharkColumnsWrapepr > .singleColumn,
  .zk-why-wrapper > .wp-block-column,
  .zk-why-wrapper > .singleColumn {
    padding: 18px 16px !important;
  }
}

@media (max-width: 520px) {
  .whyQsharkColumnsWrapepr,
  .zk-why-wrapper.whyQsharkColumnsWrapepr,
  .zk-why-wrapper {
    grid-template-columns: 1fr;
  }
}

/* Bottom CTA — "Join the Thousands of Satisfied QShark Customers" */
.zk-homepage-cta {
  margin: 48px 0 56px !important;
  padding: 36px 28px 32px !important;
  border-radius: 20px !important;
  background: linear-gradient(
    180deg,
    rgba(255, 210, 128, 0.42),
    rgba(255, 210, 128, 0.2)
  ) !important;
  border: 1px solid rgba(246, 177, 26, 0.4) !important;
  box-sizing: border-box;
}

.zk-homepage-cta > .wp-block-column {
  flex: 1 1 100% !important;
  width: 100% !important;
  max-width: 100%;
}

.zk-homepage-cta > .wp-block-column > .wp-block-heading {
  margin: 0 0 24px !important;
  padding: 0 12px;
  font-size: 26px !important;
  line-height: 1.3 !important;
  font-weight: 800 !important;
  color: #0d0d0d !important;
}

/* Button + phone row — centered, not stretched edge-to-edge */
.zk-homepage-cta .wp-block-column .wp-block-columns {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 16px 28px !important;
  margin: 0 !important;
}

.zk-homepage-cta .wp-block-column .wp-block-columns > .wp-block-column {
  flex: 0 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100%;
}

.zk-homepage-cta .wp-block-buttons {
  margin: 0 !important;
}

.zk-homepage-cta .wp-block-button__link,
.zk-homepage-cta .quoteButtonCustom .wp-block-button__link {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 28px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: #0d0d0d !important;
  background: linear-gradient(180deg, #ffc84a, #f6b11a) !important;
  border-radius: 12px !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  text-decoration: none !important;
  box-shadow: 0 6px 18px rgba(246, 177, 26, 0.35);
}

.zk-homepage-cta .wp-block-button__link:hover,
.zk-homepage-cta .wp-block-button__link:focus {
  color: #0d0d0d !important;
  opacity: 0.9;
  text-decoration: none !important;
}

.zk-homepage-cta p.has-large-font-size {
  margin: 0 !important;
  text-align: center !important;
}

.zk-homepage-cta p.has-large-font-size,
.zk-homepage-cta p.has-large-font-size a,
.zk-homepage-cta p.has-large-font-size strong {
  font-size: 22px !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
  color: #0d0d0d !important;
}

.zk-homepage-cta p.has-large-font-size a {
  text-decoration: none !important;
}

.zk-homepage-cta p.has-large-font-size a:hover {
  text-decoration: underline !important;
  opacity: 1 !important;
}

@media (max-width: 640px) {
  .zk-homepage-cta {
    padding: 28px 20px 24px !important;
  }

  .zk-homepage-cta > .wp-block-column > .wp-block-heading {
    font-size: 22px !important;
  }

  .zk-homepage-cta p.has-large-font-size,
  .zk-homepage-cta p.has-large-font-size a {
    font-size: 20px !important;
  }
}

/*
 * Inner-page amber CTA bands — centered headline + button/phone row.
 * Matches .zk-homepage-cta; excludes 40/60 split image rows.
 */
body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  ) {
  margin: 48px 0 36px !important;
  padding: 36px 28px 32px !important;
  border-radius: 20px !important;
  background: linear-gradient(
    180deg,
    rgba(255, 210, 128, 0.42),
    rgba(255, 210, 128, 0.2)
  ) !important;
  border: 1px solid rgba(246, 177, 26, 0.4) !important;
  box-sizing: border-box;
  overflow: hidden;
  align-items: stretch !important;
  gap: 0 !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  > .wp-block-column {
  flex: 1 1 100% !important;
  width: 100% !important;
  max-width: 100% !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  .wp-block-heading.has-text-align-center {
  margin: 0 0 24px !important;
  padding: 0 12px;
  text-align: center !important;
  font-size: 26px !important;
  line-height: 1.3 !important;
  font-weight: 800 !important;
  color: #0d0d0d !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  > .wp-block-column
  > .wp-block-columns {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 16px 28px !important;
  margin: 0 !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  > .wp-block-column
  > .wp-block-columns
  > .wp-block-column {
  flex: 0 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100%;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  .wp-block-buttons {
  margin: 0 !important;
  justify-content: center !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  p.has-large-font-size,
body:not(.home)
  main
  .container
  > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
    :has(> .wp-block-column[style*="flex-basis:40%"])
  )
  p.has-large-font-size
  a {
  margin: 0 !important;
  text-align: center !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  color: #0d0d0d !important;
  text-decoration: none !important;
}

@media (max-width: 640px) {
  body:not(.home)
    main
    .container
    > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
      :has(> .wp-block-column[style*="flex-basis:40%"])
    ) {
    padding: 28px 20px 24px !important;
  }

  body:not(.home)
    main
    .container
    > .wp-block-columns.has-background:has(> .wp-block-column > .wp-block-heading.has-text-align-center):not(
      :has(> .wp-block-column[style*="flex-basis:40%"])
    )
    .wp-block-heading.has-text-align-center {
    font-size: 22px !important;
  }
}

/* Footer — Contacts block spacing and readability */
.qs-footer {
  padding-top: 48px !important;
  padding-bottom: 44px !important;
}

.qs-footer__title {
  margin: 0 0 28px !important;
  font-size: 28px !important;
  line-height: 1.2 !important;
}

.qs-footer__columns {
  row-gap: 36px !important;
  column-gap: 24px !important;
}

.qs-footer__text__item {
  margin-bottom: 16px !important;
  line-height: 1.6 !important;
  font-size: 14px !important;
}

.qs-footer__text__item__title {
  display: block;
  margin: 0 0 10px !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
}

.qs-footer__text__item div {
  line-height: 1.55 !important;
}

.qs-footer__text__tel {
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
}

.qs-footer a:not([rel="nofollow"]) {
  opacity: 1;
}

.qs-footer a:not([rel="nofollow"]):hover {
  opacity: 0.75;
}

/* Prevent horizontal scroll from fixed/share widgets and wide tables */
html {
  overflow-x: clip;
}

body,
main {
  max-width: 100%;
  overflow-x: clip;
}

body.page-template-calculator .heateor_sss_vertical_sharing,
body.page-template-page-templatescalculator-php .heateor_sss_vertical_sharing {
  display: none !important;
}

@media (max-width: 991px) {
  .heateor_sss_vertical_sharing {
    display: none !important;
  }
}

@media (max-width: 768px) {
  main .container {
    max-width: 100%;
    overflow-x: clip;
  }

  .qs-main-screen__wrapper,
  .w50,
  .w100 {
    max-width: 100%;
  }

  .qs-m-calculator__quote,
  .qs-m-calculator__quote__content {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  /* Homepage carousels — scroll inside the widget, not the page */
  .qs-hp-compare__scroll,
  .qs-as-seen-on__logos {
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .qs-hp-compare__scroll::-webkit-scrollbar,
  .qs-as-seen-on__logos::-webkit-scrollbar {
    display: none;
  }
}

/* Legacy PNG tile grid (replaced by qs-services-links on inner pages) */
.movingServices .qs-service__content__aside__services {
  display: none !important;
}

main .container .qs-services-links {
  width: 100vw;
  max-width: 100vw;
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: 40px;
  margin-bottom: 40px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  main .container .qs-services-links {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/* Service/location pages — split image + copy rows (40/60 wp-block-columns) */
body:not(.home) main .container > .wp-block-columns {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 24px 32px;
  margin: 0 0 36px;
  max-width: 100%;
  box-sizing: border-box;
}

body:not(.home) main .container > .wp-block-columns.has-background:has(> .wp-block-column[style*="flex-basis:40%"]) {
  padding: 32px 24px !important;
  border-radius: 16px;
  margin-bottom: 36px;
  overflow: hidden;
}

body:not(.home) main .container > .wp-block-columns > .wp-block-column {
  min-width: 0 !important;
  box-sizing: border-box;
}

body:not(.home) main .container > .wp-block-columns > .wp-block-column[style*="flex-basis:40%"] {
  flex: 1 1 100% !important;
  max-width: 100%;
}

body:not(.home) main .container > .wp-block-columns > .wp-block-column[style*="flex-basis:60%"] {
  flex: 1 1 100% !important;
  max-width: 100%;
}

@media (min-width: 782px) {
  body:not(.home) main .container > .wp-block-columns {
    flex-wrap: nowrap !important;
  }

  /* 40% + 60% + 32px gap must fit in 100% — subtract half the gap from each column */
  body:not(.home) main .container > .wp-block-columns > .wp-block-column[style*="flex-basis:40%"] {
    flex: 0 0 calc(40% - 16px) !important;
    max-width: calc(40% - 16px) !important;
  }

  body:not(.home) main .container > .wp-block-columns > .wp-block-column[style*="flex-basis:60%"] {
    flex: 0 0 calc(60% - 16px) !important;
    max-width: calc(60% - 16px) !important;
  }
}

body:not(.home) main .container .wp-block-image {
  margin: 0;
  max-width: 100%;
}

body:not(.home) main .container .wp-block-image img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}

body:not(.home)
  main
  .container
  > .wp-block-columns:has(> .wp-block-column[style*="flex-basis:40%"])
  .wp-block-heading {
  margin: 0 0 16px;
  font-size: 28px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  color: #0d0d0d !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns:has(> .wp-block-column[style*="flex-basis:40%"])
  p {
  font-size: 16px !important;
  line-height: 1.65 !important;
  color: #0d0d0d;
  margin: 0 0 14px;
}

body:not(.home)
  main
  .container
  > .wp-block-columns:has(> .wp-block-column[style*="flex-basis:60%"])
  > .wp-block-column[style*="flex-basis:60%"]
  > .wp-block-columns
  + .wp-block-columns {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px 24px;
  margin-top: 20px !important;
}

body:not(.home)
  main
  .container
  > .wp-block-columns:has(> .wp-block-column[style*="flex-basis:60%"])
  > .wp-block-column[style*="flex-basis:60%"]
  > .wp-block-columns
  + .wp-block-columns
  > .wp-block-column {
  flex: 0 1 auto !important;
  width: auto !important;
  max-width: 100%;
}

body:not(.home) main .container > .wp-block-columns .quoteButtonCustom .wp-block-button__link {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 24px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: #0d0d0d !important;
  background: linear-gradient(180deg, #ffc84a, #f6b11a) !important;
  border-radius: 12px !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  text-decoration: none !important;
  box-shadow: 0 6px 18px rgba(246, 177, 26, 0.35);
}

body:not(.home) main .container > .wp-block-columns p.has-large-font-size,
body:not(.home) main .container > .wp-block-columns p.has-large-font-size a {
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  color: #0d0d0d !important;
  text-decoration: none !important;
  margin: 0 !important;
}

body:not(.home) main .container > .wp-block-columns p.has-large-font-size a:hover {
  text-decoration: underline !important;
}

.has-large-font-size {
  font-size: 22px !important;
  line-height: 1.35 !important;
}

/* Contact page — estimate form above 2-column contacts grid */
.qs-contacts > .container > .qs-contacts__form-wrap {
  grid-column: 1 / -1;
  width: 100%;
  margin-bottom: 48px;
}

.qs-contacts .qs-contacts__form-wrap .qs-main-screen__form-content {
  max-width: 1270px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

body.page-template-contacts .qs-contacts .qs-main-screen__form-content,
body.page-template-page-templatescontacts-php .qs-contacts .qs-main-screen__form-content {
  max-width: 1270px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 768px) {
  .qs-contacts > .container > .qs-contacts__form-wrap {
    margin-bottom: 32px;
  }
}

/* 404 page — kill hero .qs-main-screen side effects if present in cached markup */
body.error404 main {
  background: linear-gradient(180deg, #fff9ef 0%, #ffffff 55%);
}

body.error404 .qs-not-found,
body.error404 .qs-main-screen.qs-not-found {
  position: relative;
  display: block;
  min-height: 0;
  overflow: visible !important;
  background: transparent !important;
  background-image: none !important;
  padding: 120px 0 64px;
  text-align: center;
}

body.error404 .qs-not-found::after,
body.error404 .qs-main-screen.qs-not-found::after {
  display: none !important;
  content: none !important;
  height: 0 !important;
}

body.error404 .qs-not-found .qs-main-screen__title,
body.error404 .qs-not-found__title {
  margin: 0 0 16px !important;
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800;
  line-height: 1.12;
  color: #0d0d0d;
  text-align: center;
}

.qs-not-found__inner {
  max-width: 42rem;
  margin: 0 auto;
}

.qs-not-found__code {
  margin: 0 0 8px;
  font-size: clamp(64px, 12vw, 96px);
  font-weight: 800;
  line-height: 1;
  color: #f6b11a;
}

.qs-not-found__lead {
  margin: 0 auto 28px;
  max-width: 32rem;
  font-size: 18px;
  line-height: 1.55;
  color: #333;
}

.qs-not-found__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px 24px;
  margin-bottom: 36px;
}

.qs-not-found__links a {
  font-size: 16px;
  font-weight: 700;
  color: #0d0d0d;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.qs-not-found__links a:hover {
  color: #c98a00;
}

body.error404 .qs-not-found__cta.qs-amber-cta {
  margin: 0;
  width: 100%;
  max-width: none;
}

@media screen and (max-width: 768px) {
  body.error404 .qs-not-found,
  body.error404 .qs-main-screen.qs-not-found {
    padding: 96px 0 48px;
  }

  .qs-not-found__lead {
    font-size: 16px;
  }

  .qs-not-found__links {
    margin-bottom: 28px;
  }
}
