/*
Theme Name: Kadence Child
Theme URI: https://yourwebsite.com
Description: Child theme for Kadence
Author: Your Name
Author URI: https://yourwebsite.com
Template: kadence
Version: 1.0.0
*/

/* =Theme customization starts here
------------------------------------------------------- */

/*** Responsive Styles Large Desktop And Above ***/
@media all and (min-width: 1405px) {
}
/*** Responsive Styles Standard Desktop Only ***/
@media all and (min-width: 1100px) and (max-width: 1405px) {
}
/*** Responsive Styles Tablet And Below ***/
@media all and (max-width: 980px) {
}
/*** Responsive Styles Tablet Only ***/
@media all and (min-width: 768px) and (max-width: 980px) {
}
/*** Responsive Styles Smartphone Only ***/
@media all and (max-width: 767px) {
}
/*** Responsive Styles Smartphone Portrait ***/
@media all and (max-width: 479px) {
}

/* ------------- 1. general styles ------------- */

h1, h2, h3, h4, h5, h6 {overflow-wrap: normal;}

/* Make any heading visually match h6 typography */
.style-h6 {
  font-size: 14px !important;
  font-style: normal !important;
  font-weight: 400 !important;
  line-height: 1.3 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.add-dash::before {
  content: '';
  display: inline-block;
  width: 2em;
  height: 1px;
  background: currentColor;
  vertical-align: middle;
  margin-right: 0.6em;
  opacity: 0.7;
}

sup {
    position: relative;
    top: -0.5em;
    font-size: 12px;
    margin-right: 2px;
}

/* Remove required text line for gravity form Asterisk: * */
p.gform_required_legend {
    display: none;
}
/* Footer */
.widget_nav_menu a:hover {
    text-decoration: underline !important;
}
.widget_pages a, .widget_nav_menu a {
    display: block;
    padding: 0.1em 0;
    text-decoration: none;
}
@media screen and (max-width: 1024px) {
    .footer-widget-area.content-tablet-align-center {
        text-align: left;
    }
}

/* Menu Navigation - dropdown Mobile */
.kadence-svg-iconset svg {
    height: 1.2em;
    width: 1.2em;
}
.site-branding a.brand {
    gap: 0;
}
/* Breadcrumbs */
.kadence-breadcrumbs {
    margin: 0em 0;
}
/* ------------- a. Gravity contact form ------------- */

.gform_wrapper ul.gform_fields li {
    list-style: none;
}
.gform_wrapper ul.gform_fields {
    padding-left: 0 !important;
}
.gform_wrapper .hidden_label label {
    display: none;
}
.gform_wrapper input[type=text],
.gform_wrapper input[type=email],
.gform_wrapper input[type=tel],
.gform_wrapper textarea,
.gform_wrapper select {
    border-radius: 0px !important;
    background-color: #fff;
    color: inherit;
    font-family: sans-serif;
    border: 0;
    padding: 10px !important;
    border: 1px solid #eeeeee;
}
.gform_wrapper.gravity-theme .gfield_label {
    display: inline-block;
    font-size: 15px;
    font-weight: normal;
    margin-bottom: 3px;
    padding: 0;
}
.gform_wrapper input[type=email]:focus {
    border: 1px solid #eeeeee;
}
.gform_wrapper input[type=text]::placeholder,
.gform_wrapper input[type=email]::placeholder,
.gform_wrapper input[type=tel]::placeholder,
.gform_wrapper textarea::placeholder,
.gform_wrapper select::placeholder {
    color: inherit;
    font-family: inherit;
}
.gform_wrapper .gform_footer {
    text-align: right;
}
.gform_wrapper input[type=submit] {
	border: 0;
    background-color: #333333;
    color: #ffffff;
    font-family: inherit;
    text-transform: uppercase;
    font-weight: inherit;
    font-size: inherit;
    transition-duration: .3s;
    border-radius: 0px;
    padding: 8px 28px;
    cursor:pointer;
}
.gform_wrapper input[type=submit]:hover {
    transition-duration: .3s;
    opacity:0.9;
}
.gform_legacy_markup_wrapper .gform_footer {
    margin: 0px 0 0;
}

/* ---- Top bar scroll logo ---- */

.topbar-scroll-logo {
  display: none;
  align-items: center;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  flex-shrink: 0;
}

.topbar-scroll-logo img {
  height: 28px;
  width: auto;
  display: block;
}

@media (min-width: 1025px) {
  .topbar-scroll-logo {
    display: flex;
  }

  .site-top-header-wrap.topbar-show-logo .topbar-scroll-logo {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
}

/* ---- Mobile drawer navigation ---- */

/* Sub-menu borders */
.popup-drawer .mobile-navigation .sub-menu,
#mobile-site-navigation .sub-menu {
  padding: 0 !important;
  margin: 0 !important;
}

.popup-drawer .mobile-navigation .sub-menu > li,
#mobile-site-navigation .sub-menu > li {
  border-bottom: 1px solid rgba(116, 140, 164, 0.3) !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.popup-drawer .mobile-navigation .sub-menu > li:first-child,
#mobile-site-navigation .sub-menu > li:first-child {
  border-top: 1px solid rgba(116, 140, 164, 0.3) !important;
}

