/* ============================================
   COMPONENTS
   Header, footer, nav, mega menu, dark mode
   toggle, drawer, mobile CTA, back-to-top,
   Gravity Forms.

   All values reference :root --zs-* tokens
   from style.css.
   ============================================ */


/* ============================================
   HEADER
   ============================================ */

/* ============================================
   HEADER - Base (shared across all nav styles)
   ============================================ */

.zs-site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--zs-z-header);
  pointer-events: none;
  background: transparent;
  transition: background var(--zs-transition-slow),
              box-shadow var(--zs-transition-slow),
              border-color var(--zs-transition-slow);
}

.zs-header-inner {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background var(--zs-transition-slow),
              box-shadow var(--zs-transition-slow),
              border-color var(--zs-transition-slow);
}


/* ============================================
   FLOATING-BAR (default) - Glass pill
   Background lives on .zs-header-inner (the pill).
   .zs-site-header stays transparent always.
   ============================================ */

.zs-header-inner {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: oklch(100% 0 0 / 0.85);
  border: var(--zs-border-width) solid oklch(0% 0 0 / 0.06);
  border-radius: var(--zs-nav-radius);
  margin: 14px auto 0;
  padding: 0 var(--zs-space-md) 0 clamp(20px, 3vw, 32px);
  max-width: min(calc(100% - clamp(32px, 6vw, 80px)), var(--zs-container));
  box-shadow: 0 4px 24px oklch(0% 0 0 / 0.06);
}

/* Scrolled: intensify the pill bg */
.zs-site-header.is-scrolled .zs-header-inner {
  background: oklch(100% 0 0 / 0.95);
  box-shadow: 0 4px 32px oklch(0% 0 0 / 0.08);
}

/* Dark mode floating-bar */
[data-theme="dark"] .zs-header-inner {
  background: oklch(0% 0 0 / 0.5);
  border-color: oklch(100% 0 0 / 0.08);
  box-shadow: 0 8px 32px oklch(0% 0 0 / 0.2);
}

[data-theme="dark"] .zs-site-header.is-scrolled .zs-header-inner {
  background: color-mix(in oklch, var(--zs-dark-bg) 90%, transparent);
}


/* ============================================
   FLUSH - Full-width bar
   Background lives on .zs-site-header.
   .zs-header-inner is just a layout container.
   ============================================ */

body.zs-nav-flush .zs-site-header {
  pointer-events: auto;
  background: var(--zs-bg);
  border-bottom: var(--zs-border-width) solid var(--zs-border-light);
}

body.zs-nav-flush .zs-header-inner {
  border-radius: 0;
  max-width: var(--zs-container);
  margin: 0 auto;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: transparent;
  padding: 0 clamp(20px, 4vw, 48px);
}

body.zs-nav-flush .zs-site-header.is-scrolled {
  box-shadow: var(--zs-shadow-sm);
}

body.zs-nav-flush[data-theme="dark"] .zs-site-header {
  background: var(--zs-dark-bg);
  border-bottom-color: oklch(100% 0 0 / 0.08);
}


/* ============================================
   MINIMAL - Borderless full-width
   Background lives on .zs-site-header.
   .zs-header-inner is just a layout container.
   ============================================ */

body.zs-nav-minimal .zs-site-header {
  pointer-events: auto;
  background: var(--zs-bg);
}

body.zs-nav-minimal .zs-header-inner {
  border-radius: 0;
  max-width: 100%;
  margin: 0;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: transparent;
  padding: 0 clamp(20px, 4vw, 48px);
}

body.zs-nav-minimal .zs-site-header.is-scrolled {
  background: oklch(100% 0 0 / 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--zs-shadow-sm);
}

body.zs-nav-minimal[data-theme="dark"] .zs-site-header {
  background: var(--zs-dark-bg);
}

body.zs-nav-minimal[data-theme="dark"] .zs-site-header.is-scrolled {
  background: color-mix(in oklch, var(--zs-dark-bg) 90%, transparent);
}


/* ============================================
   LOGO
   ============================================ */

.zs-logo,
.zs-logo-text {
  color: var(--zs-heading);
  font-family: var(--zs-font-heading);
  font-weight: var(--zs-font-weight-bold);
  font-size: var(--zs-text-xl);
  letter-spacing: var(--zs-tracking-tight);
  text-decoration: none;
}

.zs-logo img {
  max-height: 40px;
  width: auto;
}

/* Light/dark logo variants */
.zs-logo--dark { display: none; }
[data-theme="dark"] .zs-logo--light { display: none; }
[data-theme="dark"] .zs-logo--dark { display: block; }

.zs-logo img.zs-logo-img {
}


/* ============================================
   NAVIGATION
   ============================================ */

.zs-nav { 
  background: transparent;
  margin-inline: auto;
 }

.zs-nav .zs-nav-list {
  display: flex;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0;
}

/* Nav links */
.zs-nav .zs-nav-list > li > a {
  color: var(--zs-text-muted);
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-xs);
  font-weight: var(--zs-font-weight-medium);
  letter-spacing: var(--zs-tracking-wide);
  text-transform: uppercase;
  padding: 1rem clamp(0.6rem, 1.2vw, 1rem);
  line-height: 56px;
  padding-block: 1rem;
  transition: color var(--zs-transition-base);
  position: relative;
  text-decoration: none;
}

.zs-nav .zs-nav-list > li > a:hover,
.zs-nav .zs-nav-list > li:hover > a {
  color: var(--zs-heading);
  background: transparent;
}

/* Active page dot */
.zs-nav .zs-nav-list > li.current-menu-item > a,
.zs-nav .zs-nav-list > li.current-menu-ancestor > a {
  color: var(--zs-heading);
}

/* .zs-nav .zs-nav-list > li.current-menu-item > a::after,
.zs-nav .zs-nav-list > li.current-menu-ancestor > a::after {
  content: '';
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background: var(--zs-heading);
  border-radius: 50%;
} */

/* Nav underline reveal from center.
   v5.8.0 - Scoped with body:not(.zs-nav-no-underline) so child themes that
   render their own hover indicator (typically via ::after) can opt out of the
   parent's ::before to avoid double-underline. Child themes opt out with:
     add_filter('body_class', fn($c) => array_merge($c, ['zs-nav-no-underline'])); */
