/**
 * Base CSS used by the builder's layout, including rows
 * and columns. Any module specific global CSS should be
 * included in fl-builder-layout-modules.css.
 */

/* Grid
------------------------------------------------------ */

.fl-builder-content *,
.fl-builder-content *:before,
.fl-builder-content *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.fl-row:before,
.fl-row:after,
.fl-row-content:before,
.fl-row-content:after,
.fl-col-group:before,
.fl-col-group:after,
.fl-col:before,
.fl-col:after,
.fl-module:not([data-accepts]):before,
.fl-module:not([data-accepts]):after,
.fl-module-content:before,
.fl-module-content:after {
	display: table;
	content: " ";
}
.fl-row:after,
.fl-row-content:after,
.fl-col-group:after,
.fl-col:after,
.fl-module:not([data-accepts]):after,
.fl-module-content:after {
	clear: both;
}
.fl-clear {
	clear: both;
}

/* Rows
------------------------------------------------------ */

.fl-row,
.fl-row-content {
	margin-left: auto;
	margin-right: auto;
	min-width: 0;
}
.fl-row-content-wrap {
	position: relative;
}

/* Photo Bg */
.fl-builder-mobile .fl-row-bg-photo .fl-row-content-wrap {
	background-attachment: scroll;
}

/* Video and Embed Code Bg */
.fl-row-bg-video,
.fl-row-bg-video .fl-row-content,
.fl-row-bg-embed,
.fl-row-bg-embed .fl-row-content {
	position: relative;
}

.fl-row-bg-video .fl-bg-video,
.fl-row-bg-embed .fl-bg-embed-code {
	bottom: 0;
	left: 0;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
}

.fl-row-bg-video .fl-bg-video video,
.fl-row-bg-embed .fl-bg-embed-code video {
	bottom: 0;
	left: 0px;
	max-width: none;
	position: absolute;
	right: 0;
	top: 0px;
}
.fl-row-bg-video .fl-bg-video video {
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
}
.fl-row-bg-video .fl-bg-video iframe,
.fl-row-bg-embed .fl-bg-embed-code iframe {
	pointer-events: none;
	width: 100vw;
  	height: 56.25vw; /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
  	max-width: none;
  	min-height: 100vh;
  	min-width: 177.77vh; /* Given a 16:9 aspect ratio, 16/9*100 = 177.77 */
  	position: absolute;
  	top: 50%;
  	left: 50%;
	-ms-transform: translate(-50%, -50%); /* IE 9 */
	-webkit-transform: translate(-50%, -50%); /* Chrome, Safari, Opera */
  	transform: translate(-50%, -50%);
}
.fl-bg-video-fallback {
	background-position: 50% 50%;
	background-repeat: no-repeat;
	background-size: cover;
	bottom: 0px;
	left: 0px;
	position: absolute;
	right: 0px;
	top: 0px;
}

/* Slideshow Bg */
.fl-row-bg-slideshow,
.fl-row-bg-slideshow .fl-row-content {
	position: relative;
}
.fl-row .fl-bg-slideshow {
	bottom: 0;
	left: 0;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 0;
}
.fl-builder-edit .fl-row .fl-bg-slideshow * {
	bottom: 0;
	height: auto !important;
	left: 0;
	position: absolute !important;
	right: 0;
	top: 0;
}

/* Row Bg Overlay */
.fl-row-bg-overlay .fl-row-content-wrap:after {
	border-radius: inherit;
	content: '';
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 0;
}
.fl-row-bg-overlay .fl-row-content {
	position: relative;
	z-index: 1;
}

/* Full Height Rows */
.fl-row-default-height .fl-row-content-wrap,
.fl-row-custom-height .fl-row-content-wrap {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	min-height: 100vh;
}
.fl-row-overlap-top .fl-row-content-wrap {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -moz-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	width: 100%;
}
.fl-row-default-height .fl-row-content-wrap,
.fl-row-custom-height .fl-row-content-wrap {
	min-height: 0;
}

.fl-row-default-height .fl-row-content,
.fl-row-full-height .fl-row-content,
.fl-row-custom-height .fl-row-content {
  -webkit-box-flex: 1 1 auto;
  	 -moz-box-flex: 1 1 auto;
  	  -webkit-flex: 1 1 auto;
  		  -ms-flex: 1 1 auto;
  			  flex: 1 1 auto;
}
.fl-row-default-height .fl-row-full-width.fl-row-content,
.fl-row-full-height .fl-row-full-width.fl-row-content,
.fl-row-custom-height .fl-row-full-width.fl-row-content {
	max-width: 100%;
	width: 100%;
}

/* Full height align center */
.fl-row-default-height.fl-row-align-center .fl-row-content-wrap,
.fl-row-full-height.fl-row-align-center .fl-row-content-wrap,
.fl-row-custom-height.fl-row-align-center .fl-row-content-wrap {
	-webkit-align-items: center;
	-webkit-box-align: center;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-align: center;
	-ms-flex-pack: center;
	justify-content: center;
	align-items: center;
}