.popup-drawer .mobile-navigation .sub-menu > li > a,
#mobile-site-navigation .sub-menu > li > a {
  font-size: 1.2rem !important;
  font-weight: 400 !important;
  padding: 14px 30px !important;
  display: block !important;
  color: var(--global-palette3) !important;
}

/* Hamburger icon color */
.menu-toggle-open.drawer-toggle {
  color: var(--global-palette3) !important;
}

/* X close button — matches hamburger size and weight */
.menu-toggle-close.drawer-toggle {
  color: var(--global-palette3) !important;
  font-size: 30px !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

.menu-toggle-close .toggle-close-bar {
  height: 0.08em !important;
  background-color: var(--global-palette3) !important;
}

/* Drawer inner: full-screen slide from right.
   Duration matches Kadence's 250ms close timeout so animation finishes before display:none fires. */
#mobile-drawer .drawer-inner {
  transform: translateX(100%) !important;
  max-width: 100% !important;
  left: 0 !important;
  right: 0 !important;
  opacity: 1 !important;
  background-color: #F0F0F0 !important;
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Only target .active — when Kadence removes .active (but keeps .show-drawer for 250ms),
   the transition back to translateX(100%) can start immediately. */
#mobile-drawer.active .drawer-inner {
  transform: translateX(0) !important;
}

/* Close button is moved out of drawer-inner by JS so position:fixed works against
   the viewport (not the transformed drawer-inner containing block). */
#mobile-drawer > .menu-toggle-close {
  z-index: 99999;
}

/* Hide the now-empty drawer header */
#mobile-drawer .drawer-header {
  display: none !important;
}

/* Scrollable nav content — add top padding to clear the absolute-positioned X button */
#mobile-drawer .drawer-content {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  padding-top: 80px;
}

/* Nav underline — vertical position fix.
   The <a> may inherit a tall height from Kadence customizer (height: 100%), pushing
   bottom: 0 to the row's bottom edge. Make <li> a flex container so <a> becomes a
   flex item that centers to content height, placing the underline just below the text. */
.header-navigation[class*=header-navigation-style-underline] .header-menu-container > ul > li {
  display: flex;
  align-items: center;
}
.header-navigation[class*=header-navigation-style-underline] .header-menu-container > ul > li > a {
  height: auto !important;
}

/* Suppress underline on dropdown nav items — they use the caret arrow as indicator. */
.header-navigation[class*=header-navigation-style-underline] .header-menu-container > ul > li.menu-item-has-children > a::after {
  display: none !important;
}
.header-navigation .header-menu-container > ul > li.menu-item-has-children > a,
.header-navigation .header-menu-container > ul > li.menu-item-has-children > a .nav-drop-title-wrap {
  text-decoration: none !important;
}