body:not(.zs-nav-no-underline) .zs-nav .zs-nav-list > li:not(.zs-nav-cta-wrap):not(.zs-theme-toggle-wrap) > a::before {
  content: '';
  position: absolute;
  bottom: 10px;
  left: 50%;
  right: 50%;
  height: 1px;
  background: var(--zs-accent);
  transition: left var(--zs-transition-fast), right var(--zs-transition-fast);
}

body:not(.zs-nav-no-underline) .zs-nav .zs-nav-list > li:not(.zs-nav-cta-wrap):not(.zs-theme-toggle-wrap) > a:hover::before {
  left: 20%;
  right: 20%;
}

/* Dropdown menus */
.zs-nav .zs-nav-list ul {
  background: var(--zs-card-bg);
  backdrop-filter: blur(20px);
  border: var(--zs-border-width) solid var(--zs-border-light);
  border-radius: var(--zs-radius-lg);
  padding: var(--zs-space-sm) 0;
  box-shadow: var(--zs-shadow-xl);
  list-style: none;
  position: absolute;
  min-width: 200px;
  display: none;
  z-index: var(--zs-z-dropdown);
}

.zs-nav .zs-nav-list > li:hover > ul { display: block; }

.zs-nav .zs-nav-list ul li a {
  text-transform: none;
  font-size: var(--zs-text-sm);
  padding: 0.6rem 1.25rem;
  line-height: var(--zs-leading-snug);
  display: block;
  color: var(--zs-text-secondary);
  transition: color var(--zs-transition-fast);
}

.zs-nav .zs-nav-list ul li a:hover {
  color: var(--zs-heading);
}

/* Dropdown caret */
.zs-nav .dropdown-toggle {
  padding: 0 0.3rem;
  margin-left: -0.25rem;
}

.zs-nav .dropdown-toggle svg {
  width: 0.7em;
  height: 0.7em;
}

/* No borders on nav containers */
.zs-nav,
.zs-nav .zs-nav-list ul {
  border-top: none;
  border-bottom: none;
}

/* Hide active dot on dropdown items */
.zs-nav .zs-nav-list > li.menu-item-has-children.current-menu-ancestor > a::after {
  display: none;
}


/* ============================================
   NAV CTA BUTTON
   ============================================ */

.zs-nav-cta {
}

.zs-nav-cta a {
  background: var(--zs-heading) !important;
  color: var(--zs-bg) !important;
  border-radius: var(--zs-btn-radius);
  padding: 0.6rem 1.6rem !important;
  font-weight: var(--zs-font-weight-bold);
  font-size: var(--zs-text-xs);
  letter-spacing: var(--zs-tracking-wide);
  transition: all var(--zs-transition-base);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  text-decoration: none;
}

.zs-nav-cta a:hover {
  opacity: 0.85;
  transform: translateY(-1px);
}

/* Hide active dot on CTA */
.zs-nav .zs-nav-list > li.zs-nav-cta-wrap > a::after { display: none; }


/* ============================================
   DARK MODE TOGGLE
   ============================================ */

.zs-theme-toggle {
  background: none;
  border: var(--zs-border-width) solid var(--zs-border);
  border-radius: var(--zs-pill);
  color: var(--zs-text-muted);
  cursor: pointer;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: var(--zs-space-sm);
  transition: all var(--zs-transition-base);
  flex-shrink: 0;
  padding: 0;
}

.zs-theme-toggle:hover {
  border-color: var(--zs-text-secondary);
  color: var(--zs-heading);
  background: oklch(0% 0 0 / 0.03);
}

.zs-theme-toggle .zs-icon-sun  { display: none; }
.zs-theme-toggle .zs-icon-moon { display: inline; }
[data-theme="dark"] .zs-theme-toggle .zs-icon-sun  { display: inline; }
[data-theme="dark"] .zs-theme-toggle .zs-icon-moon { display: none; }

.zs-theme-toggle-wrap {
  display: flex;
  align-items: center;
}


/* ============================================
   HAMBURGER / MENU TOGGLE
   ============================================ */

.zs-menu-toggle {
  color: var(--zs-heading);
  background: none;
  border: none;
  padding: var(--zs-space-sm);
  cursor: pointer;
  display: none;
}

.zs-menu-toggle svg {
  width: 24px;
  height: 24px;
  fill: var(--zs-heading);
}

@media (max-width: 768px) {
  .zs-menu-toggle { display: flex; align-items: center; }
  .zs-nav-cta { display: none; }
  .zs-header-inner > .zs-theme-toggle { display: none; }

  /* Drawer - always positioned off-screen, slides in via transform */
  .zs-nav {
    display: block !important;
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: min(85vw, 340px) !important;
    height: 100vh !important;
    height: 100dvh !important;
    background: var(--zs-bg) !important;
    border-left: var(--zs-border-width) solid var(--zs-border-light);
    padding: var(--zs-space-xl) !important;
    z-index: var(--zs-z-drawer);
    overflow-y: auto;
    box-shadow: -12px 0 48px oklch(0% 0 0 / 0.3);
    transform: translateX(100%);
    visibility: hidden;
    transition: transform 0.3s var(--zs-ease-out), visibility 0s 0.3s;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .zs-nav.zs-drawer-open {
    transform: translateX(0) !important;
    visibility: visible;
    transition: transform 0.3s var(--zs-ease-out), visibility 0s 0s;
  }
}


/* ============================================
   MOBILE DRAWER - Content Styles
   ============================================ */

/* Hide header logo + hamburger when drawer is open (mobile only) */
@media (max-width: 768px) {
  body.zs-drawer-open .zs-header-inner > a.zs-logo,
  body.zs-drawer-open .zs-menu-toggle {
    display: none;
  }
}

.zs-nav.zs-drawer-open {
  display: flex !important;
  flex-direction: column;
  padding-bottom: 5rem !important;
  padding-top: 1rem !important;
}

.zs-nav.zs-drawer-open .zs-nav-list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  padding: 0;
  gap: 0;
  list-style: none;
  margin: 0;
}

.zs-nav.zs-drawer-open .zs-nav-list > li { width: 100%; }

