/*******************************
  STEVENS OVERRIDES — SINGLE SOURCE OF TRUTH
  - Global typography + gutters
  - Row/container alignment (header/body/footer)
  - Header + nav behavior (desktop + mobile)
  - Hero + image-row overlay alignment
  - Footer alignment without “nested container” weirdness
*******************************/

/************************************
  GLOBAL TYPOGRAPHY + TOKENS
************************************/
:root {
  --stevens-font: klavika-web, sans-serif;

  /* Gutters (site-wide) */
  --gutter-mobile: 20px;
  --gutter-tablet: 32px;
  --gutter-desktop: 56px;

  /* Type scale */
  --fs-body: 18px;
  --lh-body: 1.6;

  --fs-h1: clamp(38px, 7vw, 68px);
  --fs-h2: clamp(28px, 5vw, 44px);
  --fs-h3: clamp(22px, 4vw, 34px);

  --fs-eyebrow: 14px;
  --ls-eyebrow: 0.14em;
}

/* Predictable sizing */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  font-family: var(--stevens-font) !important;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}

/* Headings */
h1, .h1 { font-size: var(--fs-h1); line-height: 1.05; font-family: var(--stevens-font) !important; }
h2, .h2 { font-size: var(--fs-h2); line-height: 1.15; font-family: var(--stevens-font) !important; }
h3, .h3 { font-size: var(--fs-h3); line-height: 1.2;  font-family: var(--stevens-font) !important; }

/* Eyebrow pattern */
.eyebrow,
.stevens-eyebrow,
[class*="eyebrow"] {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  font-weight: 700;
  font-family: var(--stevens-font) !important;
}

/************************************
  UNIFIED GUTTERS
  Apply the SAME left/right padding to:
  - standard theme containers (.content-wrapper)
  - DnD row containers (.dnd-section > .row-fluid)
  NOTE: We do NOT touch max-width here; theme setting controls it.
************************************/

/* Mobile gutters */
.content-wrapper,
.dnd-section > .row-fluid {
  padding-left: var(--gutter-mobile) !important;
  padding-right: var(--gutter-mobile) !important;
}

/* Tablet gutters */
@media (min-width: 768px) {
  .content-wrapper,
  .dnd-section > .row-fluid {
    padding-left: var(--gutter-tablet) !important;
    padding-right: var(--gutter-tablet) !important;
  }
}

/* Desktop gutters */
@media (min-width: 992px) {
  .content-wrapper,
  .dnd-section > .row-fluid {
    padding-left: var(--gutter-desktop) !important;
    padding-right: var(--gutter-desktop) !important;
  }
}

/************************************
  RICH TEXT: FORCE KLAVIKA WHERE POSSIBLE
  (HubSpot can inject inline styles; this helps keep consistency.)
************************************/
.hs_cos_wrapper_type_rich_text,
.hs_cos_wrapper_type_rich_text *,
.hs_cos_wrapper_type_inline_rich_text,
.hs_cos_wrapper_type_inline_rich_text * {
  font-family: var(--stevens-font) !important;
}

/************************************
  MOBILE STACK SPACING (COLUMNS)
************************************/
@media (max-width: 767px) {
  .dnd-section .dnd-column,
  .dnd-section .row-fluid .span12,
  .dnd-section .row-fluid [class*="span"] {
    margin-bottom: 22px;
  }

  .dnd-section .dnd-column:last-child,
  .dnd-section .row-fluid [class*="span"]:last-child {
    margin-bottom: 0;
  }
}

/************************************
  HERO SECTION FREE (hero-section-free)
  Full-bleed background + constrained overlay gutters
************************************/
.bc-hero__content {
  padding-left: var(--gutter-mobile) !important;
  padding-right: var(--gutter-mobile) !important;
}

@media (min-width: 768px) {
  .bc-hero__content {
    padding-left: var(--gutter-tablet) !important;
    padding-right: var(--gutter-tablet) !important;
  }
}

@media (min-width: 992px) {
  .bc-hero__content {
    padding-left: var(--gutter-desktop) !important;
    padding-right: var(--gutter-desktop) !important;
  }
}

/************************************
  IMAGE ROW SECTION (image-row-section)
  Full-bleed background + constrained overlay gutters
************************************/
.bc-image-row-section .row-text {
  padding-left: var(--gutter-mobile) !important;
  padding-right: var(--gutter-mobile) !important;
}

@media (min-width: 768px) {
  .bc-image-row-section .row-text {
    padding-left: var(--gutter-tablet) !important;
    padding-right: var(--gutter-tablet) !important;
  }
}

@media (min-width: 992px) {
  .bc-image-row-section .row-text {
    padding-left: var(--gutter-desktop) !important;
    padding-right: var(--gutter-desktop) !important;
  }
}

/* =========================================================
   Stevens testimonial "card" (for Image Row / parallax rows)
   Targets your explicit markup:
   .stevens-testimonial-row > blockquote.stevens-testimonial
========================================================= */