/* Dropdown submenus — raise well above the sticky top bar (z-index: 1200) */
#site-navigation .sub-menu,
.header-navigation ul ul.sub-menu,
.header-navigation ul ul.submenu {
  z-index: 9999 !important;
}

/* Hamburger icon — white on transparent-header pages */
body.transparent-header .menu-toggle-open,
body.mobile-transparent-header .menu-toggle-open {
  color: #fff !important;
}

/* Ancestor link color on transparent header — overrides .main-navigation palette rule */
.transparent-header .header-navigation .header-menu-container > ul > li.menu-item.current-menu-ancestor > a {
  color: rgba(255, 255, 255, 0.66);
}

/* ---- Hero + service-hero divider base ---- */

/* The hero-divider gets position:absolute from its Kadence block settings.
   The service-hero-divider needs the same via CSS since it wasn't set in the editor. */
.service-hero-divider {
  position: absolute !important;
  width:80%!important;
}

/* ---- Hero video background ---- */

.hero {
  position: relative !important;
  overflow: hidden !important;
}

/* Clear the Kadence palette background so the video shows through */
.hero.has-theme-palette9-background-color {
  background-color: transparent !important;
}

.hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform-origin: center center;
  animation: hero-reveal 2.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Subtle dark overlay */
.hero-video-overlay {
  position: absolute;
  inset: 0;
  background: rgba(12, 36, 74, 0.38);
  z-index: 1;
}

/* Existing Kadence overlay sits above the video overlay */
.hero .kt-row-layout-overlay {
  z-index: 2;
}

/* Row content stays on top */
.hero .kt-row-column-wrap {
  position: relative;
  z-index: 3;
}

@keyframes hero-reveal {
  from {
    transform: scale(0.25) translateX(-14%) rotate(-14deg);
    opacity: 0;
  }
  to {
    transform: scale(1) translateX(0) rotate(0deg);
    opacity: 1;
  }
}

/* ---- Subtle Kadence scroll animations ---- */
[data-aos="fade-left"]:not(.aos-animate)  { transform: translate3d(20px,  0, 0); }
[data-aos="fade-right"]:not(.aos-animate) { transform: translate3d(-20px, 0, 0); }
[data-aos="fade-up"]:not(.aos-animate)    { transform: translate3d(0,  20px, 0); }
[data-aos="fade-down"]:not(.aos-animate)  { transform: translate3d(0, -20px, 0); }

.kt-adv-heading249382_08e4c5-4d[data-aos] {
  transition-delay: 400ms !important;
}

/* ---- Trust bar — staggered fade-in + column dividers ---- */

@keyframes trust-col-in {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0);    }
}

.trust-bar .kt-row-column-wrap > .wp-block-kadence-column {
  opacity: 0;
}

.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column {
  animation: trust-col-in 1s ease forwards;
}

.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column:nth-child(1) { animation-delay: 0ms;   }
.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) { animation-delay: 100ms; }
.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column:nth-child(3) { animation-delay: 200ms; }
.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column:nth-child(4) { animation-delay: 300ms; }
.trust-bar.trust-bar-visible .kt-row-column-wrap > .wp-block-kadence-column:nth-child(5) { animation-delay: 400ms; }

/* Responsive grid — override Kadence's 5→1 jump */
.trust-bar .kt-row-column-wrap.kt-has-5-columns {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  align-items: center !important;
}