.zs-nav.zs-drawer-open .zs-nav-list > li > a {
  font-family: var(--zs-font-heading);
  font-size: var(--zs-text-xl);
  font-weight: var(--zs-font-weight-bold);
  color: var(--zs-text-secondary);
  text-transform: none;
  letter-spacing: var(--zs-tracking-normal);
  line-height: var(--zs-leading-snug);
  padding: 1rem 0;
  display: block;
  border: none;
  border-radius: 0;
  transition: color var(--zs-transition-fast), padding-left var(--zs-transition-fast);
}

.zs-nav.zs-drawer-open .zs-nav-list > li:last-child > a {
  border-bottom: none;
}

.zs-nav.zs-drawer-open .zs-nav-list > li > a:hover {
  color: var(--zs-heading);
  background: transparent;
  padding-left: var(--zs-space-sm);
}

/* Mobile: hover line from left edge (also gated by zs-nav-no-underline opt-out) */
body:not(.zs-nav-no-underline) .zs-nav.zs-drawer-open .zs-nav-list > li:not(.zs-nav-cta-wrap):not(.zs-theme-toggle-wrap) > a::before {
  left: 0%;
  right: 100%;
  bottom: 4px;
  background: oklch(70% 0.01 250);
}
body:not(.zs-nav-no-underline) .zs-nav.zs-drawer-open .zs-nav-list > li:not(.zs-nav-cta-wrap):not(.zs-theme-toggle-wrap) > a:hover::before {
  left: 0%;
  right: 60%;
}

/* Mobile submenu - collapsed by default, toggles on click */
@media (max-width: 768px) {
  .zs-nav.zs-drawer-open .zs-nav-list .sub-menu {
    position: static !important;
    display: none;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    padding: 0 0 var(--zs-space-sm) 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    list-style: none;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .zs-nav.zs-drawer-open .zs-nav-list .sub-menu.zs-submenu-open {
    display: block !important;
  }

  .zs-nav.zs-drawer-open .zs-nav-list .sub-menu li a {
    font-family: var(--zs-font-body) !important;
    font-size: var(--zs-text-base) !important;
    font-weight: var(--zs-font-weight-medium) !important;
    /* v5.8.0 - #45: tier-2 sub-nav items now indent by 1.5rem so the drawer
       hierarchy reads visually. Previously flush with tier-1 labels. */
    padding: var(--zs-space-sm) 0 var(--zs-space-sm) var(--zs-space-lg) !important;
    color: var(--zs-text-muted) !important;
    border-bottom: none !important;
    line-height: var(--zs-leading-normal) !important;
  }

  .zs-nav.zs-drawer-open .zs-nav-list .sub-menu li a:hover {
    color: var(--zs-heading) !important;
  }
}

/* Chevron toggle - only visible in mobile drawer */
.zs-drawer-chevron {
  display: none;
}

@media (max-width: 768px) {
  /* Parent item row: link + chevron side by side */
  .zs-nav.zs-drawer-open .menu-item-has-children {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }

  .zs-nav.zs-drawer-open .menu-item-has-children > a {
    flex: 1;
  }

  .zs-nav.zs-drawer-open .zs-drawer-chevron {
    display: flex;
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--zs-text-muted);
    transition: transform var(--zs-transition-fast), color var(--zs-transition-fast);
    padding: 0;
  }

  .zs-nav.zs-drawer-open .zs-drawer-chevron:hover {
    color: var(--zs-heading);
  }

  .zs-drawer-chevron.zs-chevron-open {
    transform: rotate(180deg);
  }

  /* Sub-menu takes full width below the parent row */
  .zs-nav.zs-drawer-open .menu-item-has-children > .sub-menu {
    width: 100%;
  }
}

/* Active state in drawer */
.zs-nav.zs-drawer-open .zs-nav-list > li.current-menu-item > a,
.zs-nav.zs-drawer-open .zs-nav-list > li.current-menu-ancestor > a {
  color: var(--zs-heading);
}

/* Hide active dot in drawer */
.zs-nav.zs-drawer-open .zs-nav-list > li > a::after { display: none; }

/* CTA in drawer */
.zs-nav.zs-drawer-open .zs-nav-list > li.zs-nav-cta-wrap > a {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--zs-tracking-wide);
  background: oklch(95% 0 0);
  color: var(--zs-dark-bg);
  border-radius: var(--zs-btn-radius);
  padding: 0.85rem 2.5rem;
  margin-top: var(--zs-space-lg);
  display: inline-block;
  line-height: 1.2;
}

/* Dark mode toggle in drawer */
.zs-nav.zs-drawer-open .zs-theme-toggle-wrap {
  margin-top: var(--zs-space-lg);
  display: flex;
  width: 100%;
}

.zs-nav.zs-drawer-open .zs-theme-toggle {
  width: 44px;
  height: 44px;
}

/* Drawer elements - hidden on desktop */
.zs-drawer-close,
.zs-drawer-footer,
.zs-drawer-backdrop {
  display: none !important;
}

@media (max-width: 768px) {
  .zs-drawer-close { display: flex !important; }
  .zs-nav.zs-drawer-open .zs-drawer-footer { display: block !important; }
  .zs-drawer-backdrop[style*="block"] { display: block !important; z-index: 10;}
}

/* Drawer close button */
.zs-drawer-close {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 10;
  background: oklch(25% 0.01 250);
  border: 1px solid oklch(30% 0.01 250);
  color: oklch(70% 0.01 250);
  cursor: pointer;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: color var(--zs-transition-fast),
              background var(--zs-transition-fast),
              border-color var(--zs-transition-fast);
}

.zs-drawer-close:hover {
  color: oklch(95% 0 0);
  background: oklch(30% 0.01 250);
  border-color: oklch(40% 0.01 250);
}

.zs-drawer-close svg { width: 20px; height: 20px; }

/* Drawer header - logo + close button */
.zs-drawer-header {
  display: none;
}

@media (max-width: 768px) {
  .zs-drawer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--zs-space-xl);
    padding-bottom: var(--zs-space-lg);
    border-bottom: var(--zs-border-width) solid var(--zs-border-light);
  }

  .zs-drawer-logo {
    display: block;
    text-decoration: none;
  }

  .zs-drawer-logo img {
    max-height: 36px;
    width: auto;
  }

  .zs-drawer-logo .zs-logo-text {
    font-size: var(--zs-text-lg);
  }

  /* Close button is now inside the drawer header, not absolute */
  .zs-drawer-close {
    position: static !important;
  }
}