/* Full height align bottom */
.fl-row-default-height.fl-row-align-bottom .fl-row-content-wrap,
.fl-row-full-height.fl-row-align-bottom .fl-row-content-wrap,
.fl-row-custom-height.fl-row-align-bottom .fl-row-content-wrap {
	-webkit-align-items: flex-end;
	-webkit-justify-content: flex-end;
	-webkit-box-align: end;
	-webkit-box-pack: end;
	-ms-flex-align: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	align-items: flex-end;
}

/* Column Groups
------------------------------------------------------ */
.fl-col-group-equal-height {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.fl-col-group-equal-height.fl-col-group-has-child-loading {
	flex-wrap: nowrap;
}
.fl-col-group-equal-height .fl-col,
.fl-col-group-equal-height .fl-col-content {
	display: flex;
	flex: 1 1 auto;
}
.fl-col-group-equal-height .fl-col-content {
	flex-direction: column;
	flex-shrink: 1;
	min-width: 1px;
	max-width: 100%;
	width: 100%;
}
.fl-col-group-equal-height:before,
.fl-col-group-equal-height .fl-col:before,
.fl-col-group-equal-height .fl-col-content:before,
.fl-col-group-equal-height:after,
.fl-col-group-equal-height .fl-col:after,
.fl-col-group-equal-height .fl-col-content:after{
	content: none;
}

/* Equal height align top */
.fl-col-group-nested.fl-col-group-equal-height.fl-col-group-align-top .fl-col-content,
.fl-col-group-equal-height.fl-col-group-align-top .fl-col-content {
	justify-content: flex-start;
}

/* Equal height align center */
.fl-col-group-nested.fl-col-group-equal-height.fl-col-group-align-center .fl-col-content,
.fl-col-group-equal-height.fl-col-group-align-center .fl-col-content {
	justify-content: center;
}

/* Equal height align bottom */
.fl-col-group-nested.fl-col-group-equal-height.fl-col-group-align-bottom .fl-col-content,
.fl-col-group-equal-height.fl-col-group-align-bottom .fl-col-content {
	justify-content: flex-end;
}

.fl-col-group-equal-height.fl-col-group-align-center .fl-col-group {
	width: 100%;
}

/* Columns
------------------------------------------------------ */

.fl-col {
	float: left;
	min-height: 1px;
}

/* Column Bg Overlay */
.fl-col-bg-overlay .fl-col-content {
	position: relative;
}
.fl-col-bg-overlay .fl-col-content:after {
	border-radius: inherit;
	content: '';
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 0;
}
.fl-col-bg-overlay .fl-module {
	position: relative;
	z-index: 2;
}

/* Templates
------------------------------------------------------ */

.single:not(.woocommerce).single-fl-builder-template .fl-content {
	width: 100%;
}

/* Shapes & Patterns
------------------------------------------------------- */
.fl-builder-layer {
	position: absolute;
	top:0;
	left:0;
	right: 0;
	bottom: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}
.fl-builder-shape-layer {
	z-index: 0;
}
.fl-builder-shape-layer.fl-builder-bottom-edge-layer {
	z-index: 1;
}
.fl-row-bg-overlay .fl-builder-shape-layer {
	z-index: 1;
}
.fl-row-bg-overlay .fl-builder-shape-layer.fl-builder-bottom-edge-layer {
	z-index: 2;
}
.fl-row-has-layers .fl-row-content {
	z-index: 1;
}
.fl-row-bg-overlay .fl-row-content {
	z-index: 2;
}

.fl-builder-layer > * {
	display: block;
	position: absolute;
	top:0;
	left:0;
	width: 100%;
}
.fl-builder-layer + .fl-row-content {
	position: relative;
}
.fl-builder-layer .fl-shape {
	fill: #aaa;
	stroke: none;
	stroke-width: 0;
	width:100%;
}
/**
Fix ipad parallax issue on safari
https://core.trac.wordpress.org/ticket/48802
https://core.trac.wordpress.org/ticket/49285
https://github.com/WordPress/gutenberg/issues/17718
*/
@supports (-webkit-touch-callout: inherit) {
  .fl-row.fl-row-bg-parallax .fl-row-content-wrap,
  .fl-row.fl-row-bg-fixed .fl-row-content-wrap {
    background-position: center !important;
    background-attachment: scroll !important;
  }
}

@supports (-webkit-touch-callout: none) {
	.fl-row.fl-row-bg-fixed .fl-row-content-wrap {
		background-position: center !important;
		background-attachment: scroll !important;
	}
}
/**
 * Base CSS used by all (or many) modules. This file should
 * not contain any generic layout CSS that doesn't apply to
 * modules. That belongs in fl-builder-layout.css.
 */

/* Utilities
------------------------------------------------------ */

.fl-clearfix:before,
.fl-clearfix:after {
	display: table;
	content: " ";
}
.fl-clearfix:after {
	clear: both;
}
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* Buttons
------------------------------------------------------ */

.fl-builder-content a.fl-button,
.fl-builder-content a.fl-button:visited {
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	display: inline-block;
	font-size: 16px;
	font-weight: normal;
	line-height: 18px;
	padding: 12px 24px;
	text-decoration: none;
	text-shadow: none;
}
.fl-builder-content .fl-button:hover {
	text-decoration: none;
}
.fl-builder-content .fl-button:active {
	position: relative;
	top: 1px;
}
.fl-builder-content .fl-button-width-full .fl-button {
	display: block;
	text-align: center;
}
.fl-builder-content .fl-button-width-custom .fl-button {
	display: inline-block;
	text-align: center;
	max-width: 100%;
}
.fl-builder-content .fl-button-left {
	text-align: left;
}
.fl-builder-content .fl-button-center {
	text-align: center;
}
.fl-builder-content .fl-button-right {
	text-align: right;
}
.fl-builder-content .fl-button i {
	font-size: 1.3em;
	height: auto;
	margin-right:8px;
	vertical-align: middle;
	width: auto;
}
.fl-builder-content .fl-button i.fl-button-icon-after {
	margin-left: 8px;
	margin-right: 0;
}
.fl-builder-content .fl-button-has-icon .fl-button-text {
	vertical-align: middle;
}

/* Icons
------------------------------------------------------ */

.fl-icon-wrap {
	display: inline-block;
}
.fl-icon {
	display: table-cell;
	vertical-align: middle;
}
.fl-icon a {
	text-decoration: none;
}
.fl-icon i {
	float: right;
	height: auto;
	width: auto;
}
.fl-icon i:before {
	border: none !important;
	height: auto;
	width: auto;
}
.fl-icon-text {
	display: table-cell;
	text-align: left;
	padding-left: 15px;
	vertical-align: middle;
}
.fl-icon-text-empty {
	display: none;
}
.fl-icon-text *:last-child {
	margin: 0 !important;
	padding: 0 !important;
}
.fl-icon-text a {
	text-decoration: none;
}
.fl-icon-text span {
	display: block;
}
.fl-icon-text span.mce-edit-focus {
	min-width: 1px;
}

/* Photos
------------------------------------------------------ */

.fl-module img {
	max-width: 100%;
}
.fl-photo {
	line-height: 0;
	position: relative;
}
.fl-photo-align-left {
	text-align: left;
}
.fl-photo-align-center {
	text-align: center;
}
.fl-photo-align-right {
	text-align: right;
}
.fl-photo-content {
	display: inline-block;
	line-height: 0;
	position: relative;
	max-width: 100%;
}
.fl-photo-img-svg {
	width: 100%;
}
.fl-photo-content img {
	display: inline;
	height: auto;
	max-width: 100%;
}
.fl-photo-crop-circle img {
	-webkit-border-radius: 100%;
	-moz-border-radius: 100%;
	border-radius: 100%;
}
.fl-photo-caption {
	font-size: 13px;
	line-height: 18px;
	overflow: hidden;
	text-overflow: ellipsis;
}
.fl-photo-caption-below {
	padding-bottom: 20px;
	padding-top: 10px;
}
.fl-photo-caption-hover {
	background: rgba(0,0,0,0.7);
	bottom: 0;
	color: #fff;
	left: 0;
	opacity: 0;
	filter: alpha(opacity = 0);
	padding: 10px 15px;
	position: absolute;
	right: 0;
	-webkit-transition:opacity 0.3s ease-in;
	-moz-transition:opacity 0.3s ease-in;
	transition:opacity 0.3s ease-in;
}
.fl-photo-content:hover .fl-photo-caption-hover {
	opacity: 100;
	filter: alpha(opacity = 100);
}

/* Pagination
------------------------------------------------------ */

.fl-builder-pagination,
.fl-builder-pagination-load-more {
	padding: 40px 0;
}
.fl-builder-pagination ul.page-numbers {
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: center;
}
.fl-builder-pagination li {
	display: inline-block;
	list-style: none;
	margin: 0;
	padding: 0;
}
.fl-builder-pagination li a.page-numbers,
.fl-builder-pagination li span.page-numbers {
	border: 1px solid #e6e6e6;
	display: inline-block;
	padding: 5px 10px;
	margin: 0 0 5px;
}
.fl-builder-pagination li a.page-numbers:hover,
.fl-builder-pagination li span.current {
	background: #f5f5f5;
	text-decoration: none;
}

/* Slideshows
------------------------------------------------------ */

.fl-slideshow,
.fl-slideshow * {
	-webkit-box-sizing: content-box;
	-moz-box-sizing: content-box;
	box-sizing: content-box;

}
.fl-slideshow .fl-slideshow-image img {
	max-width: none !important;
}
.fl-slideshow-social {
	line-height: 0 !important;
}
.fl-slideshow-social * {
	margin: 0 !important;
}

/* Sliders
------------------------------------------------------ */

.fl-builder-content .bx-wrapper .bx-viewport {
	background: transparent;
	border: none;
	box-shadow: none;
	-moz-box-shadow: none;
	-webkit-box-shadow: none;
	left: 0;
}

/* Lightbox
------------------------------------------------------ */

.mfp-wrap button.mfp-arrow,
.mfp-wrap button.mfp-arrow:active,
.mfp-wrap button.mfp-arrow:hover,
.mfp-wrap button.mfp-arrow:focus {
	background: transparent !important;
	border: none !important;
	outline: none;
	position: absolute;
	top: 50%;
	box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-box-shadow: none !important;
}
.mfp-wrap .mfp-close,
.mfp-wrap .mfp-close:active,
.mfp-wrap .mfp-close:hover,
.mfp-wrap .mfp-close:focus {
	background: transparent !important;
	border: none !important;
	outline: none;
	position: absolute;
	top: 0;
	box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-box-shadow: none !important;
}
.admin-bar .mfp-wrap .mfp-close,
.admin-bar .mfp-wrap .mfp-close:active,
.admin-bar .mfp-wrap .mfp-close:hover,
.admin-bar .mfp-wrap .mfp-close:focus {
	top: 32px!important;
}
img.mfp-img {
	padding: 0;
}
.mfp-counter {
	display: none;
}

.mfp-wrap .mfp-preloader.fa {
	font-size: 30px;
}

/* Form Fields
------------------------------------------------------ */

.fl-form-field {
	margin-bottom: 15px;
}
.fl-form-field input.fl-form-error {
	border-color: #DD6420;
}
.fl-form-error-message {
	clear: both;
	color: #DD6420;
	display: none;
	padding-top: 8px;
	font-size: 12px;
	font-weight: lighter;
}
.fl-form-button-disabled {
	opacity: 0.5;
}

/* Animations
------------------------------------------------------ */

.fl-animation {
	opacity: 0;
}
body.fl-no-js .fl-animation {
	opacity: 1;
}
.fl-builder-preview .fl-animation,
.fl-builder-edit .fl-animation,
.fl-animated {
	opacity: 1;
}
.fl-animated {
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both;
}

/* Button Icon Animation */
.fl-button.fl-button-icon-animation i {
	width: 0 !important;
	opacity: 0;
	-ms-filter: "alpha(opacity=0)";
	transition: all 0.2s ease-out;
	-webkit-transition: all 0.2s ease-out;
}
.fl-button.fl-button-icon-animation:hover i {
	opacity: 1! important;
    -ms-filter: "alpha(opacity=100)";
}
.fl-button.fl-button-icon-animation i.fl-button-icon-after {
	margin-left: 0px !important;
}
.fl-button.fl-button-icon-animation:hover i.fl-button-icon-after {
	margin-left: 10px !important;
}
.fl-button.fl-button-icon-animation i.fl-button-icon-before {
	margin-right: 0 !important;
}
.fl-button.fl-button-icon-animation:hover i.fl-button-icon-before {
	margin-right: 20px !important;
    margin-left: -10px;
}
@media (max-width: 1200px) { /**
 * Styles needed for the large breakpoint.
 */
 }@media (max-width: 992px) { /* Columns
------------------------------------------------------ */

/* Reversed Responsive Stacking */
.fl-col-group.fl-col-group-medium-reversed {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap-reverse;
	flex-wrap: wrap-reverse;
	flex-direction: row-reverse;
}
 }@media (max-width: 768px) { /* Rows
------------------------------------------------------ */

.fl-row-content-wrap {
	background-attachment: scroll !important;
}
.fl-row-bg-parallax .fl-row-content-wrap {
	background-attachment: scroll !important;
	background-position: center center !important;
}

/* Column Groups
------------------------------------------------------ */

/* Equal Heights */
.fl-col-group.fl-col-group-equal-height {
	display: block;
}
.fl-col-group.fl-col-group-equal-height.fl-col-group-custom-width {
	display: -webkit-box;
    display: -webkit-flex;
    display: flex;
}

/* Reversed Responsive Stacking */
.fl-col-group.fl-col-group-responsive-reversed {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap-reverse;
	flex-wrap: wrap-reverse;
	flex-direction: row-reverse;
}
.fl-col-group.fl-col-group-responsive-reversed .fl-col:not(.fl-col-small-custom-width) {
	flex-basis: 100%;
	width: 100% !important;
}
.fl-col-group.fl-col-group-medium-reversed:not(.fl-col-group-responsive-reversed) {
	display: unset;
	display: unset;
	-webkit-flex-wrap: unset;
	flex-wrap: unset;
	flex-direction: unset;
}

/* Columns
------------------------------------------------------ */

.fl-col {
	clear: both;
	float: none;
	margin-left: auto;
	margin-right: auto;
	width: auto !important;
}
.fl-col-small:not(.fl-col-small-full-width) {
	max-width: 400px;
}
.fl-block-col-resize {
	display:none;
}
/* Rows
------------------------------------------------------ */

.fl-row[data-node] .fl-row-content-wrap {
	margin: 0;
	padding-left: 0;
	padding-right: 0;
}
.fl-row[data-node] .fl-bg-video,
.fl-row[data-node] .fl-bg-slideshow {
	left: 0;
	right: 0;
}

/* Columns
------------------------------------------------------ */

.fl-col[data-node] .fl-col-content {
	margin: 0;
	padding-left: 0;
	padding-right: 0;
}
 }@media (min-width: 1201px) {
	html .fl-visible-large:not(.fl-visible-desktop),
	html .fl-visible-medium:not(.fl-visible-desktop),
	html .fl-visible-mobile:not(.fl-visible-desktop) {
		display: none;
	}
}

@media (min-width: 993px) and (max-width: 1200px) {
	html .fl-visible-desktop:not(.fl-visible-large),
	html .fl-visible-medium:not(.fl-visible-large),
	html .fl-visible-mobile:not(.fl-visible-large) {
		display: none;
	}
}

@media (min-width: 769px) and (max-width: 992px) {
	html .fl-visible-desktop:not(.fl-visible-medium),
	html .fl-visible-large:not(.fl-visible-medium),
	html .fl-visible-mobile:not(.fl-visible-medium) {
		display: none;
	}
}

@media (max-width: 768px) {
	html .fl-visible-desktop:not(.fl-visible-mobile),
	html .fl-visible-large:not(.fl-visible-mobile),
	html .fl-visible-medium:not(.fl-visible-mobile) {
		display: none;
	}
}
.fl-col-content {
	display: flex;
	flex-direction: column;
}
.fl-row-fixed-width {
	max-width: 1400px;
}
.fl-row-content-wrap {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 20px;
	padding-right: 20px;
	padding-bottom: 20px;
	padding-left: 20px;
}
.fl-module-content, .fl-module:where(.fl-module:not(:has(> .fl-module-content))) {
	margin-top: 20px;
	margin-right: 20px;
	margin-bottom: 20px;
	margin-left: 20px;
}
:root {
	--fl-global-button-color: #231f20;
	--fl-global-button-background: #ffcb47;
	--fl-global-button-hover-background: #ffffff;
	--fl-global-button-border-style: solid;
	--fl-global-button-background-clip: border-box;
	--fl-global-button-border-color: #474747;
	--fl-global-button-border-top-width: 1px;
	--fl-global-button-border-right-width: 1px;
	--fl-global-button-border-bottom-width: 3px;
	--fl-global-button-border-left-width: 1px;
}
.fl-builder-content button:not(.fl-menu-mobile-toggle), .fl-builder-content input[type=button], .fl-builder-content input[type=submit], .fl-builder-content a.fl-button, .fl-builder-content button:not(.fl-menu-mobile-toggle) *, .fl-builder-content input[type=button] *, .fl-builder-content input[type=submit] *, .fl-builder-content a.fl-button *, .fl-builder-content button:visited, .fl-builder-content input[type=button]:visited, .fl-builder-content input[type=submit]:visited, .fl-builder-content a.fl-button:visited, .fl-builder-content button:visited *, .fl-builder-content input[type=button]:visited *, .fl-builder-content input[type=submit]:visited *, .fl-builder-content a.fl-button:visited *, .fl-page .fl-builder-content button:not(.fl-menu-mobile-toggle), .fl-page .fl-builder-content input[type=button], .fl-page .fl-builder-content input[type=submit], .fl-page .fl-builder-content a.fl-button, .fl-page .fl-builder-content button:not(.fl-menu-mobile-toggle) *, .fl-page .fl-builder-content input[type=button] *, .fl-page .fl-builder-content input[type=submit] *, .fl-page .fl-builder-content a.fl-button *, .fl-page .fl-builder-content button:visited, .fl-page .fl-builder-content input[type=button]:visited, .fl-page .fl-builder-content input[type=submit]:visited, .fl-page .fl-builder-content a.fl-button:visited, .fl-page .fl-builder-content button:visited *, .fl-page .fl-builder-content input[type=button]:visited *, .fl-page .fl-builder-content input[type=submit]:visited *, .fl-page .fl-builder-content a.fl-button:visited * {
	color: #231f20;
}
.fl-builder-content .fl-module-content:not(:has(.fl-inline-editor)) button:not(.fl-menu-mobile-toggle), .fl-builder-content input[type=button], .fl-builder-content input[type=submit], .fl-builder-content a.fl-button, .fl-builder-content button:visited, .fl-builder-content input[type=button]:visited, .fl-builder-content input[type=submit]:visited, .fl-builder-content a.fl-button:visited, .fl-page .fl-builder-content .fl-module-content:not(:has(.fl-inline-editor)) button:not(.fl-menu-mobile-toggle), .fl-page .fl-builder-content input[type=button], .fl-page .fl-builder-content input[type=submit], .fl-page .fl-builder-content a.fl-button, .fl-page .fl-builder-content button:visited, .fl-page .fl-builder-content input[type=button]:visited, .fl-page .fl-builder-content input[type=submit]:visited, .fl-page .fl-builder-content a.fl-button:visited {
	background-color: #ffcb47;
}
.fl-builder-content .fl-module-content:not(:has(.fl-inline-editor)) button:not(.fl-menu-mobile-toggle):hover, .fl-builder-content input[type=button]:hover, .fl-builder-content input[type=submit]:hover, .fl-builder-content a.fl-button:hover, .fl-page .fl-builder-content .fl-module-content:not(:has(.fl-inline-editor)) button:not(.fl-menu-mobile-toggle):hover, .fl-page .fl-builder-content input[type=button]:hover, .fl-page .fl-builder-content input[type=submit]:hover, .fl-page .fl-builder-content a.fl-button:hover {
	background-color: #ffffff;
}
.fl-builder-content button:not(.fl-menu-mobile-toggle), .fl-builder-content input[type=button], .fl-builder-content input[type=submit], .fl-builder-content a.fl-button, .fl-builder-content button:visited, .fl-builder-content input[type=button]:visited, .fl-builder-content input[type=submit]:visited, .fl-builder-content a.fl-button:visited, .fl-page .fl-builder-content button:not(.fl-menu-mobile-toggle), .fl-page .fl-builder-content input[type=button], .fl-page .fl-builder-content input[type=submit], .fl-page .fl-builder-content a.fl-button, .fl-page .fl-builder-content button:visited, .fl-page .fl-builder-content input[type=button]:visited, .fl-page .fl-builder-content input[type=submit]:visited, .fl-page .fl-builder-content a.fl-button:visited {
	border-style: solid;
	border-width: 0;
	background-clip: border-box;
	border-color: #474747;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 3px;
	border-left-width: 1px;
}
.page .fl-post-header, .single-fl-builder-template .fl-post-header { display:none; }.fl-node-5z3ugpor6vm1 {
	color: #ffffff;
}
.fl-builder-content .fl-node-5z3ugpor6vm1 *:not(input):not(textarea):not(select):not(a):not(h1):not(h2):not(h3):not(h4):not(h5):not(h6):not(.fl-menu-mobile-toggle) {
	color: inherit;
}

.fl-builder-content .fl-node-5z3ugpor6vm1 a {
	color: #ffffff;
}

.fl-builder-content .fl-node-5z3ugpor6vm1 a:hover {
	color: #ffffff;
}

.fl-builder-content .fl-node-5z3ugpor6vm1 h1,
.fl-builder-content .fl-node-5z3ugpor6vm1 h2,
.fl-builder-content .fl-node-5z3ugpor6vm1 h3,
.fl-builder-content .fl-node-5z3ugpor6vm1 h4,
.fl-builder-content .fl-node-5z3ugpor6vm1 h5,
.fl-builder-content .fl-node-5z3ugpor6vm1 h6,
.fl-builder-content .fl-node-5z3ugpor6vm1 h1 a,
.fl-builder-content .fl-node-5z3ugpor6vm1 h2 a,
.fl-builder-content .fl-node-5z3ugpor6vm1 h3 a,
.fl-builder-content .fl-node-5z3ugpor6vm1 h4 a,
.fl-builder-content .fl-node-5z3ugpor6vm1 h5 a,
.fl-builder-content .fl-node-5z3ugpor6vm1 h6 a {
	color: #ffffff;
}


.fl-node-5z3ugpor6vm1 > .fl-row-content-wrap {
	background-color: #231f20;
}
.fl-node-5z3ugpor6vm1 .fl-builder-bottom-edge-layer > * {
	width: 100%;
	left: auto;
	right: auto;
	height: 40px;
	top: auto;
	bottom: 0;
	transform: scaleX(1) scaleY(-1);
}
.fl-node-5z3ugpor6vm1 .fl-builder-bottom-edge-layer .fl-shape-content .fl-shape {
	fill: #ffffff;
}
 .fl-node-5z3ugpor6vm1 > .fl-row-content-wrap {
	padding-bottom:40px;
}









.fl-node-u7n4xizkt98s {
	width: 100%;
}




.fl-node-nyacbtprvgs7 {
	width: 100%;
}
/* Single Product */
.fl-woocommerce-product .woocommerce ul.products li.product {
	width: 100%;
}

/* Product Columns */
.fl-module-woocommerce .woocommerce.columns-1 ul.products li.product {
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 767px) {

	.fl-module-woocommerce .woocommerce.columns-2 ul.products li.product,
	.fl-module-woocommerce .woocommerce.columns-3 ul.products li.product {
		width: 100%;
	}
}

@media (max-width: 992px) {

	.fl-module-woocommerce .woocommerce.columns-2 ul.products li.product {
		clear: none;
	}
	.fl-module-woocommerce .woocommerce.columns-2 ul.products li.product:nth-child(2n + 1) {
		clear: both;
	}
}

@media (min-width: 992px) {

	.fl-module-woocommerce .woocommerce.columns-3 ul.products li.product:nth-child(3n + 1) {
		clear: both;
	}
}

@media (min-width: 768px) {

	.fl-module-woocommerce .woocommerce.columns-2 ul.products li.product.first {
		margin-right: 3.8%;
	}
	.fl-module-woocommerce .woocommerce.columns-2 ul.products li.product.last {
		margin-right: 0;
	}
}.fl-module-heading .fl-heading {
	padding: 0 !important;
	margin: 0 !important;
}.fl-node-t7p9faskvmq5.fl-module-heading .fl-heading {
	text-align: center;
}
@media (max-width: 768px) { .fl-module-icon {
	text-align: center;
}
 }



.fl-node-sujhg4mczqbk .fl-icon i, .fl-node-sujhg4mczqbk .fl-icon i:before {
	font-size: 42px;
}
.fl-node-sujhg4mczqbk .fl-icon-wrap .fl-icon-text {
	height: 73.5px;
}
.fl-node-sujhg4mczqbk.fl-module-icon {
	text-align: center;
}
@media(max-width: 1200px) {
	.fl-node-sujhg4mczqbk .fl-icon-wrap .fl-icon-text {
		height: 73.5px;
	}
}
@media(max-width: 992px) {
	.fl-node-sujhg4mczqbk .fl-icon-wrap .fl-icon-text {
		height: 73.5px;
	}
}
@media(max-width: 768px) {
	.fl-node-sujhg4mczqbk .fl-icon-wrap .fl-icon-text {
		height: 73.5px;
	}
}
 .fl-node-sujhg4mczqbk > .fl-module-content {
	margin-top:10px;
	margin-bottom:10px;
}

/* Start Global CSS */
#fl-main-content {
    overflow: hidden;
}
body .fl-post-title {
    margin-top: 40px;
}
body.has-blocks .fl-post-content .alignwide {
    margin: 0 !important;
}