.bc-image-row-section .stevens-testimonial-row {
  position: relative;
  z-index: 2;                 /* stays above overlay/background */
  max-width: 980px;           /* control card width */
  margin: 0 auto;
  padding: 0 1rem;            /* mobile gutter */
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .bc-image-row-section .stevens-testimonial-row {
    padding: 0 2rem;          /* desktop gutter */
  }
}

/* The card itself */
.bc-image-row-section blockquote.stevens-testimonial {
  margin: 0;
  padding: 2rem 2.5rem;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 18px;
  background: rgba(0,0,0,0.45);
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);

  /* override default blockquote styles */
  quotes: none;
  font-style: italic;
  text-align: center;
  color: #fff;
}

/* Remove any default blockquote pseudo quotes if theme adds them */
.bc-image-row-section blockquote.stevens-testimonial:before,
.bc-image-row-section blockquote.stevens-testimonial:after {
  content: none !important;
}

/* Clean up those <br> tags behavior */
.bc-image-row-section blockquote.stevens-testimonial br {
  line-height: 1.2;
}

/* Attribution */
.bc-image-row-section .stevens-quote-attribution {
  display: block;
  margin-top: 1.5rem;
  font-style: italic;        /* or normal if you prefer contrast */
  font-weight: 500;
  opacity: 0.95;
}

/* Optional: tighten mobile padding so it doesn't feel huge */
@media (max-width: 767px) {
  .bc-image-row-section blockquote.stevens-testimonial {
    padding: 1.5rem 1.25rem;
  }
}



/************************************
  HEADER / NAVIGATION OVERRIDES
************************************/

/* Sticky header across all sizes */
.site-header {
  position: sticky;
  top: 0;
  z-index: 9999;
  background: #ffffff;
}

/* Add breathing room (top/bottom only; left/right handled by unified gutters) */
.site-header .content-wrapper {
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

/* Layout: logo left, right-side items in a row */
.site-header .header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: nowrap;
}

/* Logo sizing (prevents warping) */
.site-header .header-logo {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.site-header .header-logo a {
  margin-left: 0 !important;
  padding-left: 0 !important;
  display: inline-flex;
  align-items: center;
}

.site-header .header-logo img {
  max-height: 64px;
  width: auto !important;
  height: auto !important;
  display: block;
  margin-left: 0 !important;
}

/* Right side: nav + cta + toggle */
.site-header .header-right {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
  min-width: 0;
}

/* Increase nav font size */
.site-header .hs-menu-wrapper a {
  font-size: 1rem;
  font-weight: 600;
}

/* Square corners for nav <ul> */
.site-header .hs-menu-wrapper > ul {
  border-radius: 0 !important;
}

/************************************
  DESKTOP (≥ 992px)
************************************/
@media (min-width: 992px) {
  /* Hide mobile toggle + mobile panel */
  .site-header .nav-toggle,
  .site-header .mobile-nav {
    display: none !important;
  }

  /* Desktop nav row */
  .site-header .primary-nav {
    display: block;
    min-width: 0;
  }

  .site-header .hs-menu-wrapper > ul {
    display: flex;
    align-items: center;
    gap: 18px; /* You said you reduced spacing — keep this modest */
    list-style: none;
    margin: 0;
    padding: 0;
    white-space: nowrap;
  }

  .site-header .hs-menu-wrapper > ul > li {
    margin: 0;
  }

  .site-header .hs-menu-wrapper a {
    display: block;
    padding: 8px 10px;
    text-decoration: none;
    color: #f47b20;
  }

  /* Desktop dropdown */
  .site-header .hs-menu-wrapper ul.hs-menu-children-wrapper {
    position: absolute;
    z-index: 1100;
    background: #ffffff;
    padding: 8px 0;
    margin: 0;
    list-style: none;
    min-width: 220px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  }

  .site-header .hs-menu-wrapper ul.hs-menu-children-wrapper > li > a {
    padding: 8px 12px;
    color: #f47b20;
  }

  /* Desktop CTA visible */
  .site-header .header-cta {
    display: block;
    flex: 0 0 auto;
  }
}

/************************************
  HOVER STATES (desktop + general)
************************************/
.site-header .hs-menu-wrapper a:hover {
  background: #f47b20;
  color: #ffffff !important;
}

/************************************
  TABLET + MOBILE (≤ 991px)
************************************/
@media (max-width: 991px) {
  /* Hide desktop nav + CTA */
  .site-header .primary-nav,
  .site-header .header-cta {
    display: none !important;
  }

  /* Smaller logo on tablet/mobile */
  .site-header .header-logo img {
    max-height: 44px;
  }

  /* Toggle button */
  .site-header .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 44px;
    border: 2px solid #f47b20;
    background: transparent;
    cursor: pointer;
    padding: 0;
    flex: 0 0 auto;
  }

  .site-header .bars {
    display: inline-block;
    line-height: 0;
  }

  .site-header .bar {
    display: block;
    width: 20px;
    height: 2px;
    background: #f47b20;
    margin: 4px 0;
  }

  /* Hover: background orange, bars turn white */
  .site-header .nav-toggle:hover {
    background: #f47b20;
  }

  .site-header .nav-toggle:hover .bar {
    background: #ffffff;
  }

  /* Mobile nav panel */
  .site-header .mobile-nav {
    display: none;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(0,0,0,0.15);
  }

  .site-header.is-open .mobile-nav {
    display: block;
  }

  /* Vertical menu in mobile panel */
  .site-header.is-open .mobile-nav .hs-menu-wrapper > ul {
    display: block !important;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .site-header.is-open .mobile-nav .hs-menu-wrapper > ul > li {
    display: block !important;
    margin: 0 !important;
  }

  .site-header.is-open .mobile-nav .hs-menu-wrapper a {
    display: block;
    padding: 14px 0;
    color: #f47b20 !important;
    text-decoration: none;
    font-size: 1.25rem;
  }

  /* Hover/tap/focus in hamburger menu */
  .site-header.is-open .mobile-nav .hs-menu-wrapper a:hover,
  .site-header.is-open .mobile-nav .hs-menu-wrapper a:focus,
  .site-header.is-open .mobile-nav .hs-menu-wrapper a:focus-visible,
  .site-header.is-open .mobile-nav .hs-menu-wrapper a:active {
    background: #f47b20;
    color: #ffffff !important;
    outline: none;
  }

  /* No dropdown children in hamburger (for now) */
  .site-header .mobile-nav .hs-menu-wrapper ul.hs-menu-children-wrapper,
  .site-header .mobile-nav .hs-menu-wrapper .hs-menu-depth-2,
  .site-header .mobile-nav .hs-menu-wrapper .hs-menu-depth-3,
  .site-header .mobile-nav .hs-menu-wrapper .hs-menu-depth-4 {
    display: none !important;
  }
}



/************************************
  FOOTER: ALIGN WITHOUT NESTED-CONTAINER SIDE EFFECTS
  - Do NOT set footer .row-fluid max-width/padding (causes “weird block”)
  - Only remove extra column padding the theme applies
************************************/
footer .dnd-section .dnd-column,
.site-footer .dnd-section .dnd-column,
footer [class*="span"],
.site-footer [class*="span"] {
  padding-left: 0 !important;
  padding-right: 0 !important;
}


/************************************
  FOOTER: CENTER LOGO WIDGET ON TABLET/MOBILE
  (Targets the actual span/widget wrapper you’re hovering)
************************************/
@media (max-width: 991px) {
  /* The column that contains the logo widget */
  .footer .widget-span.widget-type-custom_widget {
    display: flex !important;
    justify-content: center !important;
  }

  /* The HubSpot wrapper inside the widget */
  .footer .widget-span.widget-type-custom_widget .hs_cos_wrapper_type_linked_image,
  .footer .widget-span.widget-type-custom_widget .hs_cos_wrapper_type_linked_image a {
    display: inline-flex !important;
    justify-content: center !important;
  }

  /* Image itself */
  .footer .widget-span.widget-type-custom_widget img.hs-image-widget {
    display: block !important;
    margin: 0 auto !important;
  }
}


}