[data-theme="dark"] .zs-drawer-header {
  border-bottom-color: var(--zs-border);
}

/* Drawer footer - phone, CTA, dark mode toggle */
.zs-drawer-footer {
  margin-top: auto;
  padding-top: var(--zs-space-xl);
  border-top: var(--zs-border-width) solid var(--zs-border-light);
}

.zs-drawer-footer__phone {
  font-family: var(--zs-font-heading);
  font-size: var(--zs-text-lg);
  font-weight: var(--zs-font-weight-bold);
  color: var(--zs-heading);
  display: block;
  margin-bottom: var(--zs-space-xs);
  text-decoration: none;
}

.zs-drawer-footer__cta {
  display: block;
  background: oklch(95% 0 0);
  color: var(--zs-dark-bg);
  text-align: center;
  padding: 0.85rem var(--zs-space-xl);
  border-radius: var(--zs-btn-radius);
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--zs-tracking-wide);
  margin-top: var(--zs-space-md);
  text-decoration: none;
  transition: background var(--zs-transition-fast);
}

.zs-drawer-footer__cta:hover {
  background: oklch(85% 0 0);
}

.zs-drawer-footer__toggle {
  display: flex;
  align-items: center;
  gap: var(--zs-space-sm);
  margin-top: var(--zs-space-lg);
  padding-top: var(--zs-space-md);
  border-top: 1px solid oklch(30% 0.01 250);
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-sm);
  color: oklch(55% 0.01 250);
}

.zs-drawer-footer__toggle .zs-theme-toggle {
  display: inline-flex;
  width: 40px;
  height: 40px;
  color: oklch(70% 0.01 250);
}

/* Drawer backdrop - sits on body, covers all page content */
.zs-drawer-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  background: oklch(0% 0 0 / 0.4);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: var(--zs-z-overlay);
  cursor: pointer;
}

/* Prevent body scroll when drawer open */
body.zs-drawer-open { overflow: hidden; }

/* Dark mode drawer */
[data-theme="dark"] .zs-nav {
  border-left-color: var(--zs-border) !important;
}

[data-theme="dark"] .zs-drawer-close {
  color: var(--zs-text-muted);
}

[data-theme="dark"] .zs-drawer-close:hover {
  color: var(--zs-text);
  background: oklch(100% 0 0 / 0.05);
  border-color: var(--zs-border);
}

[data-theme="dark"] .zs-nav.zs-drawer-open .zs-nav-list > li > a {
  color: var(--zs-text-muted);
}

[data-theme="dark"] .zs-nav.zs-drawer-open .zs-nav-list > li > a:hover {
  color: var(--zs-text);
}

[data-theme="dark"] .zs-nav.zs-drawer-open .zs-nav-list > li.current-menu-item > a,
[data-theme="dark"] .zs-nav.zs-drawer-open .zs-nav-list > li.current-menu-ancestor > a {
  color: var(--zs-accent);
}

[data-theme="dark"] .zs-drawer-footer {
  border-top-color: var(--zs-border);
}

[data-theme="dark"] .zs-drawer-footer__phone {
  color: var(--zs-text);
}

[data-theme="dark"] .zs-drawer-footer__cta {
  background: var(--zs-accent);
  color: var(--zs-dark-bg);
}

[data-theme="dark"] .zs-drawer-footer__toggle {
  border-top-color: var(--zs-border);
  color: var(--zs-text-muted);
}

[data-theme="dark"] .zs-drawer-backdrop {
  background: var(--zs-overlay-heavy);
}

/* Elevate header when drawer open */
body.zs-drawer-open .zs-site-header {
  z-index: calc(var(--zs-z-overlay) + 1);
  pointer-events: auto;
}

/* When drawer open, break header out of pill */
body.zs-drawer-open .zs-header-inner {
  border-radius: 0;
  max-width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none;
}


/* ============================================
   MEGA MENU
   ============================================ */

/* Hide standard sub-menu when mega is active */
.zs-has-mega > .sub-menu { display: none !important; }
.zs-nav-list li.zs-has-mega { position: static; }

/* Mega panel - full width of header bar */
.zs-mega-panel {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  background: var(--zs-card-bg);
  border: var(--zs-border-width) solid var(--zs-border-light);
  border-top: none;
  border-radius: 0 0 var(--zs-radius-lg) var(--zs-radius-lg);
  box-shadow: var(--zs-shadow-xl);
  padding: var(--zs-space-xl) clamp(20px, 3vw, 32px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--zs-transition-base), transform var(--zs-transition-base), visibility 0s 0.25s;
  z-index: var(--zs-z-dropdown);
}

.zs-has-mega:hover > .zs-mega-panel,
.zs-has-mega:focus-within > .zs-mega-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity var(--zs-transition-base), transform var(--zs-transition-base), visibility 0s 0s;
}

/* Remove bottom radius when mega is open */
.zs-header-inner:has(.zs-has-mega:hover) {
  border-radius: var(--zs-nav-radius) var(--zs-nav-radius) 0 0;
}

.zs-mega-panel__inner {
  display: flex;
  gap: var(--zs-space-xl);
  text-transform: none;
  letter-spacing: 0;
  font-weight: var(--zs-font-weight-normal);
}

/* ── Icon Grid Style ── */
.zs-mega-panel--icon-grid .zs-mega-panel__inner { display: block; }

.zs-mega-panel--icon-grid .zs-mega-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--zs-space-sm);
}

.zs-mega-panel--icon-grid .zs-mega-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--zs-space-lg) var(--zs-space-md);
  border-radius: var(--zs-radius);
  text-decoration: none;
  transition: background var(--zs-transition-fast);
}

.zs-mega-panel--icon-grid .zs-mega-card:hover {
  background: var(--zs-bg-alt);
}

.zs-mega-card__icon {
  font-size: var(--zs-text-2xl);
  margin-bottom: var(--zs-space-sm);
  line-height: 1;
}

.zs-mega-card__label {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-semibold);
  color: var(--zs-heading);
  text-transform: none;
  letter-spacing: 0;
}

.zs-mega-card__desc {
  font-size: var(--zs-text-xs);
  color: var(--zs-text-muted);
  margin-top: var(--zs-space-xs);
  line-height: 1.4;
  text-transform: none;
  letter-spacing: 0;
  font-weight: var(--zs-font-weight-normal);
}