.mejs-button button {
    background-color: transparent !important;
    border-color: transparent !important;
}

/* Hubspot Form Overrides
------------------------------------------------------*/
.hsfc-Button {
    color: #231f20 !important;
    border-color: #474747;
    border-top-width: 1px !important;
    border-right-width: 1px !important;
    border-bottom-width: 3px !important;
    border-left-width: 1px !important;
}
.hsfc-Button:hover {
    background-color: #fff !important;
    transform: translateY(0px) !important;
}
footer .hsfc-FormWrapper label {
    margin-bottom: 5px !important;
}
footer .hsfc-FormWrapper input {
    padding: 7px !important;
}
footer .hsfc-Row {
    margin-bottom: 12px !important;
}
footer .hsfc-Button {
    font-size: 16px !important;
    font-weight: bold !important;
    width: 100% !important;
}
footer .hsfc-NavigationRow {
    margin-top: 10px !important;
}

/* HEADING | Doodle
---------------------------------------------------------*/
.heading-doodle .fl-heading-text {
    display: inline-block;
    position: relative;
    padding: 0 20px;
    line-height: 1.2em;
}
.heading-doodle.pop-heading {
    text-align:center;
    margin-bottom:20px;
    line-height: 1em;
}
.heading-doodle .fl-heading-text:after {
    display: block;
    content: '';
    position: absolute;
    bottom: -15px;
    left: -0.5rem;
    right: -0.5rem;
    height: 12px;
    width: 100%;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 191.96533 9.3177128' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg' xmlns:svg='http://www.w3.org/2000/svg'%3E%3Cg transform='translate(-9.1913616,-144.67219)'%3E%3Cpath d='m 201.15149,152.40438 c 0.02,-0.25582 -0.0194,-0.49958 -0.0872,-0.74008 -0.13439,-0.47882 -0.42894,-0.96161 -0.73867,-1.4218 -2.49957,-1.39861 -7.51759,-2.44928 -14.19487,-3.25657 -6.6904,-0.80614 -15.09122,-1.36212 -24.56752,-1.72758 -18.95292,-0.73128 -42.20818,-0.69874 -64.782833,-0.3352 -9.517554,0.15389 -18.912131,0.3665 -27.816039,0.60666 -26.491831,-0.15212 -46.541144,0.0407 -46.542219,0.041 l 9.743919,1.16695 c -14.033139,0.53939 -22.9729335,0.97282 -22.9746955,0.97274 8.6909025,1.09648 17.3697175,2.22489 26.0464465,3.36767 -7.11e-4,0.0152 33.226388,-1.88688 70.437991,-2.85549 2.38361,0.0204 4.78932,0.044 7.20965,0.0718 17.47444,0.20616 35.65119,0.64154 50.83544,1.50264 7.59083,0.43185 14.43509,0.96871 20.05115,1.64688 2.80732,0.33904 5.30822,0.7132 7.42841,1.13275 2.11315,0.41886 3.87524,0.88345 5.06639,1.41315 -0.53656,-0.63149 -1.18706,-1.23584 -1.84799,-1.82089 -2.2997,-0.8475 -6.761,-1.7199 -12.75767,-2.44554 -5.964,-0.72941 -13.45466,-1.34697 -21.9091,-1.8592 2.18496,0.0468 4.32775,0.10404 6.41845,0.17255 8.43742,0.27976 16.05031,0.73817 22.28366,1.47766 3.11372,0.37211 5.88811,0.81132 8.19673,1.37001 1.14843,0.28048 2.19188,0.59313 3.0246,0.95595 0.41109,0.181 0.77008,0.38109 0.96213,0.56382 0.10735,0.0982 0.20231,0.20478 0.25552,0.33547 0.0571,0.13051 0.0359,0.29021 -0.0407,0.40917 0.17347,-0.2126 0.28498,-0.48992 0.29902,-0.74459' style='display:inline;fill:%23FFCB47;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.0352778' /%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat no-repeat;
    background-position: center center;
    background-size: 100% 100%;
}