@media (max-width: 767px) {
  .trust-bar .kt-row-column-wrap.kt-has-5-columns {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* Hide "Local to the Valley" — 5th column */
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column:nth-child(5) {
    display: none !important;
  }
  /* Each grid item stretches to fill its cell so dividers run full height */
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column {
    align-self: stretch !important;
  }
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column > .kt-inside-inner-col {
    height: 100% !important;
    justify-content: center !important;
  }
  /* Centre icon+text within the group itself, not just the group within the cell */
  .trust-bar .wp-block-group.is-vertical {
    width: 100% !important;
    align-items: center !important;
  }
  /* Dividers: right border on left-column items only */
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column:nth-child(odd) > .kt-inside-inner-col {
    border-right: 1px solid rgba(116, 140, 164, 0.3) !important;
  }
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column:nth-child(even) > .kt-inside-inner-col {
    border-right: none !important;
  }
}

/* Thin vertical dividers — only between items on the same row */
.trust-bar .kt-row-column-wrap > .wp-block-kadence-column > .kt-inside-inner-col {
  border-right: 1px solid rgba(116, 140, 164, 0.3);
  padding-left: 20px !important;
  padding-right: 20px !important;
  text-align: center;
}

/* Last item has no right border */
.trust-bar .kt-row-column-wrap > .wp-block-kadence-column:last-child > .kt-inside-inner-col {
  border-right: none;
}

/* Tablet + mobile — smaller icons and text */
@media (max-width: 980px) {
  .trust-bar .kt-svg-icon-wrap svg {
    width: 20px !important;
    height: 20px !important;
  }
  .trust-bar h5 {
    font-size: 0.75rem !important;
  }
  .trust-bar p,
  .trust-bar p.wp-block-kadence-advancedheading {
    font-size: 0.65rem !important;
  }
  .trust-bar .kt-row-column-wrap > .wp-block-kadence-column > .kt-inside-inner-col {
    padding-left: 10px !important;
    padding-right: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
}


/* ---- Scroll float animations ---- */

@keyframes subtle-float-up {
  from { opacity: 0; transform: translateY(45px); }
  to   { opacity: 1; transform: translateY(0);    }
}

@keyframes subtle-float-down {
  from { opacity: 0; transform: translateY(-45px); }
  to   { opacity: 1; transform: translateY(0);     }
}

.subtle-float-up {
  opacity: 0;
  transform: translateY(45px);
}

.subtle-float-up.is-visible {
  animation: subtle-float-up 2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.subtle-float-down {
  opacity: 0;
  transform: translateY(-45px);
}

.subtle-float-down.is-visible {
  animation: subtle-float-down 2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

/* inline elements need inline-block for transform to apply */
span.subtle-float-up,
span.subtle-float-down {
  display: inline-block;
  width: 100%;
}

/* ---- Kadence AOS timing overrides ---- */
[data-aos="fade-left"],
[data-aos="fade-right"] {
  transition-duration: 1100ms !important;
}

/* Hero floats — observer fires immediately (in viewport on load),
   so block the keyframe via animation-name: none and use hero-ready instead */
.hero .subtle-float-up.is-visible,
.hero .subtle-float-down.is-visible {
  animation: none !important;
  opacity: 0;
  transform: translateY(var(--float-y));
}

.hero .subtle-float-up  { --float-y: 45px; }
.hero .subtle-float-down { --float-y: -45px; }

.hero .subtle-float-up.hero-ready,
.hero .subtle-float-down.hero-ready {
  animation: none !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition:
    opacity 2s ease,
    transform 2.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

/* ---- About section heading — opacity-only float (translateY conflicts with flex-top pinning) ---- */

#about h2.subtle-float-up {
  transform: none !important;
  animation: none !important;
  transition: opacity 1.2s ease !important;
}

#about h2.subtle-float-up.is-visible {
  opacity: 1 !important;
}

/* ---- About section overlapping image float ----
   Must match the full positioning selector to beat its specificity (160)
   and override transform: translateY(-50%) !important with the start offset. */

#about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2).subtle-float-up {
  opacity: 0 !important;
  transform: translateY(calc(-50% + 45px)) !important;
  transition: opacity 1.5s ease, transform 2s cubic-bezier(0.22, 1, 0.36, 1) !important;
  animation: none !important;
}

#about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2).subtle-float-up.is-visible {
  opacity: 1 !important;
  transform: translateY(-50%) !important;
}

/* ---- CTA group card ---- */

.cta-group {
  max-width: 560px !important;
  backdrop-filter: blur(14.3px) !important;
  -webkit-backdrop-filter: blur(14.3px) !important;
  background-color: rgba(240, 240, 240, 0.15) !important;
  border: 1px solid rgba(240, 240, 240, 0.2) !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 19px rgba(0, 0, 0, 0.25) !important;
}

@media (max-width: 1024px) {
  .cta-group {
    max-width: none !important;
  }

  /* Cancel the desktop translateY(-50%) overlap — images stack on tablet/mobile */
  #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2).subtle-float-up,
  #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2).subtle-float-up.is-visible {
    transform: translateY(0) !important;
  }

  .kb-image249382_02d492-49 .kb-is-ratio-image {
    max-height: 420px;
    overflow: hidden;
  }

  @media (max-width: 600px) {
    .kb-image249382_02d492-49 .kb-is-ratio-image {
      max-height: 260px;
    }
  }

  .kb-image249382_02d492-49 .kb-is-ratio-image img {
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
  }
}