/* ── Image Grid Style ── */
.zs-mega-panel--image-grid .zs-mega-panel__inner { display: block; }

.zs-mega-panel--image-grid .zs-mega-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--zs-space-sm);
}

.zs-mega-panel--image-grid .zs-mega-card {
  position: relative;
  border-radius: var(--zs-radius);
  overflow: hidden;
  aspect-ratio: 4/3;
  display: flex;
  align-items: flex-end;
  text-decoration: none;
}

.zs-mega-panel--image-grid .zs-mega-card__image {
  position: absolute;
  inset: 0;
}

.zs-mega-panel--image-grid .zs-mega-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--zs-transition-base);
}

.zs-mega-panel--image-grid .zs-mega-card:hover .zs-mega-card__img {
  transform: scale(1.05);
}

.zs-mega-panel--image-grid .zs-mega-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--zs-overlay-heavy), transparent);
  pointer-events: none;
}

.zs-mega-panel--image-grid .zs-mega-card__label {
  position: relative;
  z-index: 1;
  color: #fff;
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-bold);
  padding: var(--zs-space-sm);
}

/* ── Multi-Column Style ── */
.zs-mega-panel--multi-column .zs-mega-panel__inner {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--zs-space-xl);
  align-items: start;
}

.zs-mega-featured { border-radius: var(--zs-radius); overflow: hidden; }

.zs-mega-featured__image {
  border-radius: var(--zs-radius);
  overflow: hidden;
  margin-bottom: var(--zs-space-sm);
}

.zs-mega-featured__img {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.zs-mega-featured__heading {
  font-family: var(--zs-font-heading);
  font-size: var(--zs-text-md);
  font-weight: var(--zs-font-weight-bold);
  color: var(--zs-heading);
  margin: 0 0 var(--zs-space-sm);
  text-transform: none;
  letter-spacing: var(--zs-tracking-tight);
}

.zs-mega-featured__cta {
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-semibold);
  color: var(--zs-accent);
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
}

.zs-mega-featured__cta:hover { opacity: 0.7; }

.zs-mega-links {
  display: flex;
  flex-direction: column;
  gap: var(--zs-space-xs);
}

.zs-mega-link {
  display: flex;
  align-items: center;
  gap: var(--zs-space-sm);
  padding: var(--zs-space-sm) var(--zs-space-sm);
  border-radius: var(--zs-radius);
  text-decoration: none;
  transition: background var(--zs-transition-fast);
}

.zs-mega-link:hover { background: var(--zs-bg-alt); }

.zs-mega-link__icon {
  font-size: var(--zs-text-lg);
  flex-shrink: 0;
  width: 2rem;
  text-align: center;
}

.zs-mega-link__text { display: flex; flex-direction: column; }

.zs-mega-link__label {
  font-size: var(--zs-text-sm);
  font-weight: var(--zs-font-weight-semibold);
  color: var(--zs-heading);
  text-transform: none;
  letter-spacing: 0;
}

.zs-mega-link__desc {
  font-size: var(--zs-text-xs);
  color: var(--zs-text-muted);
  line-height: 1.4;
  text-transform: none;
  letter-spacing: 0;
  font-weight: var(--zs-font-weight-normal);
}

/* Dark mode mega menu */
[data-theme="dark"] .zs-mega-panel {
  background: var(--zs-card-bg);
  border-color: var(--zs-border);
  box-shadow: var(--zs-shadow-xl);
}

/* Site overlay - glass effect */
.zs-mega-overlay {
  position: fixed;
  inset: 0;
  background: var(--zs-overlay-light);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 98;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--zs-transition-base), visibility 0s 0.3s;
  pointer-events: none;
}

/* Mobile: hide mega panels */
@media (max-width: 768px) {
  .zs-mega-panel { display: none !important; }
  .zs-mega-overlay { display: none !important; }
}


/* ============================================
   FOOTER
   ============================================ */

.zs-footer {
  background: var(--zs-dark-bg);
  /* v5.8.9 — bumped 0.6 → 0.78 to match .zs-footer a alpha so plain body
     text in the footer (tagline, address, hours block, etc.) clears
     WCAG AA 4.5:1 against --zs-dark-bg. Axe flagged 0.6 at 4.13:1. */
  color: oklch(100% 0 0 / 0.78);
  padding: var(--zs-space-3xl) var(--zs-container-padding) var(--zs-space-lg);
}

.zs-footer-inner {
  max-width: var(--zs-container);
  margin: 0 auto;
}

.zs-footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--zs-space-xl);
  margin-bottom: var(--zs-space-xl);
}

@media (max-width: 768px) {
  .zs-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--zs-space-xl);
  }
}

@media (max-width: 480px) {
  .zs-footer-grid {
    grid-template-columns: 1fr;
    gap: var(--zs-space-lg);
  }
}

.zs-footer-brand__name {
  font-family: var(--zs-font-heading);
  font-weight: var(--zs-font-weight-bold);
  font-style: italic;
  font-size: var(--zs-text-xl);
  color: #fff;
  display: block;
  margin-bottom: var(--zs-space-sm);
}

.zs-footer-brand__tagline {
  font-size: var(--zs-text-sm);
  /* v5.8.9 — was 0.5 alpha (~3.5:1, fails AA). Bumped to 0.78 to clear
     4.5:1 against --zs-dark-bg. */
  color: oklch(100% 0 0 / 0.78);
  margin: 0 0 var(--zs-space-md);
}

.zs-footer-socials {
  display: flex;
  gap: 0.75rem;
  margin-top: var(--zs-space-md);
}

.zs-footer-socials a {
  color: oklch(100% 0 0 / 0.5);
  transition: color var(--zs-transition-fast), transform var(--zs-transition-fast);
}

.zs-footer-socials a:hover {
  color: #fff;
  transform: translateY(-2px);
}

.zs-footer-brand__hours {
  margin-top: var(--zs-space-lg);
}

.zs-footer-brand__hours-heading {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-xs);
  font-weight: var(--zs-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--zs-tracking-wide);
  color: oklch(100% 0 0 / 0.8);
  margin: 0 0 var(--zs-space-sm);
}

.zs-footer-brand__hours-body {
  font-size: var(--zs-text-sm);
  color: oklch(100% 0 0 / 0.5);
  line-height: 1.6;
}

