/*
Theme Name: Beaver Builder Child Theme
Theme URI: http://www.wpbeaverbuilder.com
Version: 1.0
Description: An example child theme that can be used as a starting point for custom development.
Author: The Beaver Builder Team
Author URI: http://www.fastlinemedia.com
template: bb-theme
*/

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

a,
a:link,
a:visited,
a:hover,
a:focus,
button,
input:focus,
input[type="button"],
input[type="reset"],
input[type="submit"],
textarea:focus,
.button,
.gallery img,
a.fl-button {
    transition: all 0.25s ease-in-out !important;
}

p {
	margin-bottom: 25px;
}

ul, ol {
    margin-bottom: 25px;
	padding-inline-start: 20px;
}

ul > li {
	margin-bottom: 8px;
}

.zbump {
	position: relative;
	z-index: 99999;
}

/* --- Text Styles --- */

.large-text {
    font-family: "borax-variable", Verdana, Arial, sans-serif;
	font-size: 56px;
    font-weight: 400;
    line-height: 1.1;
}

.large-text-script {
	font-family: "Ms Madi", cursive;
	font-size: 70px;
	font-weight: 400;
	line-height: 1.1;
}
	
.large-body  {
	font-size: 18px;
	line-height: 1.5;
}

.small-body {
	font-size: 14px;
	line-height: 1.5;
}

.tagline {
	font-family: "dm-sans",Verdana,Arial,sans-serif;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
}

.inner-hero h2,
.product_title.entry-title {
	font-size: 80px;
	line-height: 1.1;
}

.inner-hero .large-text-script {
	color: #FC6F6A !important;
	font-family: "Ms Madi", cursive;
	font-size: 110px;
	font-weight: 400;
	line-height: 1;
}


@media (max-width: 1023px){
	
	.inner-hero h2,
	.product_title.entry-title {
		font-size: 50px;
		line-height: 1.1;
	}
	
	.inner-hero .large-text-script {
		font-size: 65px;
		line-height: 1;
	}
	
	.large-text {
		font-size: 30px;
	    line-height: 1.1;
	}

	.large-text-script {
		font-size: 45px;
		line-height: 1.1;
	}
	
}
	


/* --- Button Styles --- */

.haven-button .fl-button,
.haven-button .fl-button:visited {
  font-size: 16px !important;
  line-height: 1 !important;
  padding: 15px 25px !important;
  border: none !important;
  border-radius: 30px !important;
}


/* Beaver Builder button arrow after text */
.fl-button-text {
  display: inline-flex;
  align-items: center;
}

.fl-button-text .arrow {
  display: inline-block;
  width: 25px;
  height: 11.5px;
  margin-left: 12px;
  background-image: url('/wp-content/uploads/2026/01/button-arrow.png');
  background-repeat: no-repeat;
  background-size: 25px 11.5px;
  background-position: center;
  flex-shrink: 0;
}



/* --- Haven Header --- */

.haven-header .fl-row-content-wrap .fl-row-content {
  display: flex;
  align-items: center;
}

.haven-header .logo-col,
.haven-header .menu-col {
  flex: 0 0 auto !important;
  width: auto !important;
}

.haven-header .utility-col {
  color: #fff;
  flex: 1 1 auto !important;
  width: auto !important;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  text-align: right;
}