/* ---- Shower glass info overlay card ---- */

/* Grid overlap: figure and card share the same cell so card sits on top of image */
:has(> #shower-glass-bg) {
  display: grid !important;
  grid-template-columns: 1fr;
}

#shower-glass-bg {
  grid-row: 2;
  grid-column: 1;
  position: relative;
}


#shower-glass-info {
  grid-row: 2;
  grid-column: 1;
  align-self: start;
  justify-self: end;
  margin: 20px;
  z-index: 1;
  max-width: 320px;
  padding: 1em !important;
  backdrop-filter: blur(14.3px) !important;
  border: 1px solid #F0F0F033 !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 19px #00000040 !important;
}

@media (min-width: 768px) and (max-width: 980px) {
  #shower-glass-bg .kb-image-ratio-land21 {
    padding-bottom: 80% !important;
  }
  #shower-glass-info {
    max-width: 75% !important;
  }
}

@media (max-width: 767px) and (orientation: portrait) {
  /* Image fills the grid cell absolutely — card drives the cell height */
  #shower-glass-bg {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
  }
  #shower-glass-bg .kb-is-ratio-image {
    height: 100% !important;
    padding-bottom: 0 !important;
  }
  #shower-glass-bg img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  #shower-glass-info {
    max-width: 100% !important;
    margin: 16px !important;
    margin-bottom: 20px !important;
    align-self: center !important;
  }
}

/* ── Nested Kadence row — prevent alignfull breakout ───────────────────────
   A row inside a column uses alignfull + kb-theme-content-width which applies
   negative margins and 100vw width, breaking the parent column layout.
   Reset those behaviours when a row is nested inside .kt-inside-inner-col.   ────────────────────────────────────────────────────────────────────────── */

.kt-inside-inner-col .kb-row-layout-wrap.alignfull,
.kt-inside-inner-col .wp-block-kadence-rowlayout.alignfull {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  left: auto !important;
  right: auto !important;
}

