@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ── HEADER ── */
.site-header, #masthead, .kadence-header {
  background-color: #ffffff !important;
  border-bottom: 1px solid #dce7ec !important;
  box-shadow: none !important;
}

.main-navigation a,
.kadence-navigation a,
header nav a {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #0f172a !important;
  text-decoration: none !important;
  letter-spacing: 0 !important;
  transition: color 0.15s ease !important;
}

.main-navigation a:hover,
.kadence-navigation a:hover,
header nav a:hover {
  color: #2f6f73 !important;
}

.main-navigation .current-menu-item > a,
.kadence-navigation .current-menu-item > a {
  color: #2f6f73 !important;
}

.main-navigation ul, .kadence-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── HIDE KADENCE TOGGLE ── */
.menu-item-has-children .sub-menu-toggle,
button.sub-menu-toggle {
  display: none !important;
}

.main-navigation .menu-item-has-children > a > svg,
.kadence-navigation .menu-item-has-children > a > svg {
  display: none !important;
}

/* ── HIDE ::after CHEVRON ── */
.main-navigation .menu-item-has-children > a::after,
.kadence-navigation .menu-item-has-children > a::after {
  display: none !important;
  content: none !important;
}

/* ── SUPPRESS KADENCE SUB-MENU ── */
.main-navigation .menu-item-has-children .sub-menu,
.kadence-navigation .menu-item-has-children .sub-menu {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* ── MEGA DROPDOWN ── */
.wv-mega-drop {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%);
  width: 500px;
  background: #ffffff;
  border-radius: 34px;
  border: 1px solid #dce7ec;
  padding: 16px;
  box-shadow: 0 24px 60px rgba(10,37,64,0.12);
  z-index: 999999;
  pointer-events: auto;
}

.wv-mega-drop::before {
  content: '';
  position: absolute;
  top: -20px;
  left: 0; right: 0;
  height: 20px;
}

.wv-mega-label {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #92a2b8;
  padding: 16px 16px 16px 16px;
  display: block;
}

.wv-mega-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 10px;
  border-radius: 28px;
  text-decoration: none !important;
  transition: background-color 0.15s ease;
  margin-bottom: 0;
}

.wv-mega-row:hover {
  background-color: #eef3f7;
  text-decoration: none !important;
}

.wv-mega-row-left {
  display: flex;
  align-items: center;
  gap: 18px;
}

.wv-mega-icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
  background-color: #dde6ed !important;
  border-radius: 50% !important;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #2f6f73;
}

.wv-mega-icon svg {
  width: 20px;
  height: 20px;
  stroke: #2f6f73;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  display: block;
}

.wv-mega-title {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #17314c;
  line-height: 1.4;
  display: inline;
}

.wv-mega-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 4px;
  font-family: 'Inter', sans-serif;
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.8px;
  color: #2f6f73;
  border: 1px solid rgba(93,202,165,0.20);
  background-color: rgba(93,202,165,0.10);
  border-radius: 999px;
  padding: 4px 6px;
  white-space: nowrap;
  line-height: 1;
}

.wv-mega-desc {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: #60758d;
  margin-top: 4px;
  line-height: 1.45;
}

.wv-mega-row-arrow {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  color: #0f172a;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wv-mega-row-arrow svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.wv-mega-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  border-top: 1px solid #d6e0e8;
  padding: 16px 16px 8px 16px;
}

.wv-mega-cta-text {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: #95a7ba;
}

.wv-mega-cta-link,
.wv-mega-cta .wv-mega-cta-link,
.wv-mega-drop .wv-mega-cta-link {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #2f6f73 !important;
  text-decoration: none !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: gap 0.15s ease, color 0.15s ease !important;
}

.wv-mega-cta-link:hover,
.wv-mega-cta .wv-mega-cta-link:hover,
.wv-mega-drop .wv-mega-cta-link:hover {
  color: #0f766e !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  gap: 8px !important;
  text-decoration: none !important;
}

.wv-mega-cta-link svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ── HEADER CONTACT BUTTON ── */
.kadence-header-button .kb-btn,
.kadence-header-button a,
header .header-button-wrap a,
header .kadence-btn,
.wp-block-kadence-header .kb-btn,
header a[href*="contact"]:not(.wv-mega-cta-link):not(.wv-mega-row) {
  font-family: 'Inter', sans-serif !important;
  background-color: #2f6f73 !important;
  background-image: none !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  padding: 10px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  border: none !important;
  box-shadow: none !important;
  transition: background-color 0.2s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
}

.kadence-header-button .kb-btn:hover,
.kadence-header-button a:hover,
header .header-button-wrap a:hover,
header .kadence-btn:hover,
header a[href*="contact"]:not(.wv-mega-cta-link):not(.wv-mega-row):hover {
  background-color: #2f6f73 !important;
  color: #ffffff !important;
}