@media (max-width: 768px){

  /* Keep the remaining column group left-aligned */
  .haven-header .fl-col-group{
    justify-content: flex-start !important;
  }

  /* Ensure the logo column doesn’t “auto-center” */
  .haven-header .logo-col{
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  /* And make the image/module align left */
  .haven-header .logo-col .fl-photo{
    text-align: left !important;
  }
}


/* --- Haven Nav --- */

.haven-nav .menu a {
	color: #fff;
}


/* --- Home Value --- */

.home-value .value-heading {
    margin-left: auto;
    margin-right: auto;
    max-width: 440px;
}

.home-value .value-text {
    margin-left: auto;
    margin-right: auto;
    max-width: 550px;
}


/* --- Home Familycare --- */

.home-familycare {
	margin: 40px;
}

.home-familycare .fl-row-content-wrap {
  background-color: #36384C;
  background-image: url('/wp-content/uploads/2026/01/haven-pattern.svg');
  background-repeat: no-repeat;
  background-size: cover;
}

.home-familycare .heading-text {
	color: #fff;
	max-width: 900px;
}

.home-familycare .large-text-script {
	color: #fc6f6a;
}

.home-familycare .large-text-script-tm {
	color: #fc6f6a;
	font-family: "dm-sans", Verdana, Arial, sans-serif;
	font-size: 16px;
    font-weight: 400;
	position: relative;
	top: 21px;
	vertical-align: top;
}

@media (max-width: 1023px){
	
	.home-familycare {
		margin: 40px 0;
	}
	
}



/* --- Home Community --- */

.home-community .value-text {
	max-width: 430px;
}

@media (max-width: 1023px){
	
	.home-community .value-text {
		max-width: 100%;
	}
	
}


/* --- Haven Post Grid --- */

.fl-module-post-grid .fl-post-grid-post {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.fl-module-post-grid,
.fl-module-post-grid .fl-module-content,
.fl-module-post-grid .fl-post-grid,
.fl-module-post-grid .fl-post-column,
.fl-module-post-grid .fl-post-grid-post,
.fl-module-post-grid .fl-post-grid-post > div {
  overflow: visible !important;
}

.fl-module-post-grid .fl-post-grid {
  margin-left: -10px;
  margin-right: -10px;
  display: flex;
  flex-wrap: wrap;
}

.fl-module-post-grid .fl-post-column {
  padding-left: 10px;
  padding-right: 10px;
  padding-bottom: 0;
  margin-bottom: 20px;
  display: flex;
}

.fl-module-post-grid .fl-post-grid-post {
  width: 100%;
  display: flex;
}

.fl-module-post-grid .haven-post-card {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 0 !important;
  outline: 0 !important;
  border-radius: 0;
  box-shadow: 0 8px 20px rgba(0,0,0,.10);
  overflow: hidden;
  transition: background-color .2s ease;
}

.fl-module-post-grid .haven-post-card::before,
.fl-module-post-grid .haven-post-card::after {
  content: none !important;
  border: 0 !important;
}

.fl-module-post-grid .haven-post-card:hover {
  background: #f4f6f7;
}

.fl-module-post-grid .haven-post-media {
  position: relative;
  overflow: hidden;
}

.fl-module-post-grid .haven-post-media img {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
  transform: scale(1);
  transition: transform .35s ease;
}

.fl-module-post-grid .haven-post-card:hover .haven-post-media img {
  transform: scale(1.15);
}

.fl-module-post-grid .haven-post-pill {
  position: absolute;
  top: 20px;
  left: 20px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  color: #36384c;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

.fl-module-post-grid .haven-post-cat a {
  color: #36384c;
}

.fl-module-post-grid .haven-post-body {
  padding: 20px;
  flex: 1;
}

.fl-module-post-grid .haven-post-title {
  margin: 0 0 10px;
  font-size: 26px;
  line-height: 1;
}

.fl-module-post-grid .haven-post-title a {
  text-decoration: none;
  color: inherit;
}

.fl-module-post-grid .haven-post-excerpt {
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
}

.fl-module-post-grid .haven-post-excerpt p {
  margin-bottom: 0;
}



/* --- Haven Testimonials --- */

.haven-testimonials blockquote {
	border: none;
	color: #36384c;
	font-family: "borax-variable", Verdana, Arial, sans-serif;
	font-size: 30px;
    font-weight: 400;
    line-height: 1.1;
}


/* --- Home CTA --- */

.home-cta .fl-row-content-wrap {
  background-color: #36384C;
  background-image: url('/wp-content/uploads/2026/01/haven-pattern.svg');
  background-repeat: no-repeat;
  background-size: cover;
	color: #fff;
}


/* --- Home Social --- */

.home-social .social-heading,
.home-social .social-text {
    margin-left: auto;
    margin-right: auto;
    max-width: 560px;
}

@media (max-width: 1023px){
		
	.home-social .social-heading,
	.home-social .social-text {
	    max-width: 100%;
	}
	
}


/* --- Haven Footer --- */

.haven-footer .footer-heading,
.haven-footer .footer-text {
    max-width: 400px;
}

.haven-footer .footer-links h5 {
	font-size: 17px;
}

.haven-footer .footer-links {
	font-size: 14px;
}

.haven-footer .footer-links ul {
	list-style-type: none;
	padding-inline-start: 0;
}

.haven-footer .footer-links ul > li {
	margin-bottom: 0;
}

.haven-footer-credits {
	font-size: 14px;
	line-height: 1.5;
}

.footer-links a,
.haven-footer-credits a {
	text-decoration: none;
}

.footer-links a:hover,
.haven-footer-credits a:hover {
	text-decoration: underline;
}

@media (max-width: 768px){
	
	.haven-footer .footer-heading,
	.haven-footer .footer-text {
    	max-width: 100%;
	}

	.haven-footer .footer-links {
		max-width: 600px;
	}
	
	.haven-footer .footer-links ul {
    	display: grid;
    	grid-template-columns: repeat(2, 1fr);
    	column-gap: 24px;
    	row-gap: 8px;
		margin-bottom: 0;
  	}
	
	.haven-footer .footer-links .badge {
		padding-top: 20px;
	}

}


/* --- Haven Savings --- */

.haven-savings {
	margin: 40px;
}

.haven-savings.inner-hero {
	margin: 0 40px 40px;
}

.haven-savings .fl-row-content-wrap {
  background-color: #d6e0e2;
  background-image: url('/wp-content/uploads/2026/01/haven-pattern-white.svg');
  background-repeat: no-repeat;
  background-size: cover;
}

@media (max-width: 1023px){
	
	.haven-savings {
		margin: 40px 0;
	}
	
	.haven-savings.inner-hero {
		margin: 0 0 40px;
	}
	
}



/* --- Haven Membership Subnav Row --- */

.haven-subnav{
  display: flex;
  justify-content: center;
  gap: 90px; 
  align-items: center;
}

/* Links */
.haven-subnav__link{
  color: #36384C;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  line-height: 1.2;
  display: inline-block;
  padding-bottom: 2px;
}

.haven-subnav__link.is-active{
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

.haven-subnav__link:hover{
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

@media (max-width: 1023px){
	
	.haven-subnav{
  		gap: 20px; 
	}

}


/* --- Haven Accordions --- */

.haven-accordion .fl-accordion-button {
  align-items: center;
}

.haven-accordion .fl-accordion-button-icon {
  transform: translateY(2px);
}

.haven-accordion .fl-accordion-button-icon i {
  font-size: 0;
  line-height: 0;
  width: 27px;
  height: 23px;
  display: inline-block;
  position: relative;
}

.haven-accordion .fl-accordion-button-icon i::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/wp-content/uploads/2026/01/accordion-plus.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.haven-accordion
.fl-accordion-button-icon[aria-expanded="true"] i::before {
  transform: rotate(45deg);
}

.haven-accordion
.fl-accordion-button
.fl-accordion-button-icon-left,
.haven-accordion
.fl-accordion-button
.fl-accordion-button-icon-right {
  opacity: 1;
}

.haven-accordion
.fl-accordion-button:hover
.fl-accordion-button-icon-left,
.haven-accordion
.fl-accordion-button:hover
.fl-accordion-button-icon-right {
  opacity: 0.75;
}

.haven-accordion
.fl-accordion-content[aria-hidden="false"] > p:last-of-type {
  margin-bottom: 0;
}


/* --- Membership Checkmark List Style --- */

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

.membership-list li {
  position: relative;
  padding-left: 34px; /* space for the checkmark */
  margin-bottom: 20px;
}

.membership-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.25em; /* aligns icon with first line of text */
  width: 19px;
  height: 16px;
  background-image: url("/wp-content/uploads/2026/01/icon-checkmark.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}




/* ===============================
   HAVEN ARROW REVEAL SYSTEM
   =============================== */
.arrow-reveal { position: relative; }

.arrow-reveal .fl-photo-content{
  position: relative;
  overflow: visible;
}

.arrow-reveal .fl-photo-content img{
  position: relative;
  z-index: 1;
}

.arrow-reveal .fl-photo-content::after{
  content:"";
  position:absolute;
  z-index:2;
  pointer-events:none;

  /* placement (defaults to bottom-right) */
  right: var(--arrow-right, -24px);
  bottom: var(--arrow-bottom, -24px);
  left: var(--arrow-left, auto);
  top: var(--arrow-top, auto);

  width: var(--arrow-w, 200px);
  height: var(--arrow-h, 115px);

  background-image: var(--arrow-image);
  background-repeat:no-repeat;
  background-size:contain;
  background-position:center;

  opacity:0;
  clip-path: inset(0 100% 0 0);
  transform: translateX(-28px) scale(.92);

  transition:
    clip-path 1.1s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.1s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.4s ease-out;

  transition-delay: var(--arrow-delay, 150ms);
}

.arrow-reveal.is-visible .fl-photo-content::after{
  opacity:1;
  clip-path: inset(0 0 0 0);
  transform: translateX(0) scale(1);
}

/* left-side arrows slide in from the right */
.arrow-reveal.left .fl-photo-content::after{
  transform: translateX(28px) scale(.92);
}
.arrow-reveal.left.is-visible .fl-photo-content::after{
  transform: translateX(0) scale(1);
}


/* Arrow that are image module images */

.draw-right-arrow {
  position: relative;
}

.draw-right-arrow .fl-photo-content{
  overflow: visible;
}

/* Base hidden state */
.draw-right-arrow img{
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: clip-path;
}

/* Reveal */
.draw-right-arrow.is-visible img{
  clip-path: inset(0 0 0 0);
}



/* ===============================
   HAVEN ICON REVEAL SYSTEM
   =============================== */

.icon-reveal .fl-photo-content {
  position: relative;
  overflow: visible;
}

.icon-reveal .fl-photo-content::after {
  content: "";
  position: absolute;
  z-index: 2;
  pointer-events: none;
  width: var(--icon-w, 120px);
  height: var(--icon-h, 120px);
  top: var(--icon-top, auto);
  right: var(--icon-right, auto);
  bottom: var(--icon-bottom, auto);
  left: var(--icon-left, auto);
  background-image: var(--icon-image);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0;
  transition: opacity 2.2s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--icon-delay, 150ms);
  will-change: opacity;
}

.icon-reveal.is-visible .fl-photo-content::after {
  opacity: 1;
}




/* ======================================
   Gravity Forms — Button Style Match (HARD OVERRIDE)
   ====================================== */

body .gform_wrapper .gform_footer input[type="submit"],
body .gform_wrapper .gform_page_footer input[type="submit"],
body .gform_wrapper .gform_footer input[type="button"],
body .gform_wrapper .gform_page_footer input[type="button"],
body .gform_wrapper .gform_footer button,
body .gform_wrapper .gform_page_footer button{
  appearance: none !important;
  -webkit-appearance: none !important;

  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  padding: 15px 25px !important;

  border-radius: 30px !important;
  border: 0 !important;

  background: #d6e0e2 !important;
  color: #36384c !important;

  cursor: pointer !important;
  text-decoration: none !important;
  box-shadow: none !important;

  transition: background-color 0.25s ease, color 0.25s ease !important;
}

/* Hover */
body .gform_wrapper .gform_footer input[type="submit"]:hover,
body .gform_wrapper .gform_page_footer input[type="submit"]:hover,
body .gform_wrapper .gform_footer input[type="button"]:hover,
body .gform_wrapper .gform_page_footer input[type="button"]:hover,
body .gform_wrapper .gform_footer button:hover,
body .gform_wrapper .gform_page_footer button:hover{
  background: #36384c !important;
  color: #fff !important;
}

/* Focus (keyboard) */
body .gform_wrapper .gform_footer input[type="submit"]:focus-visible,
body .gform_wrapper .gform_page_footer input[type="submit"]:focus-visible,
body .gform_wrapper .gform_footer input[type="button"]:focus-visible,
body .gform_wrapper .gform_page_footer input[type="button"]:focus-visible,
body .gform_wrapper .gform_footer button:focus-visible,
body .gform_wrapper .gform_page_footer button:focus-visible{
  outline: 2px solid #36384c !important;
  outline-offset: 3px !important;
}





/* =========================================================
   HAVEN — Woo Buttons (archives + common Woo buttons)
   ========================================================= */

/* Base button style */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.add_to_cart_button,
.woocommerce a.product_type_simple,
.woocommerce a.product_type_variable,
.woocommerce a.product_type_grouped,
.woocommerce a.product_type_external{
  background: #d6e0e2 !important;
  color: #36384c !important;
  border: 0 !important;
  border-radius: 30px !important;
  padding: 15px 25px !important;
  box-sizing: border-box !important;
  transition: all 0.25s ease-in-out !important;
  box-shadow: none !important;
  outline: none !important;
  font-size: 15px !important;
  text-align: center;
}

/* Hover / focus / active */
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.add_to_cart_button:hover,
.woocommerce a.product_type_simple:hover,
.woocommerce a.product_type_variable:hover,
.woocommerce a.product_type_grouped:hover,
.woocommerce a.product_type_external:hover,
.woocommerce a.button:focus,
.woocommerce button.button:focus,
.woocommerce input.button:focus,
.woocommerce #respond input#submit:focus,
.woocommerce a.button:active,
.woocommerce button.button:active,
.woocommerce input.button:active,
.woocommerce #respond input#submit:active{
  background: #36384c !important;
  color: #ffffff !important;
  box-shadow: none !important;
  outline: none !important;
}

/* If your theme adds pseudo elements or gradients to buttons, kill them */
.woocommerce a.button::before,
.woocommerce a.button::after,
.woocommerce button.button::before,
.woocommerce button.button::after{
  content: none !important;
}

/* Shop Archive Styles */
.woocommerce ul.products li.product .woocommerce-loop-category__title, .woocommerce ul.products li.product .woocommerce-loop-product__title, .woocommerce ul.products li.product h3 {
    font-size: 20px;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) ul.products li.product .price {
    color: #36384c;
}

/* Woo Product Page */

.woocommerce-tabs h2 {
	font-size: 30px;
}

.woocommerce .quantity .qty {
	margin-right: 10px;
    padding: 13px;
	width: 80px;
}

/* Woo Checkout Page */

.fl-theme-builder-part-woo-checkout-page-header .fl-post-header {
	display: none;
}

.woocommerce-info {
    border-top-color: #d6e0e2;
}

.woocommerce-info::before {
    color: #36384c;
}


/* --- Jude --- */