.zs-footer-brand__hours-body p {
  margin: 0 0 0.25rem;
}

.zs-footer-col__heading {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-xs);
  font-weight: var(--zs-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--zs-tracking-wide);
  color: oklch(100% 0 0 / 0.5);
  margin-bottom: 0.75rem;
}

.zs-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.zs-footer ul li { margin-bottom: 0.4rem; }

.zs-footer a {
  /* v5.8.0 - #25: was 0.6 alpha (~3.82:1 contrast on dark footer - fails AA
     which needs 4.5:1 for normal text). Bumped to 0.78 to clear the threshold. */
  color: oklch(100% 0 0 / 0.78);
  text-decoration: none;
  font-size: var(--zs-text-sm);
  transition: color var(--zs-transition-fast);
}

.zs-footer a:hover { color: #fff; }

/* v5.8.0 - #25: plain list text (not links) in footer columns needs the same
   contrast bump. */
.zs-footer ul li {
  color: oklch(100% 0 0 / 0.78);
}

.zs-footer-address {
  font-size: var(--zs-text-sm);
  /* v5.8.0 - #25: bumped from 0.4 alpha (~2.4:1 - fails even 3:1 large-text)
     to 0.78 so addresses are clearly readable. */
  color: oklch(100% 0 0 / 0.78);
  line-height: var(--zs-leading-snug);
}

/* v5.8.0 - #26: `<strong>` labels inside address blocks (e.g. "Address:",
   "Hours:") inherit color: var(--zs-text) which in dark-footer contexts is
   near-black on near-black - effectively invisible (~1.02:1). Force them to
   the same readable white-alpha as the surrounding address text. */
.zs-footer-address strong,
.zs-footer-brand__hours strong,
.zs-footer strong {
  color: #fff;
  font-weight: var(--zs-font-weight-semibold);
}

/* Footer bottom bar */
.zs-footer-bottom {
  border-top: 1px solid oklch(100% 0 0 / 0.08);
  padding-top: 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--zs-space-md);
  flex-wrap: wrap;
  gap: var(--zs-space-sm);
}

.zs-footer-copyright {
  font-size: var(--zs-text-xs);
  /* v5.8.9 — was 0.6 alpha (~4.13:1, fails AA for small text which needs
     4.5:1). Bumped to 0.78. */
  color: oklch(100% 0 0 / 0.78);
  margin: 0;
}

/* Zealous Growth badge */
a.zs-zg-badge,
.zs-zg-badge {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-xs);
  color: oklch(100% 0 0 / 0.55);
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: color var(--zs-transition-fast);
}

a.zs-zg-badge:hover { color: oklch(100% 0 0 / 0.7); }

.zs-zg-name {
  font-family: 'Satoshi', var(--zs-font-body);
  font-weight: var(--zs-font-weight-bold);
  color: oklch(100% 0 0 / 0.65);
}

/* Built with love tag */
.zs-built-with-love {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-xs);
  color: oklch(100% 0 0 / 0.45);
  letter-spacing: 0.01em;
}

.zs-heart {
  color: oklch(60% 0.2 15);
}

.zs-zg-dot {
  color: #e8612d;
  font-family: 'Satoshi', var(--zs-font-body);
  font-weight: var(--zs-font-weight-bold);
}

/* Hide GP empty copyright bar */
.inside-site-info { display: none; }


/* ============================================
   ANNOUNCEMENT TOP BAR
   ============================================ */

.zs-topbar {
  background: var(--zs-dark-bg);
  color: oklch(100% 0 0 / 0.9);
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-sm);
  letter-spacing: var(--zs-tracking-wide);
  text-align: center;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.zs-topbar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--zs-space-sm);
  padding: var(--zs-space-sm) var(--zs-container-padding);
  flex-wrap: wrap;
}

.zs-topbar__message {
  font-weight: var(--zs-font-weight-medium);
}

.zs-topbar__link {
  color: var(--zs-accent);
  font-weight: var(--zs-font-weight-bold);
  text-decoration: underline;
  text-underline-offset: 0.15em;
  white-space: nowrap;
}

.zs-topbar__link:hover {
  opacity: 0.85;
}

.zs-topbar__dismiss {
  background: none;
  border: none;
  color: oklch(100% 0 0 / 0.5);
  font-size: 1.25rem;
  cursor: pointer;
  padding: 0 var(--zs-space-xs);
  line-height: 1;
  margin-left: var(--zs-space-sm);
  transition: color var(--zs-transition-fast);
}

.zs-topbar__dismiss:hover {
  color: oklch(100% 0 0 / 0.9);
}

[data-theme="dark"] .zs-topbar {
  background: oklch(10% 0 0);
  border-bottom: 1px solid oklch(100% 0 0 / 0.06);
}

@media (max-width: 768px) {
  .zs-topbar__inner {
    font-size: var(--zs-text-xs);
  }
}


/* ============================================
   EXIT-INTENT POPUP
   ============================================ */

.zs-exit-popup {
  position: fixed;
  inset: 0;
  background: oklch(0% 0 0 / 0.65);
  z-index: 10001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--zs-space-xl);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0s 0.3s;
}

.zs-exit-popup.is-open {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.3s ease, visibility 0s 0s;
}

.zs-exit-popup__box {
  background: var(--zs-bg);
  max-width: 480px;
  width: 100%;
  padding: var(--zs-space-2xl);
  border-radius: var(--zs-radius-lg);
  text-align: center;
  position: relative;
  border-top: 4px solid var(--zs-accent);
  box-shadow: 0 24px 64px oklch(0% 0 0 / 0.25);
  transform: scale(0.92) translateY(10px);
  transition: transform 0.3s var(--zs-ease-out);
}

.zs-exit-popup.is-open .zs-exit-popup__box {
  transform: scale(1) translateY(0);
}

.zs-exit-popup__close {
  position: absolute;
  top: var(--zs-space-sm);
  right: var(--zs-space-sm);
  background: transparent;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--zs-text-muted);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background var(--zs-transition-fast), color var(--zs-transition-fast);
}

.zs-exit-popup__close:hover {
  background: var(--zs-bg-alt);
  color: var(--zs-heading);
}

.zs-exit-popup__heading {
  font-family: var(--zs-font-heading);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--zs-font-weight-bold);
  color: var(--zs-heading);
  line-height: var(--zs-leading-snug);
  margin-bottom: var(--zs-space-sm);
}