/* FANCY TEXT UNDERLINE
----------------------------------------*/
.fancy-underline .fl-rich-text span,
.fancy-underline .fl-list p {
    display: inline-block;
    position: relative;
    z-index: 1;
}
.fancy-underline .fl-rich-text span:before,
.fancy-underline .fl-list p:before {
    position: absolute;
    bottom: 5px;
    display: block;
    width: 100%;
    height: 10px;
    content: '';
    background: rgba(255, 203, 71, .65);
    z-index: -1;
}

/* PHOTO DOTS
----------------------------------------*/
.photo-dots .fl-photo-content {
    position: relative;
    z-index: 2;
}
.photo-dots.tl .fl-photo-content:before,
.photo-dots.tr .fl-photo-content:before,
.photo-dots.bl .fl-photo-content:after,
.photo-dots.br .fl-photo-content:after {
    display: block;
    position: absolute;
    width: 140px;
    height: 140px;
    content:url('/wp-content/themes/bb-theme-child/images/dots.svg');
    z-index: -1;
    opacity: .55;
}
.photo-dots.o1 .fl-photo-content:before,
.photo-dots.o1 .fl-photo-content:after {
    opacity: 100;
}

.photo-dots.tl .fl-photo-content:before {
    top: -50px;
    left: -50px;
}
.photo-dots.tr .fl-photo-content:before {
    top: -50px;
    right: -50px;
    transform: rotate(90deg);
}
.photo-dots.bl .fl-photo-content:after {
    bottom: -50px;
    left: -50px;
    transform: rotate(90deg);
}
.photo-dots.br .fl-photo-content:after {
    bottom: -50px;
    right: -50px;
}
@media (max-width:992px) {
    .photo-dots.tl .fl-photo-content:before,
    .photo-dots.tr .fl-photo-content:before,
    .photo-dots.bl .fl-photo-content:after,
    .photo-dots.br .fl-photo-content:after {
        width: 60px;
        height: 60px;
    }
    .photo-dots.tl .fl-photo-content:before {
        top: -20px;
        left: -20px;
    }
    .photo-dots.tr .fl-photo-content:before {
        top: -20px;
        right: -20px;
        transform: rotate(90deg);
    }
    .photo-dots.bl .fl-photo-content:after {
        bottom: -20px;
        left: -20px;
        transform: rotate(90deg);
    }
    .photo-dots.br .fl-photo-content:after {
        bottom: -20px;
        right: -20px;
    }
}

