/**
 * 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 .fl-button:is(a, button),
.fl-builder-content a.fl-button:visited {
	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 {
	width: 100%;
	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;
	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;
}
.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;
}
.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;
}

/* Button Icon Animation */
.fl-button.fl-button-icon-animation i {
	width: 0 !important;
	opacity: 0;
	transition: all 0.2s ease-out;
}
.fl-button.fl-button-icon-animation:hover i {
	opacity: 1 !important;
}
.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;
}

/* Default button colors for non Beaver Builder themes.
------------------------------------------------------ */

.fl-builder-content .fl-button:is(a, button),
.fl-builder-content a.fl-button:visited {
	background: #fafafa;
	border: 1px solid #ccc;
	color: #333;
}
.fl-builder-content .fl-button:is(a, button) *,
.fl-builder-content a.fl-button:visited * {
	color: #333;
}@media (max-width: 1380px) { /**
 * 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;
}
 }@media (min-width: 1381px) {
	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: 1380px) {
	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;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.fl-row-fixed-width {
	max-width: 1380px;
}
.fl-builder-content > .fl-module-box {
	margin: 0;
}
.fl-row-content-wrap, .fl-builder-content > .fl-module-box {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
	padding-top: 0px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
}
.fl-module-content, .fl-module:where(.fl-module:not(:has(> .fl-module-content))) {
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}
@media (max-width: 768px) { .fl-module-icon {
	text-align: center;
}
 }.fl-node-778dfa8ee3bd8 .fl-icon i,
.fl-node-778dfa8ee3bd8 .fl-icon i:before {
	color: #9b9b9b;
}



.fl-node-778dfa8ee3bd8 .fl-icon i:hover,
.fl-node-778dfa8ee3bd8 .fl-icon i:hover:before,
.fl-node-778dfa8ee3bd8 .fl-icon a:hover i,
.fl-node-778dfa8ee3bd8 .fl-icon a:hover i:before {
	color: #7f7f7f;
}

.fl-node-778dfa8ee3bd8 .fl-icon i, .fl-node-778dfa8ee3bd8 .fl-icon i:before {
	font-size: 16px;
}
.fl-node-778dfa8ee3bd8 .fl-icon-wrap .fl-icon-text {
	height: 28px;
}
.fl-node-778dfa8ee3bd8.fl-module-icon {
	text-align: left;
}
@media(max-width: 1380px) {
	.fl-node-778dfa8ee3bd8 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 992px) {
	.fl-node-778dfa8ee3bd8 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 768px) {
	.fl-node-778dfa8ee3bd8 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
 .fl-node-778dfa8ee3bd8 > .fl-module-content {
	margin-top:0px;
	margin-bottom:0px;
	margin-left:5px;
}
.fl-node-7e5761340c00d .fl-icon i,
.fl-node-7e5761340c00d .fl-icon i:before {
	color: #9b9b9b;
}




.fl-node-7e5761340c00d .fl-icon i, .fl-node-7e5761340c00d .fl-icon i:before {
	font-size: 16px;
}
.fl-node-7e5761340c00d .fl-icon-wrap .fl-icon-text {
	height: 28px;
}
.fl-node-7e5761340c00d.fl-module-icon {
	text-align: left;
}
@media(max-width: 1380px) {
	.fl-node-7e5761340c00d .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 992px) {
	.fl-node-7e5761340c00d .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 768px) {
	.fl-node-7e5761340c00d .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
 .fl-node-7e5761340c00d > .fl-module-content {
	margin-top:0px;
	margin-right:0px;
	margin-bottom:0px;
	margin-left:3px;
}
.fl-node-76298097a1170 .fl-icon i,
.fl-node-76298097a1170 .fl-icon i:before {
	color: #9b9b9b;
}



.fl-node-76298097a1170 .fl-icon i:hover,
.fl-node-76298097a1170 .fl-icon i:hover:before,
.fl-node-76298097a1170 .fl-icon a:hover i,
.fl-node-76298097a1170 .fl-icon a:hover i:before {
	color: #7f7f7f;
}

.fl-node-76298097a1170 .fl-icon i, .fl-node-76298097a1170 .fl-icon i:before {
	font-size: 16px;
}
.fl-node-76298097a1170 .fl-icon-wrap .fl-icon-text {
	height: 28px;
}
.fl-node-76298097a1170.fl-module-icon {
	text-align: left;
}
@media(max-width: 1380px) {
	.fl-node-76298097a1170 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 992px) {
	.fl-node-76298097a1170 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 768px) {
	.fl-node-76298097a1170 .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
 .fl-node-76298097a1170 > .fl-module-content {
	margin-top:0px;
	margin-bottom:0px;
	margin-left:5px;
}
.fl-node-b55b01911c7ea .fl-icon i,
.fl-node-b55b01911c7ea .fl-icon i:before {
	color: #9b9b9b;
}




.fl-node-b55b01911c7ea .fl-icon i, .fl-node-b55b01911c7ea .fl-icon i:before {
	font-size: 16px;
}
.fl-node-b55b01911c7ea .fl-icon-wrap .fl-icon-text {
	height: 28px;
}
.fl-node-b55b01911c7ea.fl-module-icon {
	text-align: left;
}
@media(max-width: 1380px) {
	.fl-node-b55b01911c7ea .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 992px) {
	.fl-node-b55b01911c7ea .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
@media(max-width: 768px) {
	.fl-node-b55b01911c7ea .fl-icon-wrap .fl-icon-text {
		height: 28px;
	}
}
 .fl-node-b55b01911c7ea > .fl-module-content {
	margin-top:0px;
	margin-right:0px;
	margin-bottom:0px;
	margin-left:3px;
}
/**
 * PX Footer - Static CSS
 *
 * Figma: Footer (node 201-37344)
 * Layout: footer → main (max-width) → logo + 4-col grid
 *         footer → bottom → cert + bottom-bar (copyright + legal)
 *
 * Mobile accordion uses shared px-accordion__* classes (px-accordion.css).
 * This file only handles footer layout and desktop overrides.
 */


/* ==========================================================================
   Footer Section
   ========================================================================== */

.px-footer {
	display: flex;
	flex-direction: column;
	gap: var(--space-d3);
	padding: 0 var(--space-d3) var(--space-d3);
}


/* Back to top: see shared px-footer-base.css (.px-footer-base__back-top) */


/* ==========================================================================
   Main Container (centered, max-width)
   ========================================================================== */

.px-footer__main {
	max-width: var(--row-width);
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-d3);
	padding: 0;
}