.zs-exit-popup__text {
  font-size: var(--zs-text-base);
  color: var(--zs-text-secondary);
  line-height: var(--zs-leading-normal);
  margin-bottom: var(--zs-space-xl);
}

.zs-exit-popup__actions {
  display: flex;
  gap: var(--zs-space-sm);
  justify-content: center;
  flex-wrap: wrap;
}

/* Dark mode */
[data-theme="dark"] .zs-exit-popup__box {
  background: var(--zs-card-bg);
  box-shadow: 0 24px 64px oklch(0% 0 0 / 0.5);
}

[data-theme="dark"] .zs-exit-popup__close:hover {
  background: oklch(100% 0 0 / 0.08);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .zs-exit-popup,
  .zs-exit-popup__box {
    transition: none;
  }
}


/* ============================================
   MOBILE CTA BAR
   ============================================ */

.zs-mobile-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--zs-z-sticky);
  background: var(--zs-bg);
  border-top: var(--zs-border-width) solid var(--zs-border-light);
  padding: var(--zs-space-sm) var(--zs-container-padding);
  box-shadow: 0 -4px 20px oklch(0% 0 0 / 0.08);
  display: none;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

@media (max-width: 768px) {
  .zs-mobile-cta {
    display: flex;
    flex-direction: row;
    gap: var(--zs-space-sm);
    align-items: center;
  }
}

.zs-mobile-cta a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--zs-space-xs);
  font-family: var(--zs-font-body);
  font-weight: var(--zs-font-weight-bold);
  font-size: var(--zs-text-sm);
  letter-spacing: var(--zs-tracking-wide);
  text-transform: uppercase;
  padding: 0.75rem var(--zs-space-lg);
  border-radius: var(--zs-btn-radius);
  text-decoration: none;
  transition: all var(--zs-transition-base);
  white-space: nowrap;
}

.zs-mobile-cta__phone {
  flex: 0 0 auto;
  background: transparent;
  color: var(--zs-heading);
  border: var(--zs-border-width) solid var(--zs-border);
}

.zs-mobile-cta__phone svg {
  flex-shrink: 0;
}

.zs-mobile-cta__btn {
  flex: 1;
  background: var(--zs-accent);
  color: var(--zs-bg);
}

.zs-mobile-cta a:hover { opacity: 0.85; }

[data-theme="dark"] .zs-mobile-cta {
  background: var(--zs-dark-bg);
  border-top-color: oklch(100% 0 0 / 0.08);
}

[data-theme="dark"] .zs-mobile-cta__phone {
  color: oklch(100% 0 0 / 0.9);
  border-color: oklch(100% 0 0 / 0.15);
}

[data-theme="dark"] .zs-mobile-cta__btn {
  background: var(--zs-accent);
  color: var(--zs-dark-bg);
}


/* ============================================
   GRAVITY FORMS BASE STYLES
   ============================================ */

.gform_wrapper input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.gform_wrapper select,
.gform_wrapper textarea {
  border: var(--zs-border-width) solid var(--zs-border) !important;
  border-radius: var(--zs-radius) !important;
  padding: 0.75rem 1rem !important;
  font-family: var(--zs-font-body) !important;
  font-size: var(--zs-text-base) !important;
  color: var(--zs-text) !important;
  background: var(--zs-bg) !important;
  width: 100% !important;
  transition: border-color var(--zs-transition-fast), box-shadow var(--zs-transition-fast);
}

.gform_wrapper input:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus {
  border-color: var(--zs-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px oklch(from var(--zs-accent) l c h / 0.12) !important;
}

.gform_wrapper .gfield {
  margin-bottom: var(--zs-space-lg) !important;
}

.gform_wrapper .gfield_label {
  font-family: var(--zs-font-body) !important;
  font-size: var(--zs-text-sm) !important;
  font-weight: var(--zs-font-weight-semibold) !important;
  color: var(--zs-heading) !important;
  margin-bottom: var(--zs-space-xs) !important;
  display: block;
}

.gform_wrapper .gfield_required {
  color: var(--zs-accent) !important;
}

.gform_wrapper textarea {
  min-height: 140px !important;
  resize: vertical !important;
}

.gform_wrapper .gform_button,
.gform_wrapper input[type="submit"] {
  background: var(--zs-accent) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--zs-btn-radius) !important;
  padding: 0.85rem 2rem !important;
  font-family: var(--zs-font-body) !important;
  font-size: var(--zs-text-sm) !important;
  font-weight: var(--zs-font-weight-bold) !important;
  letter-spacing: var(--zs-tracking-wide) !important;
  text-transform: uppercase !important;
  cursor: pointer;
  min-width: 180px;
  transition: background var(--zs-transition-base), transform var(--zs-transition-fast);
}

.gform_wrapper .gform_button:hover,
.gform_wrapper input[type="submit"]:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}

/* Gravity Forms validation */
.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select {
  border-color: oklch(55% 0.2 25) !important;
}

.gform_wrapper .validation_message {
  font-size: var(--zs-text-xs) !important;
  color: oklch(55% 0.2 25) !important;
  margin-top: var(--zs-space-xs);
}

/* Gravity Forms confirmation */
.gform_confirmation_message {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-md);
  color: var(--zs-heading);
  padding: var(--zs-space-xl);
  text-align: center;
}

/* Gravity Forms dark mode */
[data-theme="dark"] .gform_wrapper input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
[data-theme="dark"] .gform_wrapper select,
[data-theme="dark"] .gform_wrapper textarea {
  background: var(--zs-bg-alt) !important;
  color: var(--zs-text) !important;
  border-color: var(--zs-border) !important;
}

[data-theme="dark"] .gform_wrapper .gfield_label {
  color: var(--zs-heading) !important;
}

[data-theme="dark"] .gform_wrapper .gform_button,
[data-theme="dark"] .gform_wrapper input[type="submit"] {
  background: var(--zs-accent) !important;
  color: var(--zs-dark-bg) !important;
}


/* ============================================
   BACK TO TOP
   ============================================ */

.zs-back-to-top {
  position: fixed;
  bottom: var(--zs-space-xl);
  right: var(--zs-space-xl);
  z-index: var(--zs-z-sticky);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--zs-heading);
  color: var(--zs-bg);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity var(--zs-transition-base),
              visibility var(--zs-transition-base),
              transform var(--zs-transition-base),
              background var(--zs-transition-fast);
  box-shadow: var(--zs-shadow-md);
}