/* ── FOOTER BACKGROUND ── */
.site-footer, #colophon {
  background-color: #071e3d !important;
  background-image: radial-gradient(rgba(93,202,165,0.07) 1px, transparent 1px) !important;
  background-size: 28px 28px !important;
  color: #64748b !important;
  border-top: 3px solid transparent !important;
  border-image: linear-gradient(to right, #1D9E75 0%, #5DCAA5 40%, transparent 100%) 1 !important;
}

.site-footer > *,
.footer-widget-area,
.kadence-footer-widgets,
.kadence-footer,
[id*="footer"],
[class*="kadence-footer"] {
  background-color: transparent !important;
  background-image: none !important;
}

.site-footer .wp-block-group,
.site-footer section,
.site-footer .kb-section,
.site-footer [class*="wp-block"] {
  background-color: transparent !important;
  background-image: none !important;
}

/* ── FOOTER LIST RESET ── */
.footer-widget-area ul, .footer-widget-area ol,
.site-footer ul, .site-footer ol {
  list-style: none !important;
  list-style-type: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-widget-area li, .site-footer li {
  list-style: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}

.footer-widget-area li::before, .footer-widget-area li::marker,
.site-footer li::before, .site-footer li::marker {
  display: none !important;
  content: none !important;
}

/* ── FOOTER HEADINGS ── */
.footer-widget-area .widget-title,
.footer-widget-area h4, .footer-widget-area h4,
.footer-widget-area h4, .footer-widget-area h4,
.site-footer .widget-title,
.site-footer h4, .site-footer h5,
.site-footer h4, .site-footer h5 {
  font-family: 'Inter' !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  color: #5DCAA5 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  padding-bottom: 12px !important;
  margin-bottom: 16px !important;
  margin-top: 0 !important;
  background: none !important;
}

/* ── FOOTER LOGO ── */
.footer-widget-area img[src*="logo"],
.site-footer img[src*="logo"],
.footer-widget-area .custom-logo,
.footer-widget-area .site-logo img {
  width: 120px !important;
  height: auto !important;
  max-width: 120px !important;
  display: block !important;
  margin-bottom: 25px !important;
}

/* ── FOOTER BODY TEXT ── */

.footer-widget-area em, .site-footer em {
  color: #2f6f73 !important;
  font-style: italic !important;
  font-weight: 600 !important;
}

/* ── FOOTER LINKS DEFAULT ── */
.footer-widget-area a,
.site-footer a {
  font-family: 'Inter'!important;
  font-size: 13.5px !important;
  color: #8899aa !important;
  text-decoration: none !important;
  font-weight: 400 !important;
  display: flex !important;
  align-items: center !important;
  padding: 5px 0 !important;
  gap: 0px !important;
  line-height: 1.5 !important;
  transition: color 0.2s ease, gap 0.2s ease !important;
  position: relative !important;
  background: none !important;
}

.footer-widget-area a::before,
.site-footer a::before {
  display: none !important;
  content: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 0 !important;
}

.footer-widget-area a:hover,
.site-footer a:hover {
  color: #ffffff !important;
  text-decoration: none !important;
}

/* ── DOT ANIMATION — Services & Resources columns ── */
.wv-dot-col a {
  gap: 0px !important;
  transition: color 0.2s ease, gap 0.2s ease !important;
}

.wv-dot-col a::before {
  content: '' !important;
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  min-width: 6px !important;
  border-radius: 50% !important;
  background-color: #5DCAA5 !important;
  opacity: 100 !important;
  transform: scale(0) !important;
  flex-shrink: 0 !important;
  margin-right: 0px !important;
  transition: opacity 0.2s ease, transform 0.2s ease, margin-right 0.2s ease !important;
}

.wv-dot-col a:hover {
  color: #ffffff !important;
  gap: 8px !important;
}

.wv-dot-col a:hover::before {
  opacity: 1 !important;
  transform: scale(1) !important;
  margin-right: 8px !important;
}

/* ── COMPANY column — white on hover, NO dot ── */
.wv-company-col a {
  color: #8899aa !important;
  gap: 0 !important;
  transition: color 0.2s ease !important;
}

.wv-company-col a::before {
  display: none !important;
  content: none !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
}

.wv-company-col a:hover {
  color: #5DCAA5 !important;
  gap: 0 !important;
}

/* ── GET IN TOUCH column — teal on hover, NO dot ── */
.wv-contact-col a {
  gap: 10px !important;
  color: #8899aa !important;
  font-size: 13px !important;
  align-items: center !important;
  padding: 4px 0 !important;
  transition: color 0.2s ease !important;
}

.wv-contact-col a::before {
  display: none !important;
  content: none !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
}

.wv-contact-col a:hover {
  color: #2f6f73 !important;
  gap: 10px !important;
}

/* ── SOCIAL ICONS ── */
.footer-widget-area .wp-block-social-links,
.site-footer .wp-block-social-links {
  display: flex !important;
  gap: 8px !important;
  margin-top: 16px !important;
  padding: 0 !important;
  list-style: none !important;
}

.footer-widget-area .wp-block-social-link,
.footer-widget-area .wp-social-link,
.site-footer .wp-block-social-link {
  width: 36px !important;
  height: 36px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  background-color: rgba(255,255,255,0.05) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: border-color 0.25s ease, background-color 0.25s ease, box-shadow 0.25s ease !important;
}

.footer-widget-area .wp-block-social-link:hover,
.footer-widget-area .wp-social-link:hover,
.site-footer .wp-block-social-link:hover {
  border-color: #2f6f73 !important;
  background-color: rgba(47,111,115,0.15) !important;
  box-shadow: 0 0 14px rgba(47,111,115,0.25) !important;
}

.footer-widget-area .wp-block-social-link a,
.site-footer .wp-block-social-link a {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  color: #8899aa !important;
  background: none !important;
  border: none !important;
  gap: 0 !important;
  transition: color 0.25s ease !important;
}

.footer-widget-area .wp-block-social-link:hover a,
.site-footer .wp-block-social-link:hover a {
  color: #2f6f73 !important;
}

.footer-widget-area .wp-block-social-link svg,
.site-footer .wp-block-social-link svg {
  width: 15px !important;
  height: 15px !important;
  fill: currentColor !important;
}

/* ── FOOTER BOTTOM BAR ── */
.site-footer .footer-bottom,
#colophon .site-info,
.kadence-footer-bottom,
.site-footer .site-info {
  background-color: transparent !important;
  border-top: 1px solid rgba(255,255,255,0.07) !important;
  padding: 20px 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: #64748b !important;
}

.site-footer .footer-bottom a,
#colophon .site-info a,
.site-footer .site-info a {
  color: #64748b !important;
  font-size: 13px !important;
  padding: 0 !important;
  display: inline !important;
  background: none !important;
}

.site-footer .footer-bottom strong,
#colophon .site-info strong {
  color: #94a3b8 !important;
  font-weight: 600 !important;
}