.kt-inside-inner-col .kb-row-layout-wrap .kt-row-column-wrap.kb-theme-content-width {
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* ── Utility: .stack-on-tablet ─────────────────────────────────────────────
   Add this class to a Kadence row block via "Additional CSS class" to force
   all columns to stack to a single column on tablet and below (≤ 980px).    ────────────────────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  html body .kb-row-layout-wrap.stack-on-tablet > .kt-row-column-wrap {
    display: flex !important;
    flex-direction: column !important;
  }
  html body .kb-row-layout-wrap.stack-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* number-fact rows — stack and left-align on tablet */
  html body .kb-row-layout-wrap.number-fact > .kt-row-column-wrap {
    display: flex !important;
    flex-direction: column !important;
  }
  html body .kb-row-layout-wrap.number-fact > .kt-row-column-wrap > .wp-block-kadence-column {
    width: 100% !important;
    max-width: 100% !important;
    text-align: left !important;
  }
  html body .kb-row-layout-wrap.number-fact h2,
  html body .kb-row-layout-wrap.number-fact h3,
  html body .kb-row-layout-wrap.number-fact p {
    text-align: left !important;
  }
  .kb-row-layout-wrap.number-fact .horizontal-items > .kt-inside-inner-col {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .kb-row-layout-wrap.number-fact .horizontal-items h2 {
    margin-bottom: 12px !important;
  }
  .kb-row-layout-wrap.number-fact .horizontal-items h3 {
    margin-bottom: 22px !important;
  }

  /* Hero + service hero divider position on tablet */
  .hero-divider {
    top: 65% !important;
  }

  .service-hero-divider {
    top: 45%;
    width: 100% !important;
  }

  /* Remove min-height: 100vh on service hero sections for tablet */
  @media (min-width: 768px) {
    .kb-row-layout-wrap.service-hero,
    .kb-row-layout-wrap.service-hero > .kt-row-column-wrap {
      min-height: unset !important;
    }
  }

  /* Push hero content down on tablet only (not mobile) */
  @media (min-width: 768px) {
    .kb-row-layout-wrap.hero > .kt-row-column-wrap {
      padding-top: 250px !important;
    }
  }

  /* Generic reverse-on-tablet utility + commercial row */
  html body .kb-row-layout-wrap.reverse-on-tablet > .kt-row-column-wrap,
  html body .kb-row-layout-id249382_47440c-d5.kb-row-layout-wrap.stack-on-tablet.reverse-on-tablet > .kt-row-column-wrap,
  html body .kb-row-layout-id249382_47440c-d5.kb-row-layout-wrap.stack-on-tablet > .kt-row-column-wrap {
    display: flex !important;
    flex-direction: column-reverse !important;
  }
  html body .kb-row-layout-wrap.reverse-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column,
  html body .kb-row-layout-id249382_47440c-d5.kb-row-layout-wrap.stack-on-tablet.reverse-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column,
  html body .kb-row-layout-id249382_47440c-d5.kb-row-layout-wrap.stack-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column {
    width: 100% !important;
    max-width: 100% !important;
  }

  .site-main-header-wrap .site-header-row-container-inner>.site-container {
    padding: 0 var(--global-content-edge-padding)!important;
  }

  /* Frosted glass CTA — darker overlay on tablet (parallax scrolls less, image shows more) */
  .kb-row-layout-id249382_b29020-44 .kt-row-layout-overlay {
    opacity: 0.72 !important;
  }

  /* About section — overlapping image layout on tablet (html body raises specificity above inline <style>) */
  html body #about > .kt-row-column-wrap {
    display: block !important;
    min-height: unset !important;
    column-gap: 0 !important;
  }
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:first-child > .kt-inside-inner-col > .wp-block-kadence-column > .kt-inside-inner-col {
    min-height: unset !important;
    height: auto !important;
    display: block !important;
  }
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) {
    border-left: none !important;
    padding-left: 0 !important;
  }
  /* Image container — relatively positioned, fixed height for absolute children */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col {
    display: block !important;
    position: relative !important;
    height: 480px !important;
    min-height: unset !important;
    margin-top: 40px !important;
    overflow: visible !important;
  }
  /* Large image (:first-child) — right side, fills container so small image can centre on it */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:first-child {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: 68% !important;
    height: 100% !important;
    transform: none !important;
    z-index: 1 !important;
  }
  /* Small portrait (:nth-child(2)) — left side, vertically centred on large image */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    right: auto !important;
    bottom: 0 !important;
    margin-top: auto !important;
    margin-bottom: auto !important;
    transform: none !important;
    width: 40% !important;
    height: 75% !important;
    z-index: 2 !important;
  }
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 .wp-block-kadence-image figure,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 .wp-block-kadence-image .kb-is-ratio-image {
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    padding-bottom: 0 !important;
  }
  /* Large image — fills container with cover crop */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:first-child figure,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:first-child img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    aspect-ratio: unset !important;
    display: block !important;
  }
  /* Portrait — fill its fixed container with cover */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) figure,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) img,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column.kadence-column249382_116665-48 > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) .kb-is-ratio-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    aspect-ratio: unset !important;
    padding-bottom: 0 !important;
    display: block !important;
  }
}