/* Logo: see shared px-footer-base.css (.px-footer-base__logo) */


/* ==========================================================================
   4-Column Grid
   ========================================================================== */

.px-footer__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-d3);
}


/* ==========================================================================
   Column
   ========================================================================== */

.px-footer__col {
	display: flex;
	flex-direction: column;
	gap: var(--space-d15);
}

.px-footer__col--1 {
	margin-bottom: var(--space-d1);
}


/* ==========================================================================
   Nav Sections
   ========================================================================== */

.px-footer__nav-section {
	display: flex;
	flex-direction: column;
	gap: var(--space-d1);
}

.px-footer__nav-heading {
	margin: 0;
}

.px-footer__nav-title {
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	font-size: var(--text-d125);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-tight);
	color: var(--gray-dark);
}


/* -- Nav panel (link list) -- */

.px-footer__nav-panel-inner {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-d1);
}

/* Static nav section (no accordion on mobile) — spacing between siblings */
.px-footer__nav-section--static:not(:last-child) {
	margin-bottom: var(--space-d075);
}

/* Nav rich text item */
.px-footer__nav-text {
	padding: 0 var(--space-d075) var(--space-d05);
	margin-left: calc(-1 * var(--space-d075));
	font-family: var(--font-body);
	font-size: var(--text-body);
	line-height: var(--lh-normal);
	color: var(--gray-dark);
}