.zs-back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.zs-back-to-top:hover {
  background: var(--zs-accent);
  transform: translateY(-2px);
}

.zs-back-to-top svg {
  width: 20px;
  height: 20px;
}

[data-theme="dark"] .zs-back-to-top {
  background: var(--zs-accent);
  color: var(--zs-dark-bg);
}

/* Offset for mobile CTA */
@media (max-width: 768px) {
  .zs-back-to-top { bottom: 5rem; }
}


/* ============================================
   GRAVITY FORMS
   ============================================ */

.gform_wrapper .gform_fields {
  list-style: none;
  padding: 0;
  margin: 0;
}

.gform_wrapper .gfield_label,
.gform_wrapper .gfield .gfield_label {
  font-family: var(--zs-font-body);
  font-weight: var(--zs-font-weight-semibold);
  font-size: var(--zs-text-sm);
  color: var(--zs-heading);
  margin-bottom: 6px;
}

.gform_wrapper .name_first label,
.gform_wrapper .name_last label {
  font-size: var(--zs-text-xs);
  color: var(--zs-text-muted);
  font-weight: var(--zs-font-weight-medium);
}

.gform_wrapper .gfield_required { color: var(--zs-secondary); }

.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="number"],
.gform_wrapper textarea,
.gform_wrapper select {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-base);
  padding: 0.7rem 0.9rem;
  border: var(--zs-border-width) solid var(--zs-border);
  border-radius: var(--zs-radius);
  background: var(--zs-bg);
  color: var(--zs-text);
  transition: border-color var(--zs-transition-base), box-shadow var(--zs-transition-base);
  width: 100%;
}

.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper textarea:focus,
.gform_wrapper select:focus {
  border-color: var(--zs-accent);
  box-shadow: 0 0 0 3px var(--zs-primary-muted);
  outline: none;
}

.gform_wrapper textarea { min-height: 140px; resize: vertical; }

.gform_wrapper select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 2.5rem;
}

.gform_wrapper .gform_button,
.gform_wrapper input[type="submit"] {
  font-family: var(--zs-font-body);
  font-weight: var(--zs-font-weight-bold);
  font-size: var(--zs-text-sm);
  letter-spacing: 0.02em;
  background: var(--zs-dark-bg);
  color: #fff;
  border: none;
  border-radius: var(--zs-btn-radius);
  padding: 0.85rem 2.2rem;
  cursor: pointer;
  transition: all var(--zs-transition-base);
  width: auto;
  display: inline-block;
}

.gform_wrapper .gform_button:hover,
.gform_wrapper input[type="submit"]:hover {
  opacity: 0.85;
  transform: translateY(-1px);
}

.gform_wrapper .gfield { margin-bottom: 1.25rem; }

.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select { border-color: oklch(50% 0.2 25); }

.gform_wrapper .gfield_error .gfield_label { color: oklch(50% 0.2 25); }

.gform_wrapper .validation_message {
  font-size: var(--zs-text-xs);
  color: oklch(50% 0.2 25);
  margin-top: 4px;
}

.gform_wrapper .charleft {
  font-size: var(--zs-text-xs);
  color: var(--zs-text-muted);
}

.gform_confirmation_message {
  font-family: var(--zs-font-body);
  font-size: var(--zs-text-md);
  line-height: 1.6;
  color: var(--zs-heading);
  text-align: center;
  padding: var(--zs-space-xl);
}

.gform_confirmation_message strong {
  display: block;
  font-family: var(--zs-font-heading);
  font-size: var(--zs-text-xl);
  margin-bottom: var(--zs-space-sm);
}

.gform_wrapper .gform_footer {
  margin-top: var(--zs-space-sm);
  padding-top: 0;
  border: none;
}

/* Dark mode GF */
[data-theme="dark"] .gform_wrapper input:focus,
[data-theme="dark"] .gform_wrapper textarea:focus,
[data-theme="dark"] .gform_wrapper select:focus {
  box-shadow: 0 0 0 3px var(--zs-selection-bg);
}


/* ============================================
   ADMIN BAR OFFSETS
   ============================================ */

.admin-bar .zs-site-header { top: 32px; }
.admin-bar .zs-drawer-close { top: 1rem; }

@media screen and (max-width: 782px) {
  .admin-bar .zs-site-header { top: 46px; }
  .admin-bar .zs-drawer-close { top:  1rem; }
}


/* ── Drawer CTA block ── v5.8.0 - #46
   Hidden on desktop. Reveals at the bottom of the mobile drawer with
   click-to-call + primary CTA. */
.zs-drawer-cta {
  display: none;
}
@media (max-width: 768px) {
  body.zs-drawer-open .zs-drawer-cta {
    display: flex;
    flex-direction: column;
    gap: var(--zs-space-md);
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    padding: var(--zs-space-lg) var(--zs-space-xl) calc(var(--zs-space-xl) + env(safe-area-inset-bottom, 0px));
    background: var(--zs-bg);
    border-top: var(--zs-border-width) solid var(--zs-border-light);
    z-index: calc(var(--zs-z-drawer) + 1);
  }
  body.zs-drawer-open .zs-drawer-cta[aria-hidden="true"] {
    aria-hidden: false; /* for clarity; JS can flip the attr, CSS can't */
  }
  .zs-drawer-cta__phone {
    display: inline-flex;
    align-items: center;
    gap: var(--zs-space-sm);
    text-decoration: none;
    color: var(--zs-heading);
    font-family: var(--zs-font-heading);
    font-weight: var(--zs-font-weight-bold);
    font-size: var(--zs-text-lg);
    letter-spacing: -0.01em;
  }
  .zs-drawer-cta__phone svg { color: var(--zs-accent); }
  .zs-drawer-cta__btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: var(--zs-space-md) var(--zs-space-lg);
    background: var(--zs-accent);
    color: var(--zs-dark-bg);
    border-radius: var(--zs-btn-radius);
    font-family: var(--zs-font-body);
    font-weight: var(--zs-font-weight-semibold);
    text-decoration: none;
  }
  .zs-drawer-cta__btn:hover { opacity: 0.9; }
}