/************************************
  SCREEN-READER HELPER
************************************/
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/************************************
  FINAL FONT ENFORCE (KEEP AT BOTTOM)
  Ensures late-loading module CSS doesn't “win.”
************************************/
html body,
body,
p, li, span, a,
label, input, textarea, select, button,
.hs_cos_wrapper_type_rich_text,
.hs_cos_wrapper_type_rich_text *,
.hs_cos_wrapper_type_inline_rich_text,
.hs_cos_wrapper_type_inline_rich_text * {
  font-family: var(--stevens-font) !important;
}

/************************************
  FOOTER: MATCH SITE CONTENT WIDTH
************************************/

/* Make footer inner container match main content width */
footer .content-wrapper,
.site-footer .content-wrapper {
  max-width: inherit !important;
  padding-left: var(--gutter-mobile) !important;
  padding-right: var(--gutter-mobile) !important;
}

@media (min-width: 768px) {
  footer .content-wrapper,
  .site-footer .content-wrapper {
    padding-left: var(--gutter-tablet) !important;
    padding-right: var(--gutter-tablet) !important;
  }
}

@media (min-width: 992px) {
  footer .content-wrapper,
  .site-footer .content-wrapper {
    padding-left: var(--gutter-desktop) !important;
    padding-right: var(--gutter-desktop) !important;
  }
}

/* Remove extra column padding that makes footer feel narrower */
footer .dnd-column,
.site-footer .dnd-column,
footer [class*="span"],
.site-footer [class*="span"] {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/************************************
  FOOTER MOBILE: CENTER CONTENT (LOGO + NAV)
************************************/
@media (max-width: 991px) {
  /* The footer row is flex; center its children */
  .footer .row-fluid {
    justify-content: center !important;
    text-align: center !important;
  }

  /* Ensure the logo widget itself is centered */
  .footer .hs_cos_wrapper_type_linked_image,
  .footer .hs_cos_wrapper_type_linked_image a {
    display: inline-flex !important;
    justify-content: center !important;
  }

  .footer img.hs-image-widget {
    display: block !important;
    margin: 0 auto !important;
  }
}