.px-footer__nav-text p {
	margin: 0;
}

.px-footer__nav-text p + p {
	margin-top: var(--space-d05);
}



/* ==========================================================================
   Nav trigger (button — accordion on mobile, plain heading on desktop)
   No shared px-accordion__* classes — fully self-contained.
   ========================================================================== */

.px-footer__nav-trigger {
	display: flex;
	align-items: center;
	gap: var(--space-d05);
	width: 100%;
	padding: var(--space-d025) 0;
	margin: 0;
	border: none;
	background: none;
	text-align: left;
	cursor: default;
	color: var(--gray-dark);
}

.px-footer__nav-trigger:focus-visible {
	outline: solid 3px var(--btn-focus-ring);
	outline-offset: 2px;
}

/* Accordion title: underline like FAQ items */
[data-px-accordion-item] .px-footer__nav-title {
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.px-footer__nav-trigger:hover .px-footer__nav-title {
	text-decoration: none;
}

.is-open .px-footer__nav-title {
	text-decoration: none;
}

/* Icon — hidden on desktop */
.px-footer__nav-icon {
	display: none;
}

/* Panel — always visible on desktop */
.px-footer__nav-panel {
	display: flex;
	flex-direction: column;
}


/* ==========================================================================
   International Link
   ========================================================================== */

.px-footer__international {
	display: flex;
	flex-direction: column;
	gap: var(--space-d05);
	align-items: flex-start;
}

.px-footer__intl-heading {
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	font-size: var(--text-d15);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-tight);
	color: var(--gray-dark);
}

.px-footer__intl-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-d05);
	padding: var(--space-d025) var(--space-d05);
	margin-left: calc(-1 * var(--space-d05));
	border-radius: var(--radius-s);
	font-family: var(--font-display);
	font-weight: var(--weight-medium);
	font-size: var(--text-body);
	line-height: var(--lh-normal);
	color: var(--gray-dark);
	text-decoration: none;
	transition: background-color var(--duration-normal) var(--ease-smooth),
	            color var(--duration-normal) var(--ease-smooth);
}

.px-footer__intl-link:hover {
	color: var(--action);
}

.px-footer__intl-icon {
	display: flex;
	align-items: center;
}

.px-footer__intl-icon svg {
	width: var(--space-d15);
	height: var(--space-d15);
}


/* ==========================================================================
   Social Media
   ========================================================================== */

.px-footer__social {
	display: flex;
	flex-direction: column;
	gap: var(--space-d1);
}

.px-footer__social-heading {
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	font-size: var(--text-d15);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-tight);
	color: var(--gray-dark);
}

.px-footer__social-links {
	display: flex;
	gap: var(--space-d05);
}

/* Social icon button (circle) */
.px-footer__social-link {
	display: flex;
	justify-content: center;
	align-items: center;
	width: var(--space-d3);
	height: var(--space-d3);
	background-color: var(--white);
	border: 3px solid transparent;
	border-radius: var(--radius-full);
	box-shadow: var(--shadow-subtle);
	transition: var(--transition-btn);
}

.px-footer__social-link span {
	display: flex;
}

.px-footer__social-link svg {
	width: var(--space-d15);
	height: var(--space-d15);
}

.px-footer__social-link svg path {
	transition: var(--transition-btn);
}

.px-footer__social-link:hover {
	border-color: var(--action);
	box-shadow: var(--shadow-hover);
}

.px-footer__social-link:hover svg path {
	fill: var(--action);
}

.px-footer__social-link:focus-visible {
	outline: solid 3px var(--btn-focus-ring);
	outline-offset: 0;
	border-color: transparent;
	box-shadow: var(--shadow-hover);
}

.px-footer__social-link:active {
	background-color: var(--sky-blue);
	box-shadow: var(--shadow-pressed);
}