/* ── Allow Custom HTML footer links to use their own styles ── */
.site-footer .wv-footer-dot-link,
#colophon .wv-footer-dot-link {
  display: flex !important;
  align-items: center !important;
  gap: 0px !important;
  color: #8fa3b8 !important;
  font-size: 14px !important;
  text-decoration: none !important;
  line-height: 2.4 !important;
  transition: color 0.2s ease, gap 0.2s ease !important;
}

.site-footer .wv-footer-dot-link::before,
#colophon .wv-footer-dot-link::before {
  content: '' !important;
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  min-width: 6px !important;
  border-radius: 50% !important;
  opacity: 0 !important;
  transform: scale(0) !important;
  flex-shrink: 0 !important;
  margin-right: 0px !important;
  transition: opacity 0.2s ease, transform 0.2s ease, margin-right 0.2s ease !important;
}

.site-footer .wv-footer-dot-link:hover,
#colophon .wv-footer-dot-link:hover {
  color: #ffffff !important;
  gap: 8px !important;
}

.site-footer .wv-footer-dot-link:hover::before,
#colophon .wv-footer-dot-link:hover::before {
  opacity: 1 !important;
  transform: scale(1) !important;
  margin-right: 8px !important;
}

/* ── Column 2 & 3 wrapper — increase gap, prevent word break ── */
.site-footer .wv-footer-dot-link,
#colophon .wv-footer-dot-link {
  white-space: nowrap !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
}

/* Remove Kadence widget top padding from footer column 1 */
.site-footer .widget:first-child,
#colophon .widget:first-child,
.site-footer .kb-inside-inner-wrap > *:first-child,
#colophon .kb-inside-inner-wrap > *:first-child {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* ── Remove all Kadence widget padding from footer column 1 ── */
.site-footer .widget_block,
.site-footer .widget,
#colophon .widget_block,
#colophon .widget {
  padding: 0 !important;
  margin: 0 !important;
}

.site-footer .wp-block-html,
#colophon .wp-block-html {
  padding: 0 !important;
  margin: 0 !important;
}

.site-footer .kb-widget-area,
#colophon .kb-widget-area {
  padding: 0 !important;
  margin: 0 !important;
}

.site-footer .kb-inside-inner-wrap,
#colophon .kb-inside-inner-wrap {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.site-footer .footer-widget-area,
#colophon .footer-widget-area {
  padding-top: 25px !important;
  padding-bottom: 15px !important;
}