/* HUBSPOT | Buttons
----------------------------------------------*/
.hs-submit .actions {
    margin-top: 0 !important;
}
.hs-button,
.hs-button:hover,
.hs-button:focus {    
    color: #231f20 !important;
    background-color: #ffcb47 !important;
    font-family: "Inter", sans-serif !important;
    font-weight: 400 !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    border-style: solid !important;
    border-width: 1px !important;
    border-color: #474747 !important;
    border-radius: 24px !important;
    border-bottom-width: 3px !important;
    padding: 5px 24px !important;
    text-decoration: none !important;
    text-shadow: none !important;
    box-shadow: none !important;
}
.hs-button:hover {
    background: #ffd56a !important;
}

/* GRAVITY | Buttons
----------------------------------------------*/
.gform_wrapper .gform_button {
    color: #231f20 !important;
    background-color: #ffcb47 !important;
    font-weight: 400 !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    border-style: solid !important;
    border-width: 1px !important;
    border-color: #474747 !important;
    border-radius: 24px !important;
    border-bottom-width: 3px !important;
}
.gform_wrapper .gform_button:hover {
    background-color: #ffd56a !important;
}

#gform_submit_button_3 {
    margin: 0 auto;
}
.single_add_to_cart_button {
    width: 100%;
    margin-bottom: 20px;
}