.px-footer__social-link:active svg path {
	fill: var(--action);
}


/* ==========================================================================
   Mobile Sections (mobile-only, between nav and col 4)
   ========================================================================== */

.px-footer__mobile-section {
	display: none;
}

.px-footer__mobile-heading {
	font-family: var(--font-display);
	font-weight: var(--weight-semibold);
	font-size: var(--text-d15);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-tight);
	color: var(--gray-dark);
	margin: 0;
}

.px-footer__mobile-links {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-d025);
}


/* Footer bottom: see shared px-footer-base.css (.px-footer-base__bottom, etc.) */


/* ==========================================================================
   Focus states (WCAG keyboard)
   ========================================================================== */

.px-footer__intl-link:focus-visible {
	outline: solid 3px var(--btn-focus-ring);
	outline-offset: 2px;
}


/* ==========================================================================
   Responsive – Tablet
   ========================================================================== */

@media screen and (max-width: 992px) {
	.px-footer {
		padding: 0 var(--space-d2) var(--space-d3);
	}

	.px-footer__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}


/* ==========================================================================
   Responsive – Mobile
   ========================================================================== */

@media screen and (max-width: 767px) {
	.px-footer {
		padding: 0 var(--space-d1) var(--space-d3);
	}

	.px-footer__grid {
		grid-template-columns: 1fr;
		gap: var(--space-d075);
	}

	.px-footer__col {
		gap: var(--space-d075);
	}

	/* Nav titles: match other mobile headings */
	.px-footer__nav-title {
		font-size: var(--text-d15);
	}

	/* Static nav section: match spacing of other mobile sections */
	.px-footer__nav-section--static {
		gap: var(--space-d05);
	}

	/* Nav trigger: interactive on mobile */
	.px-footer__nav-trigger {
		cursor: pointer;
	}

	/* Nav icon: visible on mobile */
	.px-footer__nav-icon {
		display: flex;
		align-items: center;
		flex-shrink: 0;
		width: var(--space-d15);
		height: var(--space-d15);
		transition: transform var(--duration-normal) var(--ease-smooth);
	}

	.px-footer__nav-icon svg {
		width: 100%;
		height: 100%;
		fill: currentColor;
	}

	.is-open .px-footer__nav-icon {
		transform: rotate(180deg);
	}

	/* Nav panel: accordion animation on mobile (only accordion items, not static) */
	[data-px-accordion-item] > .px-footer__nav-panel {
		display: grid;
		grid-template-rows: 0fr;
		transition: grid-template-rows var(--duration-normal) var(--ease-smooth);
	}

	.is-open > .px-footer__nav-panel {
		grid-template-rows: 1fr;
	}

	[data-px-accordion-item] .px-footer__nav-panel-inner {
		overflow: hidden;
		visibility: hidden;
		transition: padding var(--duration-normal) var(--ease-smooth),
		            visibility 0s linear var(--duration-normal);
	}

	.is-open .px-footer__nav-panel-inner {
		visibility: visible;
		transition: padding var(--duration-normal) var(--ease-smooth),
		            visibility 0s linear 0s;
	}

	/* Column 4: extra spacing from nav columns */
	.px-footer__col--4 {
		padding-top: var(--space-d075);
		gap: var(--space-d15);
	}

	/* Social links: wrap if needed */
	.px-footer__social-links {
		flex-wrap: wrap;
	}

	/* Hide-mobile items */
	.px-footer__hide-mobile {
		display: none;
	}

	/* Mobile sections: visible on mobile */
	.px-footer__mobile-section {
		display: flex;
		flex-direction: column;
		gap: var(--space-d05);
		align-items: flex-start;
	}
}

/* Start Global CSS */

/* End Global CSS */


/* Start Global Nodes CSS */

/* End Global Nodes CSS */


/* Start Layout CSS */

/* End Layout CSS */

