/* =========================
   BSM MAINE GLOBAL COLORS
========================= */

:root {
  --bsm-blue: #004AD0;
  --bsm-blue-dark: #0039A6;
  --bsm-navy: #081634;
  --bsm-muted: #5e6a7d;
  --bsm-soft: #f4f7ff;
  --bsm-border: #dbe4f5;
  --bsm-radius: 20px;
  --bsm-radius-large: 32px;
  --bsm-shadow: 0 14px 34px rgba(8, 22, 52, 0.075);
  --bsm-shadow-strong: 0 22px 54px rgba(8, 22, 52, 0.13);
}

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

.ct-header,
.site-header,
header {
  position: relative !important;
  z-index: 9999 !important;
  background: #ffffff !important;
  overflow: visible !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ct-header [data-row] {
  height: auto !important;
  min-height: 82px !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  border-bottom: 1px solid #eef1f6 !important;
  overflow: visible !important;
  margin: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.ct-header .ct-container {
  max-width: 1360px !important;
  margin: 0 auto !important;
  padding-left: 28px !important;
  padding-right: 28px !important;
  overflow: visible !important;
}

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

.ct-header [data-id="logo"],
.ct-header [data-id="logo"] a,
.ct-header .site-branding,
.ct-header .ct-logo,
.ct-header .site-logo-container {
  display: flex !important;
  align-items: center !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}

.ct-header [data-id="logo"] img,
.ct-header .site-branding img,
.ct-header .ct-logo img,
.ct-header .site-logo-container img,
.ct-header img.custom-logo,
.site-branding img,
.custom-logo,
.site-logo-container img {
  display: block !important;
  width: 255px !important;
  max-width: 255px !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center !important;
}

header [data-id="logo"],
.ct-header [data-id="logo"] {
  margin-left: 0 !important;
  margin-right: 28px !important;
}

/* =========================
   DESKTOP HEADER MENU
========================= */

@media (min-width: 1000px) {
  .ct-header [data-id="menu"] {
    margin-left: 20px !important;
    flex: 1 1 auto !important;
  }

  .ct-header .menu {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 26px !important;
    overflow: visible !important;
  }

  .ct-header .menu > li {
    position: relative !important;
    overflow: visible !important;
  }

  .ct-header .menu > li > a,
  .ct-header nav a {
    font-size: 14px !important;
    font-weight: 850 !important;
    letter-spacing: 0.01em !important;
    color: var(--bsm-navy) !important;
    text-transform: uppercase !important;
    padding: 10px 0 !important;
    text-decoration: none !important;
    background: transparent !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }

  .ct-header .menu > li > a:hover,
  .ct-header nav a:hover {
    color: var(--bsm-blue) !important;
  }

  .ct-header .menu > li.current-menu-item > a,
  .ct-header .menu > li.current-menu-ancestor > a,
  .ct-header .menu > li.current_page_item > a,
  .ct-header .menu > li.current_page_parent > a,
  .ct-header .menu > li.current_page_ancestor > a {
    background: var(--bsm-blue) !important;
    color: #ffffff !important;
    border-radius: 999px !important;
    padding: 10px 16px !important;
    box-shadow: 0 10px 22px rgba(0, 74, 208, 0.18) !important;
  }

  .ct-header .sub-menu,
  .ct-header .menu .sub-menu,
  .ct-header nav .sub-menu {
    position: absolute !important;
    top: calc(100% + 14px) !important;
    left: 0 !important;
    z-index: 99999 !important;
    min-width: 275px !important;
    width: 275px !important;
    padding: 12px 0 !important;
    margin: 0 !important;
    border-radius: 18px !important;
    border: 1px solid rgba(0, 74, 208, 0.06) !important;
    background: #ffffff !important;
    box-shadow: 0 22px 55px rgba(17, 34, 68, 0.16) !important;
    overflow: visible !important;
  }

  .ct-header .sub-menu li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-header .sub-menu li:first-child {
    border-bottom: 1px solid #eef2f7 !important;
    margin-bottom: 6px !important;
    padding-bottom: 6px !important;
  }

  .ct-header .sub-menu li a,
  .ct-header .menu .sub-menu li a,
  .ct-header nav .sub-menu li a {
    display: block !important;
    width: 100% !important;
    padding: 14px 22px !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
    color: var(--bsm-navy) !important;
    background: #ffffff !important;
    border-radius: 0 !important;
    text-transform: none !important;
    text-decoration: none !important;
    white-space: nowrap !important;
  }

  .ct-header .sub-menu li a:hover,
  .ct-header .menu .sub-menu li a:hover,
  .ct-header nav .sub-menu li a:hover {
    color: var(--bsm-blue) !important;
    background: #f7fbff !important;
  }
}

/* =========================
   HEADER CONTACT BUTTON
========================= */

.bsm-header-contact {
  margin-left: 34px !important;
  flex-shrink: 0 !important;
}

.bsm-header-contact a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  padding: 12px 24px !important;
  border-radius: 999px !important;
  background: var(--bsm-blue) !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  box-shadow: 0 12px 28px rgba(0, 74, 208, 0.24) !important;
  white-space: nowrap !important;
}

.bsm-header-contact a:hover {
  background: var(--bsm-blue-dark) !important;
  color: #ffffff !important;
}

/* =========================
   REMOVE HEADER BOTTOM LINE
   BSM Maine
========================= */

#header,
#header [data-row],
#header [data-row*="middle"],
#header .ct-container,
#header .ct-header,
#header .ct-sticky-container,
.ct-header,
.ct-header [data-row],
.ct-header .ct-container {
  border-bottom: none !important;
  box-shadow: none !important;
}

#header::before,
#header::after,
.ct-header::before,
.ct-header::after,
.ct-sticky-container::before,
.ct-sticky-container::after {
  display: none !important;
  content: none !important;
  border: none !important;
  box-shadow: none !important;
}

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

@media (min-width: 768px) and (max-width: 999px) {
  .ct-header,
  .site-header,
  header {
    min-height: 70px !important;
    height: auto !important;
    max-height: none !important;
    background: #ffffff !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-header [data-row],
  .ct-header [data-row="top"],
  .ct-header [data-row="middle"],
  .ct-header [data-row="bottom"],
  .ct-header [data-row] .ct-container,
  .ct-header [data-row="top"] .ct-container,
  .ct-header [data-row="middle"] .ct-container,
  .ct-header [data-row="bottom"] .ct-container {
    min-height: 70px !important;
    height: auto !important;
    max-height: none !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .ct-header .ct-container {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .ct-header [data-id="logo"] img,
  .ct-header .site-branding img,
  .ct-header .ct-logo img,
  .ct-header .site-logo-container img,
  .ct-header img.custom-logo,
  .site-branding img,
  .custom-logo,
  .site-logo-container img {
    width: 225px !important;
    max-width: 225px !important;
  }

  .ct-header-trigger,
  .ct-header-trigger button,
  .ct-header-trigger a,
  .ct-header-trigger svg {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 42px !important;
    height: auto !important;
    position: relative !important;
    z-index: 100001 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
  }

  .bsm-me-hero {
    padding-top: 12px !important;
    margin-top: 0 !important;
  }

  .bsm-me-hero__inner,
  .bsm-me-hero__card {
    margin-top: 0 !important;
  }
}

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

@media (max-width: 767px) {
  .ct-header,
  .site-header,
  header {
    min-height: 76px !important;
    height: auto !important;
    max-height: none !important;
    background: #ffffff !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-header [data-row],
  .ct-header [data-row="top"],
  .ct-header [data-row="middle"],
  .ct-header [data-row="bottom"],
  .ct-header [data-row] .ct-container,
  .ct-header [data-row="top"] .ct-container,
  .ct-header [data-row="middle"] .ct-container,
  .ct-header [data-row="bottom"] .ct-container {
    min-height: 76px !important;
    height: auto !important;
    max-height: none !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .ct-header .ct-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .ct-header [data-id="logo"] img,
  .ct-header .site-branding img,
  .ct-header .ct-logo img,
  .ct-header .site-logo-container img,
  .ct-header img.custom-logo,
  .site-branding img,
  .custom-logo,
  .site-logo-container img {
    width: 230px !important;
    max-width: 230px !important;
  }

  .ct-header-trigger,
  .ct-header-trigger button,
  .ct-header-trigger a,
  .ct-header-trigger svg {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    height: auto !important;
    position: relative !important;
    z-index: 100001 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
  }

  .bsm-me-hero {
    padding-top: 12px !important;
    margin-top: 0 !important;
  }

  .bsm-me-hero__inner,
  .bsm-me-hero__card {
    margin-top: 0 !important;
  }
}

/* =========================
   OFFCANVAS MOBILE MENU
========================= */

@media (max-width: 999px) {
  .ct-drawer-canvas,
  .ct-panel,
  .ct-panel-content,
  .ct-drawer-inner,
  .ct-drawer-content,
  .ct-header-panel,
  .ct-offcanvas,
  .ct-offcanvas-content,
  .ct-panel-inner {
    background: #ffffff !important;
    color: var(--bsm-navy) !important;
    z-index: 999999 !important;
  }

  .ct-panel,
  .ct-drawer-inner,
  .ct-drawer-content,
  .ct-header-panel,
  .ct-offcanvas {
    min-height: 100vh !important;
    height: 100vh !important;
    max-height: 100vh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .ct-panel-content,
  .ct-drawer-content,
  .ct-header-panel {
    min-height: 100vh !important;
    background: #ffffff !important;
    padding: 58px 26px 120px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .ct-toggle-close,
  .ct-panel .ct-toggle-close,
  .ct-drawer-canvas .ct-toggle-close,
  .ct-offcanvas .ct-toggle-close,
  .ct-header-panel .ct-toggle-close {
    display: flex !important;
    position: absolute !important;
    top: 22px !important;
    right: 24px !important;
    z-index: 1000001 !important;
    color: var(--bsm-navy) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    pointer-events: auto !important;
  }

  .ct-panel [data-row],
  .ct-offcanvas [data-row],
  .ct-header-panel [data-row],
  .ct-panel .ct-container,
  .ct-offcanvas .ct-container,
  .ct-header-panel .ct-container {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .ct-drawer-canvas [data-id="logo"],
  .ct-panel [data-id="logo"],
  .ct-offcanvas [data-id="logo"],
  .ct-header-panel [data-id="logo"],
  .ct-drawer-canvas [data-id="trigger"],
  .ct-panel [data-id="trigger"],
  .ct-offcanvas [data-id="trigger"],
  .ct-header-panel [data-id="trigger"] {
    display: none !important;
  }

  .ct-drawer-canvas [data-id="mobile-menu"],
  .ct-panel [data-id="mobile-menu"],
  .ct-offcanvas [data-id="mobile-menu"],
  .ct-header-panel [data-id="mobile-menu"],
  .ct-drawer-canvas .mobile-menu,
  .ct-panel .mobile-menu,
  .ct-offcanvas .mobile-menu,
  .ct-header-panel .mobile-menu {
    display: block !important;
    width: 100% !important;
    background: #ffffff !important;
    opacity: 1 !important;
    visibility: visible !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-drawer-canvas .menu,
  .ct-panel .menu,
  .ct-offcanvas .menu,
  .ct-header-panel .menu,
  .ct-drawer-canvas .mobile-menu ul,
  .ct-panel .mobile-menu ul,
  .ct-offcanvas .mobile-menu ul,
  .ct-header-panel .mobile-menu ul {
    display: grid !important;
    gap: 12px !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    background: #ffffff !important;
  }

  .ct-drawer-canvas .menu li,
  .ct-panel .menu li,
  .ct-offcanvas .menu li,
  .ct-header-panel .menu li,
  .ct-drawer-canvas .mobile-menu li,
  .ct-panel .mobile-menu li,
  .ct-offcanvas .mobile-menu li,
  .ct-header-panel .mobile-menu li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-drawer-canvas .menu a,
  .ct-panel .menu a,
  .ct-offcanvas .menu a,
  .ct-header-panel .menu a,
  .ct-drawer-canvas .mobile-menu a,
  .ct-panel .mobile-menu a,
  .ct-offcanvas .mobile-menu a,
  .ct-header-panel .mobile-menu a {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 48px !important;
    width: 100% !important;
    padding: 0 !important;
    color: var(--bsm-navy) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    font-size: 20px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
    text-transform: none !important;
    text-align: left !important;
  }

  .ct-drawer-canvas .menu .current-menu-item > a,
  .ct-panel .menu .current-menu-item > a,
  .ct-offcanvas .menu .current-menu-item > a,
  .ct-header-panel .menu .current-menu-item > a {
    color: var(--bsm-blue) !important;
  }
}

/* =========================
   MOBILE MENU DROPDOWN FIX
========================= */

@media (max-width: 999px) {
  .ct-drawer-canvas .menu-item-has-children > .sub-menu,
  .ct-panel .menu-item-has-children > .sub-menu,
  .ct-offcanvas .menu-item-has-children > .sub-menu,
  .ct-header-panel .menu-item-has-children > .sub-menu {
    display: none !important;
    margin: 8px 0 12px !important;
    padding: 0 0 0 18px !important;
    background: #ffffff !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .ct-drawer-canvas .menu-item-has-children:has([aria-expanded="true"]) > .sub-menu,
  .ct-panel .menu-item-has-children:has([aria-expanded="true"]) > .sub-menu,
  .ct-offcanvas .menu-item-has-children:has([aria-expanded="true"]) > .sub-menu,
  .ct-header-panel .menu-item-has-children:has([aria-expanded="true"]) > .sub-menu,
  .ct-drawer-canvas .menu-item-has-children.active > .sub-menu,
  .ct-panel .menu-item-has-children.active > .sub-menu,
  .ct-offcanvas .menu-item-has-children.active > .sub-menu,
  .ct-header-panel .menu-item-has-children.active > .sub-menu,
  .ct-drawer-canvas .menu-item-has-children.ct-active > .sub-menu,
  .ct-panel .menu-item-has-children.ct-active > .sub-menu,
  .ct-offcanvas .menu-item-has-children.ct-active > .sub-menu,
  .ct-header-panel .menu-item-has-children.ct-active > .sub-menu,
  .ct-drawer-canvas .menu-item-has-children.open > .sub-menu,
  .ct-panel .menu-item-has-children.open > .sub-menu,
  .ct-offcanvas .menu-item-has-children.open > .sub-menu,
  .ct-header-panel .menu-item-has-children.open > .sub-menu,
  .ct-drawer-canvas .menu-item-has-children.is-open > .sub-menu,
  .ct-panel .menu-item-has-children.is-open > .sub-menu,
  .ct-offcanvas .menu-item-has-children.is-open > .sub-menu,
  .ct-header-panel .menu-item-has-children.is-open > .sub-menu {
    display: grid !important;
    gap: 8px !important;
  }

  .ct-drawer-canvas .sub-menu a,
  .ct-panel .sub-menu a,
  .ct-offcanvas .sub-menu a,
  .ct-header-panel .sub-menu a {
    min-height: 38px !important;
    font-size: 17px !important;
    font-weight: 850 !important;
    color: var(--bsm-navy) !important;
    padding-left: 0 !important;
    text-align: left !important;
  }

  .ct-drawer-canvas .sub-menu a:hover,
  .ct-panel .sub-menu a:hover,
  .ct-offcanvas .sub-menu a:hover,
  .ct-header-panel .sub-menu a:hover {
    color: var(--bsm-blue) !important;
  }

  .ct-drawer-canvas .bsm-me-mobile-sticky,
  .ct-drawer-canvas .bsm-mobile-sticky,
  .ct-drawer-canvas .bsm-sticky-cta,
  .ct-panel .bsm-me-mobile-sticky,
  .ct-panel .bsm-mobile-sticky,
  .ct-panel .bsm-sticky-cta,
  .ct-offcanvas .bsm-me-mobile-sticky,
  .ct-offcanvas .bsm-mobile-sticky,
  .ct-offcanvas .bsm-sticky-cta,
  .ct-header-panel .bsm-me-mobile-sticky,
  .ct-header-panel .bsm-mobile-sticky,
  .ct-header-panel .bsm-sticky-cta {
    display: none !important;
  }
}

/* =========================
   PAGE CONTENT STACKING
========================= */

.site-main,
.entry-content,
.bsm-me-page,
.bsm-me-hero,
.bsm-me-hero__inner,
.bsm-me-hero__card,
.bsm-loan-hero,
.bsm-refi-hero,
.bsm-purchase-hero,
.bsm-page,
#main,
.ct-container-full {
  position: relative !important;
  z-index: 1 !important;
}

.bsm-me-mobile-sticky,
.bsm-mobile-sticky,
.bsm-sticky-cta {
  z-index: 800 !important;
}

/* =========================
   GLOBAL BUTTON SYSTEM
========================= */

.bsm-btn--primary,
.bsm-button--primary,
.bsm-purchase-btn--primary,
.bsm-refi-btn--primary,
.bsm-funnel-btn--primary,
.bsm-about-btn--primary,
.bsm-contact-btn:not(.bsm-contact-btn--outline),
.bsm-me-btn--primary {
  background: var(--bsm-blue) !important;
  color: #ffffff !important;
  border: 2px solid var(--bsm-blue) !important;
  box-shadow: 0 12px 28px rgba(0, 74, 208, 0.22) !important;
}

.bsm-btn--primary:hover,
.bsm-button--primary:hover,
.bsm-purchase-btn--primary:hover,
.bsm-refi-btn--primary:hover,
.bsm-funnel-btn--primary:hover,
.bsm-about-btn--primary:hover,
.bsm-contact-btn:not(.bsm-contact-btn--outline):hover,
.bsm-me-btn--primary:hover {
  background: var(--bsm-blue-dark) !important;
  color: #ffffff !important;
  border-color: var(--bsm-blue-dark) !important;
}

.bsm-btn--outline,
.bsm-button--outline,
.bsm-purchase-btn--outline,
.bsm-refi-btn--outline,
.bsm-about-btn--secondary,
.bsm-about-btn--outline,
.bsm-funnel-btn--secondary,
.bsm-funnel-btn--outline,
.bsm-me-btn--outline,
.bsm-contact-btn--outline {
  background: #ffffff !important;
  color: var(--bsm-blue) !important;
  border: 2px solid var(--bsm-blue) !important;
  box-shadow: none !important;
}

/* =========================
   SERVICE AREA TWO COLUMN SECTION
========================= */

.bsm-service-area,
.bsm-me-service-area,
.bsm-location-section {
  width: min(1120px, calc(100% - 48px)) !important;
  max-width: 1120px !important;
  margin: 56px auto !important;
  padding: 46px 42px !important;
  border-radius: 30px !important;
  background: linear-gradient(135deg, #ffffff 0%, #f5f8ff 100%) !important;
  box-shadow: 0 18px 46px rgba(8, 22, 52, 0.075) !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 430px !important;
  column-gap: 42px !important;
  row-gap: 20px !important;
  align-items: center !important;
  text-align: left !important;
}

.bsm-service-area h2,
.bsm-service-area h3,
.bsm-me-service-area h2,
.bsm-me-service-area h3,
.bsm-location-section h2,
.bsm-location-section h3 {
  grid-column: 1 / -1 !important;
  max-width: 760px !important;
  margin: 0 auto 14px !important;
  color: var(--bsm-navy) !important;
  font-size: clamp(30px, 3.4vw, 44px) !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
  letter-spacing: -0.04em !important;
  text-align: center !important;
}

.bsm-service-area > p:not(:has(a)),
.bsm-me-service-area > p:not(:has(a)),
.bsm-location-section > p:not(:has(a)) {
  grid-column: 1 / -1 !important;
  max-width: 720px !important;
  margin: 0 auto 32px !important;
  color: var(--bsm-muted) !important;
  font-size: 17px !important;
  line-height: 1.65 !important;
  text-align: center !important;
}

.bsm-service-area .bsm-chip-list,
.bsm-service-area .bsm-town-list,
.bsm-service-area .bsm-location-list,
.bsm-me-service-area .bsm-chip-list,
.bsm-me-service-area .bsm-town-list,
.bsm-me-service-area .bsm-location-list,
.bsm-location-section .bsm-chip-list,
.bsm-location-section .bsm-town-list,
.bsm-location-section .bsm-location-list {
  grid-column: 1 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 12px 14px !important;
  width: 100% !important;
  max-width: 610px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.bsm-service-area .bsm-chip,
.bsm-service-area .bsm-town,
.bsm-service-area .bsm-chip-list span,
.bsm-service-area .bsm-town-list span,
.bsm-service-area .bsm-location-list span,
.bsm-me-service-area .bsm-chip,
.bsm-me-service-area .bsm-town,
.bsm-me-service-area .bsm-chip-list span,
.bsm-me-service-area .bsm-town-list span,
.bsm-me-service-area .bsm-location-list span,
.bsm-location-section .bsm-chip,
.bsm-location-section .bsm-town,
.bsm-location-section .bsm-chip-list span,
.bsm-location-section .bsm-town-list span,
.bsm-location-section .bsm-location-list span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  padding: 10px 20px !important;
  border-radius: 999px !important;
  border: 1px solid #bdd0ff !important;
  background: #ffffff !important;
  color: var(--bsm-navy) !important;
  font-size: 16px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
  box-shadow: 0 8px 18px rgba(0, 74, 208, 0.05) !important;
}

.bsm-service-area a[href^="tel:"],
.bsm-me-service-area a[href^="tel:"],
.bsm-location-section a[href^="tel:"] {
  grid-column: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: fit-content !important;
  min-height: 50px !important;
  padding: 14px 26px !important;
  margin: 22px 0 0 !important;
  border-radius: 999px !important;
  background: var(--bsm-blue) !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  border: 2px solid var(--bsm-blue) !important;
  box-shadow: 0 14px 30px rgba(0, 74, 208, 0.20) !important;
}

.bsm-service-area a[href^="tel:"]:hover,
.bsm-me-service-area a[href^="tel:"]:hover,
.bsm-location-section a[href^="tel:"]:hover {
  background: var(--bsm-blue-dark) !important;
  border-color: var(--bsm-blue-dark) !important;
  color: #ffffff !important;
  text-decoration: none !important;
}

.bsm-service-area img,
.bsm-me-service-area img,
.bsm-location-section img,
.bsm-service-area figure,
.bsm-me-service-area figure,
.bsm-location-section figure {
  grid-column: 2 !important;
  grid-row: 3 / span 3 !important;
  display: block !important;
  width: 100% !important;
  max-width: 430px !important;
  height: auto !important;
  margin: 0 !important;
  border-radius: 24px !important;
  box-shadow: 0 18px 44px rgba(8, 22, 52, 0.11) !important;
}

.bsm-service-area figure img,
.bsm-me-service-area figure img,
.bsm-location-section figure img {
  width: 100% !important;
  max-width: 430px !important;
  margin: 0 !important;
  box-shadow: none !important;
}

/* =========================
   FINAL CTA CLEANUP
========================= */

.bsm-me-section--final,
.bsm-final-cta,
.bsm-me-final-cta {
  width: min(980px, calc(100% - 48px)) !important;
  margin: 52px auto 48px !important;
  padding: 44px 34px 46px !important;
  border-radius: 30px !important;
  background: linear-gradient(135deg, #ffffff 0%, #f4f7ff 100%) !important;
  box-shadow: 0 18px 46px rgba(8, 22, 52, 0.08) !important;
  text-align: center !important;
  overflow: hidden !important;
}

.bsm-me-section--final h2,
.bsm-final-cta h2,
.bsm-me-final-cta h2 {
  max-width: 760px !important;
  margin: 0 auto 14px !important;
  color: var(--bsm-navy) !important;
  font-size: clamp(30px, 3.2vw, 42px) !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
  letter-spacing: -0.045em !important;
  text-align: center !important;
}

.bsm-me-section--final p,
.bsm-final-cta p,
.bsm-me-final-cta p {
  max-width: 640px !important;
  margin: 0 auto 26px !important;
  color: #526176 !important;
  font-size: 17px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}

.bsm-me-section--final .bsm-me-actions,
.bsm-final-cta .bsm-me-actions,
.bsm-me-final-cta .bsm-me-actions,
.bsm-me-section--final .bsm-actions,
.bsm-final-cta .bsm-actions,
.bsm-me-final-cta .bsm-actions {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin: 0 auto !important;
}

.bsm-me-section--final a,
.bsm-final-cta a,
.bsm-me-final-cta a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 50px !important;
  min-width: 150px !important;
  padding: 13px 24px !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.bsm-me-section--final a:first-of-type,
.bsm-final-cta a:first-of-type,
.bsm-me-final-cta a:first-of-type {
  background: var(--bsm-blue) !important;
  color: #ffffff !important;
  border: 2px solid var(--bsm-blue) !important;
  box-shadow: 0 14px 30px rgba(0, 74, 208, 0.22) !important;
}

.bsm-me-section--final a:not(:first-of-type),
.bsm-final-cta a:not(:first-of-type),
.bsm-me-final-cta a:not(:first-of-type) {
  background: #ffffff !important;
  color: var(--bsm-blue) !important;
  border: 2px solid var(--bsm-blue) !important;
  box-shadow: none !important;
}

.bsm-me-section--final a:hover,
.bsm-final-cta a:hover,
.bsm-me-final-cta a:hover {
  background: var(--bsm-blue-dark) !important;
  color: #ffffff !important;
  border-color: var(--bsm-blue-dark) !important;
  text-decoration: none !important;
}

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

.site-footer,
.ct-footer,
.bsm-footer,
footer {
  background: #f6f8fc !important;
  border-top: 1px solid #e7ebf3 !important;
  color: var(--bsm-navy) !important;
  margin-top: 0 !important;
  padding: 42px 0 42px !important;
  overflow: visible !important;
  height: auto !important;
  max-height: none !important;
}

.ct-footer .ct-container,
.site-footer .ct-container,
.ct-footer-inner-wrap,
.footer-widgets-container {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.footer-widgets,
.footer-columns,
.ct-footer [data-columns],
.site-footer .widget-area,
.ct-footer .widget-area {
  display: grid !important;
  grid-template-columns: 300px 230px 200px 190px !important;
  column-gap: 82px !important;
  row-gap: 38px !important;
  align-items: start !important;
  justify-content: center !important;
  max-width: 1080px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.footer-widgets > *,
.footer-columns > *,
.ct-footer [data-columns] > *,
.site-footer .widget-area > *,
.ct-footer .widget-area > * {
  min-width: 0 !important;
  max-width: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
  position: static !important;
}

.bsm-footer-col,
.bsm-footer-brand {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  text-align: left !important;
}

.bsm-footer-logo,
.bsm-footer-logo-image {
  width: 260px !important;
  max-width: 280px !important;
  height: auto !important;
  display: block !important;
  margin: 0 0 26px !important;
}

.bsm-footer-col h2,
.bsm-footer-col h3,
.bsm-footer-col h4,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.ct-footer h2,
.ct-footer h3,
.ct-footer h4,
.bsm-footer h2,
.bsm-footer h3,
.bsm-footer h4 {
  margin: 0 0 26px !important;
  color: var(--bsm-navy) !important;
  font-size: 25px !important;
  line-height: 1.15 !important;
  font-weight: 950 !important;
  letter-spacing: -0.035em !important;
  text-align: left !important;
}

.bsm-footer-col p,
.bsm-footer-description,
.bsm-footer-brand p {
  margin: 0 0 22px !important;
  max-width: 300px !important;
  color: var(--bsm-muted) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  text-align: left !important;
}

.ct-footer a,
.site-footer a,
.bsm-footer a,
.bsm-footer-col a,
.bsm-footer-col li a {
  color: var(--bsm-blue) !important;
  text-decoration: none !important;
}

.bsm-footer-col ul,
.ct-footer ul,
.site-footer ul,
.bsm-footer ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.bsm-footer-col li,
.ct-footer li,
.site-footer li,
.bsm-footer li {
  margin: 0 0 17px !important;
  color: var(--bsm-muted) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  text-align: left !important;
}

.bsm-footer-col a,
.ct-footer li a,
.site-footer li a,
.bsm-footer li a {
  color: var(--bsm-blue) !important;
  font-size: 16px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
  text-align: left !important;
}

.bsm-footer-col a:hover,
.ct-footer li a:hover,
.site-footer li a:hover,
.bsm-footer li a:hover {
  color: var(--bsm-blue-dark) !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
}

.bsm-footer-trust {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  margin: 24px 0 28px !important;
}

.bsm-footer-trust span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid #d7e1f3 !important;
  color: var(--bsm-navy) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}

.bsm-footer-nmls {
  display: block !important;
  width: 100% !important;
  max-width: 300px !important;
  margin: 30px 0 28px !important;
  color: var(--bsm-muted) !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
  text-align: left !important;
}

.bsm-footer-nmls strong {
  display: block !important;
  margin-bottom: 4px !important;
  color: var(--bsm-navy) !important;
  font-weight: 950 !important;
}

.bsm-footer-contact {
  display: block !important;
  width: 100% !important;
  max-width: 300px !important;
  margin-top: 52px !important;
  padding-top: 12px !important;
  text-align: left !important;
}

.bsm-footer-contact p {
  margin: 0 0 18px !important;
  color: var(--bsm-muted) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  text-align: left !important;
}

.bsm-footer-phone,
.bsm-footer-contact .bsm-footer-phone,
.bsm-footer-contact a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 50px !important;
  width: auto !important;
  max-width: none !important;
  padding: 12px 22px !important;
  border-radius: 999px !important;
  background: var(--bsm-blue) !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  box-shadow: 0 14px 30px rgba(0, 74, 208, 0.22) !important;
  border: 2px solid var(--bsm-blue) !important;
  white-space: nowrap !important;
  margin-top: 14px !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.bsm-footer-phone:hover,
.bsm-footer-contact .bsm-footer-phone:hover,
.bsm-footer-contact a:hover {
  background: var(--bsm-blue-dark) !important;
  border-color: var(--bsm-blue-dark) !important;
  color: #ffffff !important;
}

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

@media (min-width: 701px) and (max-width: 1100px) {
  .site-footer,
  .ct-footer,
  .bsm-footer,
  footer {
    padding-top: 42px !important;
    padding-left: 36px !important;
    padding-right: 36px !important;
    padding-bottom: 42px !important;
  }

  .ct-footer .ct-container,
  .site-footer .ct-container,
  .ct-footer-inner-wrap,
  .footer-widgets-container {
    width: 100% !important;
    max-width: 920px !important;
  }

  .footer-widgets,
  .footer-columns,
  .ct-footer [data-columns],
  .site-footer .widget-area,
  .ct-footer .widget-area {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 54px !important;
    row-gap: 54px !important;
    align-items: start !important;
    justify-content: start !important;
    max-width: 920px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .bsm-footer-logo,
  .bsm-footer-logo-image {
    width: 220px !important;
    max-width: 220px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .bsm-footer-contact {
    margin-top: 34px !important;
    text-align: left !important;
  }
}

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

@media (max-width: 700px) {
  .site-footer,
  .ct-footer,
  .bsm-footer,
  footer {
    padding-top: 36px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    padding-bottom: 96px !important;
    text-align: left !important;
  }

  .ct-footer .ct-container,
  .site-footer .ct-container,
  .ct-footer-inner-wrap,
  .footer-widgets-container {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .footer-widgets,
  .footer-columns,
  .ct-footer [data-columns],
  .site-footer .widget-area,
  .ct-footer .widget-area {
    display: grid !important;
    grid-template-columns: 1fr !important;
    row-gap: 32px !important;
    column-gap: 0 !important;
    justify-content: start !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
  }

  .bsm-footer-brand,
  .bsm-footer-col {
    text-align: left !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .bsm-footer-logo,
  .bsm-footer-logo-image {
    width: 220px !important;
    max-width: 220px !important;
    margin: 0 0 24px 0 !important;
  }

  .bsm-footer-brand p,
  .bsm-footer-col p,
  .bsm-footer-description {
    max-width: 340px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
  }

  .bsm-footer-contact {
    text-align: left !important;
    margin-top: 28px !important;
    max-width: 340px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .bsm-footer-phone,
  .bsm-footer-contact a {
    width: auto !important;
    max-width: 340px !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-content: center !important;
  }

  .bsm-footer-col h2,
  .bsm-footer-col h3,
  .bsm-footer-col h4,
  .site-footer h2,
  .site-footer h3,
  .site-footer h4,
  .ct-footer h2,
  .ct-footer h3,
  .ct-footer h4,
  .bsm-footer h2,
  .bsm-footer h3,
  .bsm-footer h4 {
    margin-top: 0 !important;
    margin-bottom: 12px !important;
    font-size: 22px !important;
    text-align: left !important;
  }
}

/* =========================
   MOBILE STICKY CALL TEXT APPLY BAR
========================= */

@media (min-width: 768px) {
  .bsm-mobile-cta,
  .mobile-cta,
  .footer-mobile-cta,
  .sticky-footer-cta,
  .bsm-me-mobile-sticky,
  .bsm-mobile-sticky,
  .bsm-sticky-cta {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .bsm-mobile-cta,
  .mobile-cta,
  .footer-mobile-cta,
  .sticky-footer-cta,
  .bsm-me-mobile-sticky,
  .bsm-mobile-sticky,
  .bsm-sticky-cta {
    position: fixed !important;
    left: 14px !important;
    right: 14px !important;
    bottom: 12px !important;
    z-index: 9999 !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
    background: #ffffff !important;
    border-radius: 26px !important;
    padding: 8px !important;
    box-shadow: 0 14px 34px rgba(0, 74, 208, 0.22) !important;
  }

  .bsm-mobile-cta a,
  .mobile-cta a,
  .footer-mobile-cta a,
  .sticky-footer-cta a,
  .bsm-me-mobile-sticky a,
  .bsm-mobile-sticky a,
  .bsm-sticky-cta a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 42px !important;
    border-radius: 22px !important;
    background: #3530d4 !important;
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    line-height: 1 !important;
    text-align: center !important;
  }
}

/* =========================
   TABLET SERVICE AREA
========================= */

@media (max-width: 1024px) {
  .bsm-service-area,
  .bsm-me-service-area,
  .bsm-location-section {
    width: min(920px, calc(100% - 40px)) !important;
    grid-template-columns: minmax(0, 1fr) 360px !important;
    column-gap: 30px !important;
    padding: 40px 32px !important;
  }

  .bsm-service-area img,
  .bsm-me-service-area img,
  .bsm-location-section img,
  .bsm-service-area figure,
  .bsm-me-service-area figure,
  .bsm-location-section figure {
    max-width: 360px !important;
  }

  .bsm-service-area figure img,
  .bsm-me-service-area figure img,
  .bsm-location-section figure img {
    max-width: 360px !important;
  }
}

/* =========================
   MOBILE SERVICE AREA AND FINAL CTA
========================= */

@media (max-width: 767px) {
  .bsm-service-area,
  .bsm-me-service-area,
  .bsm-location-section,
  .bsm-me-section--final,
  .bsm-final-cta,
  .bsm-me-final-cta {
    width: calc(100% - 32px) !important;
    display: block !important;
    margin: 38px auto 34px !important;
    padding: 32px 22px 34px !important;
    border-radius: 24px !important;
    text-align: left !important;
  }

  .bsm-service-area h2,
  .bsm-service-area h3,
  .bsm-me-service-area h2,
  .bsm-me-service-area h3,
  .bsm-location-section h2,
  .bsm-location-section h3,
  .bsm-me-section--final h2,
  .bsm-final-cta h2,
  .bsm-me-final-cta h2 {
    font-size: 30px !important;
    line-height: 1.12 !important;
    text-align: left !important;
  }

  .bsm-service-area > p:not(:has(a)),
  .bsm-me-service-area > p:not(:has(a)),
  .bsm-location-section > p:not(:has(a)),
  .bsm-me-section--final p,
  .bsm-final-cta p,
  .bsm-me-final-cta p {
    text-align: left !important;
    margin-bottom: 24px !important;
    font-size: 16px !important;
    line-height: 1.55 !important;
  }

  .bsm-service-area .bsm-chip-list,
  .bsm-service-area .bsm-town-list,
  .bsm-service-area .bsm-location-list,
  .bsm-me-service-area .bsm-chip-list,
  .bsm-me-service-area .bsm-town-list,
  .bsm-me-service-area .bsm-location-list,
  .bsm-location-section .bsm-chip-list,
  .bsm-location-section .bsm-town-list,
  .bsm-location-section .bsm-location-list {
    justify-content: flex-start !important;
    gap: 10px !important;
    max-width: 100% !important;
  }

  .bsm-service-area .bsm-chip,
  .bsm-service-area .bsm-town,
  .bsm-service-area .bsm-chip-list span,
  .bsm-service-area .bsm-town-list span,
  .bsm-service-area .bsm-location-list span,
  .bsm-me-service-area .bsm-chip,
  .bsm-me-service-area .bsm-town,
  .bsm-me-service-area .bsm-chip-list span,
  .bsm-me-service-area .bsm-town-list span,
  .bsm-me-service-area .bsm-location-list span,
  .bsm-location-section .bsm-chip,
  .bsm-location-section .bsm-town,
  .bsm-location-section .bsm-chip-list span,
  .bsm-location-section .bsm-town-list span,
  .bsm-location-section .bsm-location-list span {
    font-size: 14px !important;
    min-height: 38px !important;
    padding: 9px 14px !important;
  }

  .bsm-service-area a[href^="tel:"],
  .bsm-me-service-area a[href^="tel:"],
  .bsm-location-section a[href^="tel:"] {
    width: 100% !important;
    margin: 22px 0 24px !important;
    font-size: 15px !important;
  }

  .bsm-service-area img,
  .bsm-me-service-area img,
  .bsm-location-section img,
  .bsm-service-area figure,
  .bsm-me-service-area figure,
  .bsm-location-section figure {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    border-radius: 22px !important;
  }

  .bsm-me-section--final .bsm-me-actions,
  .bsm-final-cta .bsm-me-actions,
  .bsm-me-final-cta .bsm-me-actions,
  .bsm-me-section--final .bsm-actions,
  .bsm-final-cta .bsm-actions,
  .bsm-me-final-cta .bsm-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    width: 100% !important;
  }

  .bsm-me-section--final a,
  .bsm-final-cta a,
  .bsm-me-final-cta a {
    width: 100% !important;
    min-height: 50px !important;
  }
}

/* =========================
   EDITOR PREVIEW CLEANUP
========================= */

.elementor-editor-active .bsm-footer,
.elementor-editor-active .site-footer,
.elementor-editor-active .ct-footer,
.elementor-editor-active footer {
  overflow: visible !important;
  height: auto !important;
  max-height: none !important;
}

.elementor-editor-active .bsm-footer .elementor-widget,
.elementor-editor-active .site-footer .elementor-widget,
.elementor-editor-active .ct-footer .elementor-widget,
.elementor-editor-active footer .elementor-widget {
  margin-bottom: 0 !important;
}

/* =========================
   REMOVE FOOTER TOP LINE
   BSM Maine
========================= */

footer,
footer.site-footer,
.ct-footer,
.ct-footer [data-row],
.ct-footer [data-row] > div,
.ct-footer .ct-container,
.ct-footer .ct-footer-copyright,
#footer,
#footer [data-row],
#footer .ct-container {
  border-top: none !important;
  box-shadow: none !important;
}

footer::before,
footer::after,
.ct-footer::before,
.ct-footer::after,
#footer::before,
#footer::after,
.ct-footer [data-row]::before,
.ct-footer [data-row]::after {
  display: none !important;
  content: none !important;
  border: none !important;
  box-shadow: none !important;
}

/* =========================
   BSM Maine Header Final Clean Layout
   Logo | Centered Menu | Call/Text
========================= */

@media (min-width: 1000px) {

  /* Header row */
  .ct-header [data-row] {
    min-height: 82px !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    background: #ffffff !important;
    border-bottom: none !important;
    box-shadow: none !important;
  }

  .ct-header .ct-container {
    max-width: 1360px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding-left: 28px !important;
    padding-right: 28px !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
  }

  /* Logo */
  .ct-header [data-id="logo"],
  .ct-header [data-id="logo"] a,
  .ct-header .site-branding,
  .ct-header .ct-logo,
  .ct-header .site-logo-container {
    display: flex !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .ct-header [data-id="logo"] img,
  .ct-header .site-branding img,
  .ct-header .ct-logo img,
  .ct-header .site-logo-container img,
  .ct-header img.custom-logo,
  .site-branding img,
  .custom-logo,
  .site-logo-container img {
    display: block !important;
    width: 250px !important;
    max-width: 250px !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
  }

  header [data-id="logo"],
  .ct-header [data-id="logo"] {
    margin-right: 22px !important;
  }

  /* Menu container */
  .ct-header [data-id="menu"] {
    flex: 1 1 auto !important;
    margin-left: 20px !important;
    margin-right: 26px !important;
    min-width: 0 !important;
  }

  .ct-header .menu {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 20px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    transform: translateX(10px) !important;
  }

  .ct-header .menu > li {
    position: relative !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .ct-header .menu > li > a,
  .ct-header nav a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 38px !important;
    padding: 8px 0 !important;
    color: var(--bsm-navy) !important;
    background: transparent !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    white-space: nowrap !important;
  }

  .ct-header .menu > li > a:hover,
  .ct-header nav a:hover {
    color: var(--bsm-blue) !important;
    text-decoration: none !important;
  }

  /* Active menu pill */
  .ct-header .menu > li.current-menu-item > a,
  .ct-header .menu > li.current-menu-ancestor > a,
  .ct-header .menu > li.current_page_item > a,
  .ct-header .menu > li.current_page_parent > a,
  .ct-header .menu > li.current_page_ancestor > a {
    padding: 10px 16px !important;
    background: var(--bsm-blue) !important;
    color: #ffffff !important;
    border-radius: 999px !important;
    box-shadow: 0 10px 22px rgba(0, 74, 208, 0.18) !important;
  }

  /* Dropdown menu */
  .ct-header .sub-menu,
  .ct-header .menu .sub-menu,
  .ct-header nav .sub-menu {
    position: absolute !important;
    top: calc(100% + 14px) !important;
    left: 0 !important;
    z-index: 99999 !important;
    min-width: 275px !important;
    width: 275px !important;
    padding: 12px 0 !important;
    margin: 0 !important;
    border-radius: 18px !important;
    border: 1px solid rgba(0, 74, 208, 0.06) !important;
    background: #ffffff !important;
    box-shadow: 0 22px 55px rgba(17, 34, 68, 0.16) !important;
    overflow: visible !important;
  }

  .ct-header .sub-menu li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .ct-header .sub-menu li:first-child {
    border-bottom: 1px solid #eef2f7 !important;
    margin-bottom: 6px !important;
    padding-bottom: 6px !important;
  }

  .ct-header .sub-menu li a,
  .ct-header .menu .sub-menu li a,
  .ct-header nav .sub-menu li a {
    display: block !important;
    width: 100% !important;
    padding: 14px 22px !important;
    color: var(--bsm-navy) !important;
    background: #ffffff !important;
    border-radius: 0 !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
    text-transform: none !important;
    text-decoration: none !important;
    white-space: nowrap !important;
  }

  .ct-header .sub-menu li a:hover,
  .ct-header .menu .sub-menu li a:hover,
  .ct-header nav .sub-menu li a:hover {
    color: var(--bsm-blue) !important;
    background: #f7fbff !important;
  }

  /* Call/Text button */
  .bsm-header-contact {
    margin-left: 26px !important;
    flex-shrink: 0 !important;
  }

  .bsm-header-contact a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 46px !important;
    padding: 12px 24px !important;
    border-radius: 999px !important;
    background: var(--bsm-blue) !important;
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    box-shadow: 0 12px 28px rgba(0, 74, 208, 0.24) !important;
  }

  .bsm-header-contact a:hover {
    background: var(--bsm-blue-dark) !important;
    color: #ffffff !important;
    text-decoration: none !important;
  }
}

/* ================================
   FINAL FIX - Maine Desktop Dropdown Spacing
================================ */

@media (min-width: 1000px) {
  .ct-header .menu .sub-menu {
    padding: 8px 0 !important;
  }

  .ct-header .menu .sub-menu li,
  .ct-header .menu .sub-menu li:first-child {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-bottom: 0 !important;
  }

  .ct-header .menu .sub-menu li a,
  .ct-header .menu .sub-menu li:first-child a {
    padding: 12px 22px !important;
    line-height: 1.2 !important;
    border: 0 !important;
    box-shadow: none !important;
  }
}