/* PRODUCT ARCHIVES
----------------------------------------------*/
.products .product.has-post-thumbnail img.attachment-woocommerce_thumbnail {
	margin-left: 11.5%;
}
.products .product.product_cat-specialty-stoneware img.attachment-woocommerce_thumbnail,
.products .product.product_cat-custom-shot-glasses img.attachment-woocommerce_thumbnail {
	margin-left: 5%;
	margin-left: 2%;
}

/* PRODUCT PAGES
----------------------------------------------*/
.woocommerce div.product div.images .woocommerce-product-gallery__wrapper .zoomImg {
    width: 175% !important;
    height: 175% !important;
}
/* End Global CSS */


/* Start Global Nodes CSS */

/* End Global Nodes CSS */


/* Start Layout CSS */
.portfolio-gallery {
    column-count: 4;
    column-gap: 10px;
    width: 100%;
}
.portfolio-gallery img {
    width: 100%;
    display: block; /* Removes space below images */
    margin-bottom: 10px; /* Vertical gap between items */
    break-inside: avoid; /* Prevents breaking images across columns */
}

.flex-benefits .fl-col-content {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(400px, 1fr)); /* Adjust column width as needed */
    grid-gap: 10px; /* Space between items */
    grid-auto-rows: 10px; /* Minimum row height, small value */
}
.flex-benefits .fl-col-content .fl-module {
    width: 100%; /* Ensure images take up full column width */
    display: block; /* Removes bottom margin/gap */
    grid-row-end: span 10; /* Default span, you can adjust this based on your content */
    object-fit: cover; /* Optional: this makes images cover their area */
}

.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); /* Adjust column width as needed */
    grid-gap: 10px; /* Space between items */
    grid-auto-rows: 10px; /* Minimum row height, small value */
}

.gallery img {
    width: 100%; /* Ensure images take up full column width */
    display: block; /* Removes bottom margin/gap */
    grid-row-end: span 10; /* Default span, you can adjust this based on your content */
    object-fit: cover; /* Optional: this makes images cover their area */
}

/* End Layout CSS */