/* Mobile-specific overrides — use grid to bypass Kadence's kt-mobile-layout-row flex rules */
@media (max-width: 767px) {
  html body .kb-row-layout-wrap.reverse-on-tablet > .kt-row-column-wrap,
  html body .kb-row-layout-id249382_47440c-d5 > .kt-row-column-wrap {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  /* Image column (last-child) appears first via order */
  html body .kb-row-layout-wrap.reverse-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column:last-child,
  html body .kb-row-layout-id249382_47440c-d5 > .kt-row-column-wrap > .wp-block-kadence-column:last-child {
    order: -1 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  html body .kb-row-layout-wrap.reverse-on-tablet > .kt-row-column-wrap > .wp-block-kadence-column:first-child,
  html body .kb-row-layout-id249382_47440c-d5 > .kt-row-column-wrap > .wp-block-kadence-column:first-child {
    width: 100% !important;
    max-width: 100% !important;
  }
  /* CTA section — left-align buttons */
  .kb-btns249382_5f7645-9e {
    justify-content: flex-start !important;
  }
  /* Footer nav — remove left border on column containers */
  html body .site-footer .kt-inside-inner-col,
  html body .site-footer .wp-block-kadence-column {
    border-left: none !important;
  }
  /* Footer nav — remove left border on nav link elements */
  html body .wp-block-kadence-navigation .kb-nav-link-content,
  html body .wp-block-kadence-navigation .kb-link-wrap,
  html body .kb-navigation li {
    border-left: none !important;
    padding-left: 0 !important;
  }
  /* Legal footer — stack columns, left-align everything */
  html body .kb-row-layout-id250143_012ec7-cd > .kt-row-column-wrap {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  html body .kb-row-layout-id250143_012ec7-cd .kt-inside-inner-col {
    justify-content: flex-start !important;
    align-items: center !important;
    text-align: left !important;
  }
  /* Legal nav — left-align links */
  html body .kb-row-layout-id250143_012ec7-cd .kb-navigation {
    justify-content: flex-start !important;
  }
  /* Remove Kadence-generated left border on footer column */
  html body .kadence-column250143_09949c-06 > .kt-inside-inner-col {
    border-left: none !important;
  }
}

@media (min-width: 768px) {
  .location-hero {
    max-width: 700px;
  }
}

/* ---- About section images — remove transforms on mobile to prevent content overlap ---- */
@media (max-width: 767px) {
  /* Container — tighter height on mobile, clip to prevent images bleeding over content above */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col {
    height: 360px !important;
    overflow: hidden !important;
  }

  /* Right image (first child) — fills container so left image can centre on it */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:first-child {
    width: 62% !important;
    height: 100% !important;
    bottom: 0 !important;
    transform: none !important;
    z-index: 1 !important;
  }

  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:first-child figure,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:first-child img {
    aspect-ratio: 3 / 4 !important;
    object-fit: cover !important;
    width: 100% !important;
    height: 100% !important;
  }

  /* Left image (second child) — vertically centred on right image, no float animation */
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) {
    width: 38% !important;
    height: 70% !important;
    top: 50% !important;
    bottom: auto !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    transform: translateY(-50%) !important;
    animation: none !important;
    opacity: 1 !important;
    transition: none !important;
    z-index: 3 !important;
  }

  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) figure,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) img,
  html body #about > .kt-row-column-wrap > .wp-block-kadence-column:nth-child(2) > .kt-inside-inner-col > .wp-block-kadence-image:nth-child(2) .kb-is-ratio-image {
    aspect-ratio: 2 / 3 !important;
    object-fit: cover !important;
    width: 100% !important;
    height: 100% !important;
    padding-bottom: 0 !important;
  }
}


/* Utility: align column content to the top without shrinking the column itself. */
.wp-block-kadence-column:has(.align-top) .kt-inside-inner-col {
  justify-content: flex-start !important;
}
