/*
Theme Name: Weave Digital Studio
Template: generatepress
Theme URI: https://weave.co.nz
Author: Weave Digital Studio
Author URI: https://weave.co.nz/
Description: Weave Digital Studio website 
Version: 1.16
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gpc
*/

/*
CONTENTS:
1. GENERAL
	1.1 Theme Variables
	1.2 Fonts
	1.3 Local Icons
	1.4 Layout
	1.5 Heading
	1.6 Text
	1.7 List
	1.8 Blockquote
	1.9 Link & Button
	1.10 Image
	1.11 Misc
2. HEADER
	2.1 Layout
	2.2 GP Desktop Menu
	2.3 GP Mobile Menu
	2.4 GP Sticky Header
3. FOOTER
4. COMPONENTS
	4.1 Background Animation
	4.2 Color on Scroll
	4.3 Blob Animation
	4.4 List Animation
	4.5 Visibility Toggle
	4.6 Accordion - Capabilities & Expertise 
	4.7 Accordion - Pricing
	4.8 Post Grid (Global)
	4.9 Post Grid: Projects
	4.10 Post Grid: Blog
	4.11 BB Button Group
	4.12 Call to Action
	4.13 Testimonials
	4.14 PP Image Scroll
	4.15 Simple Author Box
	4.16 BT Post Navigation
	4.17 WP Gridbuilder
	4.18 PP Image Comparison
	4.19 Gravity Forms
5. PROJECTS
6. INSIGHTS (BLOG)
7. SEARCH RESULTS
8. MISC
9. STYLES TEMPLATE
*/


/*/////////////////////////////////////////////////////
1. GENERAL
/////////////////////////////////////////////////////*/

/* --------------------------
THEME VARIABLES
-------------------------- */

:root {

	/* COLORS VARIABLES */

	/*
	--primary: #031E29;
	--secondary: #D6CDB7;
	--tertiary: #FBF8F1;
	--coral: #FF9248;
	--unbleached-silk: #FFDBCC;
	--maize: #EDCD48;
	--baby-blue-eyes: #A9C1F6;
	--green-sheen: #7ABC9C;

	--primary-light: #0D3A4D;
	--secondary-light: #F2EBD9;
	--tertiary-light: #ffffff;
	--coral-light: #F9B78A;
	--unbleached-silk-light: #FCE7E0;
	--maize-light: #FCE46D;
	--baby-blue-eyes-light: #C8D3F2;
	--green-sheen-light: #C3EAD7;

	--error: #ff4e7a;
	*/

	--primary-rgb: 3, 30, 41;

	/* MISC VARIABLES */

	--transition-1: all .15s ease-out;
	--transition-2: all .3s ease-out;

}

/* --------------------------
FONTS
-------------------------- */

/*
.woff2 		=> 	Super Modern Browsers
.woff 		=> 	Modern Browsers
.ttf 		=> 	Safari, Android, iOS
.eot 		=> 	IE9 Compat Modes
.eot?#iefix 	=> 	IE6-IE8
*/


/* --------------------------
LOCAL ICONS
-------------------------- */

[class^="wea-icon-"], 
[class*=" wea-icon-"] {
	display: inline-block;
}

/* --------------------------
LAYOUT
-------------------------- */

/* --- RESPONSIVE --- */

@media (min-width: 769px) {
	.wea-mobile {
		display: none;
	}
}
@media (max-width: 768px) {
	.wea-desktop {
		display: none;
	}
}

/* --------------------------
HEADING
-------------------------- */

/* FLUID TYPOGRAPHY */

/* 
https://www.smashingmagazine.com/2022/01/modern-fluid-typography-css-clamp/ 
https://modern-fluid-typography.vercel.app/ 
https://chatgpt.com/share/67f1be86-6218-800e-8232-ae123ff085d1
*/

html {
	/* 16px (browser default) */
	font-size: 100%; 
}
body {
	/* 15/17/20 px */
	font-size: clamp(0.9375rem, .435vw + 0.85rem, 1.25rem);
}
h1, 
.wea-fake-h1 :is(h2,h3,h4,h5,h6), 
.wea-fake-h1:is(h2,h3,h4,h5,h6), 
.wea-heading-fake-h1 :is(h2,h3,h4,h5,h6), 
.wea-heading-fake-h1:is(h2,h3,h4,h5,h6) {
	/* 42/60/100 px */
	font-size: clamp(2.625rem, 5.5vw + 1.5rem, 6.25rem);
}
h2, 
.wea-fake-h2 :is(h1,h3,h4,h5,h6), 
.wea-fake-h2:is(h1,h3,h4,h5,h6), 
.wea-heading-fake-h2 :is(h1,h3,h4,h5,h6), 
.wea-heading-fake-h2:is(h1,h3,h4,h5,h6) {
	/* 28/40/68 px */
	font-size: clamp(1.75rem, 3.7vw + 1rem, 4.25rem); 
}
h3, 
.wea-fake-h3 :is(h1,h3,h4,h5,h6), 
.wea-fake-h3:is(h1,h3,h4,h5,h6), 
.wea-heading-fake-h3 :is(h1,h3,h4,h5,h6), 
.wea-heading-fake-h3:is(h1,h3,h4,h5,h6) {
	/* 22/32/54 px */
	font-size: clamp(1.375rem, 2.7vw + 1rem, 3.375rem);
}
h4 {
	/* 18/25/36 px */
	font-size: clamp(1.125rem, 1.4vw + 1rem, 2.25rem); 
}
h5, 
.wea-fake-h5 :is(h1,h2,h3,h4,h6), 
.wea-fake-h5:is(h1,h2,h3,h4,h6), 
.wea-heading-fake-h5 :is(h1,h2,h3,h4,h6), 
.wea-heading-fake-h5:is(h1,h2,h3,h4,h6) {
	font-family: var(--gp-font--bricolage-grotesque);
	/* 16/22/32 px */
	font-size: clamp(1rem, 1.2vw + 0.85rem, 2rem);
	font-weight: 300;
}
h6 {
	font-family: var(--gp-font--bricolage-grotesque);
	/* 14/17/22 px */
	font-size: clamp(0.875rem, 0.6vw + 0.85rem, 1.375rem); 
}
[class*="wea-fake-h"].wea-color-secondary :is(h1,h2,h3,h4,h5,h6), 
[class*="wea-fake-h"].wea-color-secondary:is(h1,h2,h3,h4,h5,h6) {
	color: var(--secondary) !important;
}

/* MISC */

:is(h1,h2,h3,h4,h5,h6) a {
	text-decoration: none;
}
h1, h2, h3, h4, h5, h6, 
blockquote, blockquote p {
	text-wrap: balance;
} 
.wea-no-balance, 
.wea-no-balance * /*, 
.wea-no-balance:is(h1, h2, h3, h4, h5, h6, 
blockquote, blockquote p) */ {
	text-wrap: unset;
} 
p+:is(h1,h2,h3,h4,h5,h6), 
ul+:is(h1,h2,h3,h4,h5,h6), 
ol+:is(h1,h2,h3,h4,h5,h6) {
	margin-top: 2em;
}

/* PRE-HEADING */

.wea-pre-heading, 
.wea-pre-heading p {
	font-size: clamp(0.813rem, 0.6vw + 0.7rem, 1.25rem); 
	font-weight: 400;
}
.wea-pre-heading a {
	text-decoration: none;
}

/* --------------------------
TEXT
-------------------------- */

p {
	text-wrap: pretty;
}
small {
	font-size: 65%;
}
strong, 
.fl-builder-content .fl-rich-text strong {
	font-weight: 600;
}
.wea-text-intro, 
.wea-text-intro p {
	font-size: clamp(1rem, 0.7vw + 0.8rem, 1.375rem);
	font-weight: 500;
	line-height: 1.3;
}
.wea-text-intro-large, 
.wea-text-intro-large p {
	font-size: clamp(18px, 1vw + .9rem, 32px);
	font-weight: 400;
	line-height: 1.3;
	text-wrap: balance;
}
.wea-text-no-margin-b p, 
p.wea-text-no-margin-b {
	margin-bottom: 0;
}
.wea-whitespace-nowrap {
	white-space: nowrap;
}
.wea-note, 
.wea-note p {
	font-weight: 700;
	font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
	color: var(--error);
	text-align: center;
}
.wea-note a {
	color: var(--error);
}

/* --------------------------
LIST
-------------------------- */

#content .fl-builder-content :not(.fl-module-overlay, .wpgb-facet) li {
	margin-bottom: .5rem;
}
#content .fl-builder-content .fl-module-overlay li, 
.sabox-authors li {
	margin-bottom: 0 !important;
}
#content .fl-builder-content .wpgb-facet li {
	margin-bottom: inherit;
}
.wea-list-no-margin-l ul, 
ul.wea-list-no-margin-l {
	margin-left: 1.2rem;
}

/* --------------------------
BLOCKQUOTE
-------------------------- */

blockquote, 
html .wp-block-quote {
	margin: clamp(1.8em, 5vw, 2.5em) 0;
	padding: 0 0 0 2.5em;
	font-style: normal;
	font-weight: 500;
	color: var(--secondary-dark);
	border: none;
}
blockquote::before {
	content: "“";
	position: absolute;
	top: -.2em;
	left: 0;
	display: block;
	font-family: var(--gp-font--recife-display); 
	font-size: 400%;
	line-height: 1;
}
blockquote p {
	margin-bottom: 0;
	/* 20/22/24 px */
	font-size: clamp(1.125rem, 0.8vw + 0.9rem, 1.5rem);
	line-height: 1.3;
}
blockquote a {
	color: inherit;
}
blockquote a:hover, 
blockquote a:focus {
	color: var(--coral);
}

/* --------------------------
LINK & BUTTON
-------------------------- */

a:not([href]),
a[href=""] {
	cursor: default;
}
/* a:not([href]):hover,
a[href=""]:hover {
	pointer-events: none;
} */
#content a, 
#content a *,
.fl-builder-content a, 
.fl-builder-content a *, 
#content .fl-button, 
#content .fl-button *, 
button.button, 
a.button, 
.button a {
	transition: var(--transition-1);
}
button.button, 
a.button, 
.button a,
.fl-builder-content a.fl-button,
.pp-gf-content .gform_wrapper .gform-button, 
.pp-gf-content .gform_wrapper .gform_footer .gform_button, 
.pp-gf-content .gform_wrapper .gform_page_footer .button {
	padding: 12px 24px;
	background-color: var(--secondary-light);
	font-size: 17px;
	font-weight: 400;
	line-height: 1.2;
	color: var(--primary);
}
button.wea-bt-large, 
.fl-builder-content button.wea-bt-large:not(.fl-menu-mobile-toggle),
button.button.wea-bt-large, 
a.button.wea-bt-large, 
.button.wea-bt-large a,
.fl-builder-content .wea-bt-large a.fl-button,
.fl-builder-content a.fl-button.wea-bt-large,
.wea-bt-large .pp-gf-content .gform_wrapper .gform-button, 
.wea-bt-large .pp-gf-content .gform_wrapper .gform_footer .gform_button, 
.wea-bt-large .pp-gf-content .gform_wrapper .gform_page_footer .button {
	padding: 15px 30px;
	font-size: 20px;
}
button.button:hover, 
a.button:hover, 
.button a:hover,
.pp-gf-content .gform_wrapper .gform-button:hover, 
.pp-gf-content .gform_wrapper .gform_footer .gform_button:hover, 
.pp-gf-content .gform_wrapper .gform_page_footer .button:hover {
	background-color: var(--primary);
	color: white;
}

.fl-builder-content .fl-button i {
	font-size: 1.1em;
}

*:focus {
	outline: none;
}
*:focus-visible {
	outline: 1px dotted rgba(0,0,0,.6);
}
.wea-no-link {
	pointer-events: none;
}
.wea-link-no-underline a, 
a.wea-link-no-underline {
	text-decoration: none;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	button.button, 
	a.button, 
	.button a,
	.fl-builder-content a.fl-button,
	.pp-gf-content .gform_wrapper .gform-button, 
	.pp-gf-content .gform_wrapper .gform_footer .gform_button, 
	.pp-gf-content .gform_wrapper .gform_page_footer .button {
		padding: 10px 20px;
		font-size: 14px;
	}
	button.wea-bt-large, 
	.fl-builder-content button.wea-bt-large:not(.fl-menu-mobile-toggle),
	button.button.wea-bt-large, 
	a.button.wea-bt-large, 
	.button.wea-bt-large a,
	.fl-builder-content .wea-bt-large a.fl-button,
	.wea-bt-large .pp-gf-content .gform_wrapper .gform-button, 
	.wea-bt-large .pp-gf-content .gform_wrapper .gform_footer .gform_button, 
	.wea-bt-large .pp-gf-content .gform_wrapper .gform_page_footer .button {
		padding: 12px 25px;
		font-size: 17px;
	}
}
@media (max-width: 768px) {
	button.button, 
	a.button, 
	.button a,
	.fl-builder-content a.fl-button,
	.pp-gf-content .gform_wrapper .gform-button, 
	.pp-gf-content .gform_wrapper .gform_footer .gform_button, 
	.pp-gf-content .gform_wrapper .gform_page_footer .button {
		padding: 8px 15px;
		font-size: 12px;
	}
	button.wea-bt-large, 
	.fl-builder-content button.wea-bt-large:not(.fl-menu-mobile-toggle),
	button.button.wea-bt-large, 
	a.button.wea-bt-large, 
	.button.wea-bt-large a,
	.fl-builder-content .wea-bt-large a.fl-button,
	.wea-bt-large .pp-gf-content .gform_wrapper .gform-button, 
	.wea-bt-large .pp-gf-content .gform_wrapper .gform_footer .gform_button, 
	.wea-bt-large .pp-gf-content .gform_wrapper .gform_page_footer .button {
		padding: 10px 20px;
		font-size: 14px;
	}
}

/* --------------------------
IMAGE
-------------------------- */

.wea-img-bg-primary-light img {
	background-color: var(--primary-light);
}

/* --------------------------
MISC
-------------------------- */

hr, 
hr.wp-block-separator {
	margin: 2rem auto;
	border: none;
	border-top: 1px solid var(--secondary);
}
[data-node] .fl-separator {
	border-color: var(--secondary);
}
code, kbd, tt, var {
	background-color: #e5e5e5;
	padding: .2rem .5rem;
}

/*/////////////////////////////////////////////////////
2. HEADER
/////////////////////////////////////////////////////*/

/* --------------------------
LAYOUT
-------------------------- */

@media (max-width: 768px) {
	.generate-back-to-top {
		bottom: 15px;
		right: 15px;
		line-height: 30px;
		width: 30px;
	}
}

/* --------------------------
GP DESKTOP MENU
-------------------------- */

/* DEV */
/* .desktop-nav ul ul {
	left: 0;
	height: auto;
	opacity: 1;
} */
/* END DEV */

/* GLOBAL */ 

[data-node] .pp-advanced-menu .menu > li {
	margin: 0;
}
[data-node] .pp-advanced-menu .menu > li > a, 
[data-node] .pp-advanced-menu .menu > li > .pp-has-submenu-container > a {
	padding: 10px 15px;
}
[data-node] .pp-advanced-menu .menu > li.current-menu-ancestor > a, 
[data-node] .pp-advanced-menu .menu > li.current-menu-ancestor > .pp-has-submenu-container > a {
	color: var(--blue-medium);
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	[data-node] .pp-advanced-menu .menu > li > a, 
	[data-node] .pp-advanced-menu .menu > li > .pp-has-submenu-container > a {
		padding-right: 12px;
		padding-left: 12px;
	}
}
@media (max-width: 850px) {
	[data-node] .pp-advanced-menu .menu > li > a, 
	[data-node] .pp-advanced-menu .menu > li > .pp-has-submenu-container > a {
		padding-right: 5px;
		padding-left: 5px;
		letter-spacing: -.5px;
	}
}

/* MENU BUTTON */ 

/* SUB MENU */ 

[data-node] .pp-advanced-menu .sub-menu {
	min-width: 340px;
}
[data-node] .pp-advanced-menu .menu > li > .pp-has-submenu-container + ul.sub-menu {
	padding-top: 10px;
	padding-bottom: 10px;
	animation: submenu_1 .25s ease-out 0s;
}
@keyframes submenu_1 { 
	from { top: 120%; } 
	to { top: 100%; }
}
[data-node] .pp-advanced-menu ul.sub-menu ul.sub-menu {
	padding-left: 10px;
	animation: submenu_2 .25s ease-out 0s;
}
@keyframes submenu_2 { 
	from { top: 8px; } 
	to { top: 0; }
}

/* [data-node] .pp-advanced-menu .sub-menu > li > a, 
[data-node] .pp-advanced-menu .sub-menu > li > .pp-has-submenu-container > a, 
[data-node] .pp-advanced-menu .sub-menu > li:last-child > a:not(:focus), 
[data-node] .pp-advanced-menu .sub-menu > li:last-child > .pp-has-submenu-container > a:not(:focus) {
	margin-bottom: 5px;
	border-radius: 50px;
}
[data-node] .pp-advanced-menu .sub-menu > li.current-menu-ancestor > a, 
[data-node] .pp-advanced-menu .sub-menu > li.current-menu-ancestor > .pp-has-submenu-container > a {
	background-color: var(--blue-medium);
} */

.desktop-nav ul ul.sub-menu li a {
	position: relative;
	display: flex;
}
.desktop-nav ul ul.sub-menu li a::before {
	content: "";
	display: inline-block;
	aspect-ratio: 1 / 1;
	height: 12px;
	margin: .25em 20px 0 0;
	transition: var(--transition-1);
}
.desktop-nav ul ul.sub-menu li a:hover::before {
	transform: rotate(90deg);
	transform-origin: center;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+1) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+1) a::before {
	background-color: var(--secondary);
	border-radius: 0 100% 0 0;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+2) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+2) a::before {
	background-color: var(--maize);
	border-radius: 0 0 100% 0;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+3) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+3) a::before {
	background-color: var(--baby-blue-eyes);
	border-radius: 0 0 0 100%;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+4) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+4) a::before {
	background-color: var(--green-sheen);
	border-radius: 100% 0 0 0;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+5) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+5) a::before {
	background-color: var(--unbleached-silk);
	border-radius: 0 100% 0 0;
}
.desktop-nav ul ul.sub-menu > li:nth-child(6n+6) a::before, 
.desktop-nav ul ul.sub-menu li:nth-child(6n+6) a::before {
	background-color: var(--coral);
	border-radius: 0 0 100% 0;
}

/* --------------------------
GP MOBILE MENU
-------------------------- */

/* MENU TOGGLE */ 

.fl-module-pp-advanced-menu .pp-advanced-menu-mobile-toggle {
	padding: 0;
	border-radius: unset !important;
}
.fl-builder-content [data-node].fl-module .pp-advanced-menu-mobile .pp-advanced-menu-mobile-toggle, 
.fl-page .fl-builder-content [data-node].fl-module .pp-advanced-menu-mobile .pp-advanced-menu-mobile-toggle, 
.fl-builder-content [data-node].fl-module .pp-advanced-menu-mobile .pp-advanced-menu-mobile-toggle:hover, 
.fl-page .fl-builder-content [data-node].fl-module .pp-advanced-menu-mobile .pp-advanced-menu-mobile-toggle:hover {
	background-color: unset;
}
.pp-advanced-menu-mobile-toggle:hover .pp-hamburger .pp-hamburger-box .pp-hamburger-inner, 
.pp-advanced-menu-mobile-toggle:hover .pp-hamburger .pp-hamburger-box .pp-hamburger-inner:before, 
.pp-advanced-menu-mobile-toggle:hover .pp-hamburger .pp-hamburger-box .pp-hamburger-inner:after, 

[class] .pp-advanced-menu .pp-menu-overlay .pp-menu-close-btn:hover:before, 
[class] .pp-advanced-menu .pp-menu-overlay .pp-menu-close-btn:hover:after {
	background-color: var(--blue-medium);
}
.pp-advanced-menu-mobile-toggle .pp-hamburger .pp-hamburger-box .pp-hamburger-inner, 
.pp-advanced-menu-mobile-toggle .pp-hamburger .pp-hamburger-box .pp-hamburger-inner:before, 
.pp-advanced-menu-mobile-toggle .pp-hamburger .pp-hamburger-box .pp-hamburger-inner:after {
	border-radius: unset;
}
.pp-advanced-menu .pp-menu-overlay .pp-menu-close-btn {
	top: 13px;
	right: 18px;
}
.admin-bar .pp-advanced-menu .pp-menu-overlay .pp-menu-close-btn {
	top: 59px;
}

@media only screen and (max-width: 768px) {
	[class] .pp-advanced-menu.full-screen .pp-menu-overlay ul.menu {
		width: 100%;
	}
	[class] .pp-advanced-menu .menu a {
		font-size: clamp(1.25rem, 1vw + 1rem, 1.625rem);
	}
}

/* SUB MENU */ 

[class*="fl-node"] .pp-advanced-menu.full-screen .menu .sub-menu li a, 
[class*="fl-node"] .pp-advanced-menu.full-screen .menu .sub-menu li .pp-has-submenu-container a {
	padding: 5px 10px;
}
[class*="fl-node"] .pp-advanced-menu.full-screen .sub-menu {
	padding: 1.5em 0;
	border-top: 1px solid var(--secondary);
	border-bottom: 1px solid var(--secondary);
}
.fl-theme-builder-header-header-dark-bg [class*="fl-node"] .pp-advanced-menu.full-screen .sub-menu {
	border-color: var(--primary-light);
}

/* --------------------------
GP STICKY HEADER
-------------------------- */

header.fl-theme-builder-header-shrink .fl-row-content-wrap {
	box-shadow: 0 0 20px rgba(var(--primary-rgb), .1);
}
header .wea-logo .fl-photo-content {
	transition: var(--transition-2);
}
header.fl-theme-builder-header-shrink .wea-logo .fl-photo-content {
	max-width: 110px;
}

/* Fix for Themer 1.5 responsive shrinked header */
.fl-row > .fl-theme-builder-header-shrink-row-top.fl-row-content-wrap {
	padding-top: 5px;
}
.fl-row > .fl-theme-builder-header-shrink-row-bottom.fl-row-content-wrap {
	padding-bottom: 5px;
}


/*/////////////////////////////////////////////////////
3. FOOTER
/////////////////////////////////////////////////////*/


/*/////////////////////////////////////////////////////
4. COMPONENTS
/////////////////////////////////////////////////////*/

/*--------------------------
BACKGROUND ANIMATION
--------------------------*/

.wea-bg-anim .fl-row-content, 
.fl-module-box.wea-bg-anim {
	z-index: 2;
	overflow: hidden;
}
.fl-module-box.wea-bg-anim {
	position: relative;
}

/* BG ANIMATION 1 */

.wea-bg-anim .fl-row-content-wrap::before, 
.fl-module-box.wea-bg-anim::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 40vmin;
	height: auto;
	aspect-ratio: 1/1;
	background-color: var(--coral);
	border-radius: 100%;
	filter: blur(12vmin);
	transform: translate(-50%, -50%) scale(.5);
	transform-origin: center;
	z-index: 1;
	animation: 4s linear 0s infinite alternate wea-bg-anim-1;
}
body.contact .wea-bg-anim::before {
	top: 40%;
	left: -5%;
	width: 30vmin;
	opacity: .5;
}

@keyframes wea-bg-anim-1 {
	from {
		transform: translate(-50%, -50%) scale(.6);
	}
	to { 
		transform: translate(-50%, -50%) scale(1.2);
	}
}

/* BG ANIMATION 2 */

.wea-bg-anim .fl-row-content-wrap::after, 
.fl-module-box.wea-bg-anim::after {
	content: "";
	position: absolute;
	width: auto;
	background: no-repeat center/contain url('/wp-content/uploads/2025/04/mesh-gradient-shape-1.jpg');
	aspect-ratio: 74/100;
	filter: blur(1.5vw);
	transform-origin: center;
}
body.home .wea-bg-anim .fl-row-content-wrap::after {
	top: 15%;
	right: 5%;
	height: 85%;
	animation: 30s linear infinite 0s wea-bg-anim-2;
}
body.contact .wea-bg-anim::after {
	top: -20%;
	right: 40%;
	width: clamp(300px,50%,730px);
	height: auto;
	z-index: -1;
	transform: rotate(-65deg);
}

@keyframes wea-bg-anim-2 {
	0% {
		transform: rotate(0deg) scale(.5);
		opacity: .7;
	}
	50% { 
		transform: rotate(180deg) scale(1.1); 
		opacity: 1;
	}
	100% { 
		transform: rotate(360deg) scale(.5); 
		opacity: .7;
	}
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	body.contact .wea-bg-anim::after {
		top: -15%;
		right: 40%;
	}
}
@media (max-width: 768px) {
	body.home .wea-bg-anim .fl-row-content-wrap::after {
		right: -20%;
	}
	body.contact .wea-bg-anim::after {
		top: -11%;
		right: 35%;
	}
}

/* ---------------------------------
COLOR ON SCROLL
--------------------------------- */

/* TARGET */ 

.wea-color-on-scroll .fl-row-content-wrap {
	transition: background-color 1s ease-out;
	background: transparent;
}
.wea-color-on-scroll.active .fl-row-content-wrap {
	background-color: var(--primary);
}

/* --------------------
BLOB ANIMATION
-------------------- */

[class*="wea-blob-anim"] {
	position: relative;
	overflow: hidden;
	z-index: 0;
}
[class*="wea-blob-anim"] .wea-blob {
	filter: blur(60px);
	position: absolute;
	margin: auto;
	/*inline-size: 100%;*/
	block-size: 100%;
	overflow: hidden;
	transform: scale(1);
	inset: 0;
	z-index: -1;
	animation: animBlob 10s linear infinite;
}
[class*="wea-blob-anim"] .wea-blob::before {
	position: absolute;
	border-radius: 1000px;
	width: 100%;
	height: 60%;
	inset: 0;
	margin: auto;
	content: "";
	z-index: -1;
}
.wea-blob-anim-1 .wea-blob::before {
	background: conic-gradient(
		from 0deg,
		var(--secondary),
		var(--tertiary),
		var(--tertiary),
		var(--unbleached-silk),
		var(--baby-blue-eyes),
		var(--coral)
	);
}

@keyframes animBlob {
	0% {
		opacity: 1;
		transform: rotate(0deg) scaleX(1);
		inline-size: 100%;
	}
	50% {
		 opacity: .5;
		transform: rotate(180deg) scaleX(3);
		inline-size: 20%;
	}
	100% {
		opacity: 1;
		transform: rotate(360deg) scaleX(1);
		inline-size: 100%;
	}
}

/* ---------------------------------
LIST ANIMATION
--------------------------------- */

body:not(.fl-builder-edit) .wea-list-anim .pp-list-item {
	opacity: 0;
	transition: all 1s ease-out;
	transform: translateY(50%);
}
body:not(.fl-builder-edit) .wea-list-anim .pp-list-item.active {
	opacity: 1;
	transform: translateY(0);
}

/* ---------------------------------
VISIBILITY TOGGLE
--------------------------------- */

body:not(.fl-builder-edit) .wea-visibility-target {
	display: none;
}

/*--------------------------
PP ACCORDION
--------------------------*/

.fl-module-pp-advanced-accordion .pp-accordion-button-icon::before {
	display: flex;
	justify-content: center;
	align-items: center;
	aspect-ratio: 1;
	width: auto;
	height: 100%;
	padding: .6em;
	border-radius: 100%;
	transition: var(--transition-1);
}
.fl-module-pp-advanced-accordion.wea-primary-bg .pp-accordion-button-icon::before {
	background-color: var(--primary-light);
}
.fl-module-pp-advanced-accordion.wea-primary-bg .pp-accordion-item:hover .pp-accordion-button-icon::before, 
.fl-module-pp-advanced-accordion.wea-primary-bg .pp-accordion-item-active .pp-accordion-button-icon::before {
	background-color: var(--secondary-light);
	color: var(--primary-light);
}

/*--------------------------
ACCORDION - CAPABILITIES & EXPERTISE
--------------------------*/

/* GENERAL */ 

.wea-accordion-cap-expert {
	color: var(--primary);
}
.wea-color-on-scroll.active .wea-accordion-cap-expert {
	color: white;
}
body:not(.fl-builder-edit) .wea-accordion-cap-expert .wea-item:not(.active):hover, 
body:not(.fl-builder-edit) .wea-accordion-cap-expert .wea-item.active .wea-label:hover {
	cursor: pointer;
}
.wea-accordion-cap-expert .wea-item {
	padding: 30px 0;
}

/* ACCORDION ITEM LABEL */ 

.wea-accordion-cap-expert .wea-item .wea-label .fl-module {
	display: flex;
}
.wea-accordion-cap-expert .wea-item .wea-label {
	transition: var(--transition-1);
}
.wea-accordion-cap-expert .wea-item .wea-label > .fl-module-rich-text {
	gap: .8rem;
}
.wea-accordion-cap-expert .wea-item.active .wea-label, 
.wea-accordion-cap-expert .wea-item:hover .wea-label, 

body.website-design .wea-accordion-cap-expert .wea-item .wea-label .website-design, 
body.website-development .wea-accordion-cap-expert .wea-item .wea-label .website-development, 
body.wordpress-experts .wea-accordion-cap-expert .wea-item .wea-label .wordpress-experts, 
body.digital-branding-kits .wea-accordion-cap-expert .wea-item .wea-label .digital-branding-kits, 
body.logo-design-branding .wea-accordion-cap-expert .wea-item .wea-label .logo-design-branding, 
body.hosting-security .wea-accordion-cap-expert .wea-item .wea-label .hosting-security, 
body.cms-training .wea-accordion-cap-expert .wea-item .wea-label .cms-training, 
body.website-audits .wea-accordion-cap-expert .wea-item .wea-label .website-audits {
	color: var(--blue-medium);
}
.wea-accordion-cap-expert .wea-item .wea-label p {
	margin-bottom: 0;
}
.wea-accordion-cap-expert .wea-item .wea-label .fl-module::before {
	content: "\e905";
	font-family: "Weave-Icons";
	font-size: 75%;
	width: 1em;
	transform: translateY(.25em);
}
.wea-accordion-cap-expert .wea-item.active .wea-label .fl-module::before {
	content: "\e907";
}

/* ACCORDION ITEM CONTENT */ 

body:not(.fl-builder-edit.single) .wea-accordion-cap-expert .wea-item .wea-content {
	display: none;
}
.wea-accordion-cap-expert ul {
	margin-left: 1.2rem;
}
.wea-accordion-cap-expert .wea-content .wea-item ul {
	margin-left: 1em;
}
#content .fl-builder-content .wea-accordion-cap-expert .wea-item .wea-content ul li {
	margin-bottom: .25em;
}
.wea-accordion-cap-expert .wea-item .wea-content a.fl-button {
	background: transparent;
	border: 1px solid var(--primary);
	border-radius: 50px;
}
.wea-accordion-cap-expert .wea-item .wea-content a.fl-button * {
	color: var(--primary);
}
.wea-accordion-cap-expert .wea-item .wea-content a.fl-button:hover {
	background-color: var(--primary);
}
.wea-accordion-cap-expert .wea-item .wea-content a.fl-button:hover * {
	color: white;
}
.wea-color-on-scroll.active .wea-accordion-cap-expert .wea-item .wea-content a.fl-button {
	border-color: white;
}
.wea-color-on-scroll.active .wea-accordion-cap-expert .wea-item .wea-content a.fl-button:hover {
	background-color: white;
}
.wea-color-on-scroll.active .wea-accordion-cap-expert .wea-item .wea-content a.fl-button * {
	color: white;
}
.wea-color-on-scroll.active .wea-accordion-cap-expert .wea-item .wea-content a.fl-button:hover * {
	color: var(--primary);
}
.wea-accordion-cap-expert .wea-item .wea-text {
	flex-basis: 50%;
	flex-shrink: 1;
}
.wea-accordion-cap-expert .wea-item .wea-img {
	flex-basis: 50%;
	flex-shrink: 0;
	transition: var(--transition-2);
	background-color: var(--primary-light);
}
.wea-color-on-scroll:not(.active) .wea-accordion-cap-expert .wea-item .wea-img {
	background-color: var(--primary-light);
}
.wea-accordion-cap-expert .wea-item .wea-img:hover, 
.wea-color-on-scroll:not(.active) .wea-accordion-cap-expert .wea-item .wea-img:hover {
	background-color: var(--primary);
	/* background-color: var(--primary-light); */
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	.wea-accordion-cap-expert .wea-item {
		padding: 20px 0;
	}
	.wea-accordion-cap-expert .wea-item .wea-text {
		flex-basis: 70%;
	}
	.wea-accordion-cap-expert .wea-item .wea-img {
		flex-basis: 30%;
	}
}
@media (max-width: 768px) {
	.wea-accordion-cap-expert .wea-item {
		padding: 15px 0;
	}
	.wea-accordion-cap-expert .wea-item .wea-img {
		flex-basis: 100px;
	}
}

/*--------------------------
ACCORDION - PRICING
--------------------------*/

/* GENERAL */ 

.wea-accordion-pricing .pp-accordion-item {
	background-color: white;
	border-radius: 20px;
}
.wea-accordion-pricing .pp-accordion-button {
	position: relative;
}

/* ACCORDION ITEM LABEL */ 

.wea-accordion-pricing .pp-accordion-button-label {
	display: flex;
	justify-content: space-between;
	align-items: center;
	column-gap: 1em;
	font-size: clamp(1rem, 1.2vw + 0.85rem, 2rem);
	font-weight: 400;
}
.wea-accordion-pricing .pp-accordion-button-label small, 
.wea-accordion-pricing .pp-accordion-button-label .wea-description {
	font-size: clamp(1rem, 0.7vw + 0.8rem, 1.375rem);
}
.wea-accordion-pricing .pp-accordion-button-label .wea-price {
	padding-right: 2.5em;
}
.wea-accordion-pricing .pp-accordion-button-label small {
	font-weight: 300;
}
.wea-accordion-pricing .pp-accordion-button-label .wea-description {
	color: var(--primary);
	width: 100%;
	border-top: 1px solid var(--green-sheen);
	padding-top: .6em;
	margin-top: .8em;
	text-wrap: balance;
}
.wea-accordion-pricing .pp-accordion-button-icon {
	padding-left: 0 !important;
	position: absolute;
	top: 25px;
	right: 30px;
}
.wea-accordion-pricing .pp-accordion-button-icon::before {
	border: 1px solid var(--green-sheen);
}
.wea-accordion-pricing .pp-accordion-item:nth-child(2) .pp-accordion-button-label .wea-description, 
.wea-accordion-pricing .pp-accordion-item:nth-child(2) .pp-accordion-button-icon::before, 
.wea-accordion-pricing .pp-accordion-item:nth-child(2):hover .pp-accordion-button-icon::before, 
.wea-accordion-pricing .pp-accordion-item:nth-child(2):focus .pp-accordion-button-icon::before {
	border-color: var(--coral);
}
.wea-accordion-pricing .pp-accordion-item:nth-child(2):hover .pp-accordion-button-icon::before, 
.wea-accordion-pricing .pp-accordion-item:nth-child(2):focus .pp-accordion-button-icon::before, 
.wea-accordion-pricing .pp-accordion-item-active:nth-child(2) .pp-accordion-button-icon::before {
	border-color: var(--coral);
	color: var(--coral);
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.wea-accordion-pricing .pp-accordion-button-icon {
		right: 20px;
	}
}

/* ACCORDION ITEM CONTENT */ 

.wea-accordion-pricing .pp-accordion-content ul {
	margin-left: 2em;
	list-style-type: none;
}
.wea-accordion-pricing .pp-accordion-content ul li {
	position: relative;
	padding-left: 2em;
}
.wea-accordion-pricing .pp-accordion-content ul li::before {
	content: "\e90e";
	position: absolute;
	top: 0;
	left: 0;
	font-family: "Weave-Icons";
	font-size: 120%;
}
.wea-accordion-pricing .pp-accordion-content a.fl-button {
	display: inline-flex;
	margin-top: 2.5em;
}
.wea-accordion-pricing .pp-accordion-content a.fl-button::after {
	content: "\e90b";
	font-family: "Weave-Icons";
	margin-left: .5em;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	.wea-accordion-pricing .pp-accordion-item {
		margin-bottom: 40px;
		border-radius: 15px;
	}
	.wea-accordion-pricing .pp-accordion-content ul {
		margin-left: 0;
	}
}
@media (max-width: 768px) {
	.wea-accordion-pricing .pp-accordion-item {
		margin-bottom: 30px;
		border-radius: 10px;
	}
	.wea-accordion-pricing .pp-accordion-button-label {
		flex-direction: column;
		align-items: flex-start;
	}
}

/*--------------------------
POST GRID (GLOBAL)
--------------------------*/

.fl-loop-grid, 
.fl-loop-grid li {
	margin: 0 !important;
}
.wea-posts.wea-grid .fl-loop-grid a:hover .wea-heading.fl-rich-text *, 
.wea-posts.wea-grid .fl-loop-grid a:focus .wea-heading.fl-rich-text * {
	/* color: var(--blue-medium); */
	color: var(--coral);
}
.wea-posts.wea-grid .fl-loop-grid .wea-feat-img img {
	aspect-ratio: 1.5;
	object-fit: cover;
}
.wea-posts.wea-grid .fl-loop-grid a:hover .wea-feat-img img {
	filter: brightness(.9);
}
.wea-posts.wea-grid .fl-loop-grid .wea-text *:not(b, strong) {
	font-size: clamp(0.875rem, 0.5vw + 0.7rem, 1.125rem);
}
.wea-posts.wea-grid .fl-loop-grid .wea-text.wea-tax *:not(b, strong) {
	font-size: clamp(0.675rem, 0.5vw + 0.7rem, 0.925rem);
}
.wea-posts.wea-grid .fl-loop-grid .wea-text p {
	margin-bottom: 0;
}

/* PAGINATION */ 

.fl-builder-pagination ul.page-numbers {
	display: flex; 
	justify-content: center;
	gap: 1em;
}
.fl-builder-pagination ul.page-numbers li {
	margin: unset !important;
}
.fl-builder-pagination li a.page-numbers, 
.fl-builder-pagination li span.page-numbers {
	padding: .2em 0;
	margin: unset;
	text-decoration: none;
	font-weight: 400;
	color: var(--coral);
	border: none;
	border-bottom: 1px solid var(--coral);
}
.fl-builder-pagination li .page-numbers {
	min-width: 1.2em;
}
.fl-builder-pagination li a.page-numbers:hover, 
.fl-builder-pagination li span.current {
	background: unset;
	color: var(--primary);
	border-color: var(--primary);
}

/*--------------------------
POST GRID: PROJECTS
--------------------------*/

/* BB LOOP MODULE */

.wea-posts.wea-grid.wea-projects > .fl-loop-grid {
	grid-template-columns: repeat(8, 1fr);
}
.wea-posts.wea-grid.wea-projects > .fl-loop-grid:has(~ .fl-loop-grid)  {
	margin-bottom: 60px !important;
}
.wea-posts.wea-grid > .fl-loop-grid > li:has(.fl-module-box), 
.wea-posts.wea-grid.wea-projects > .fl-loop-grid > li:has(.fl-module-box) {
	display: block;
}
.wea-posts.wea-grid.wea-projects > .fl-loop-grid > li {
	grid-column: span 2;
}
body:not(:has(.wpgb-page)) .wea-posts.wea-grid.wea-projects.wea-featured > .fl-loop-grid:first-child > li:first-of-type,
body:has(.wpgb-page > a[data-page="1"][aria-current="true"]) .wea-posts.wea-grid.wea-projects.wea-featured > .fl-loop-grid:first-child > li:first-of-type {
	grid-column: span 4;
}
body.home .wea-posts.wea-grid.wea-projects > .fl-loop-grid > li:nth-of-type(4) {
	grid-column: span 3;
}
body.home .wea-posts.wea-grid.wea-projects > .fl-loop-grid > li:nth-of-type(5) {
	grid-column: 5/span 4;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	.wea-posts.wea-grid.wea-projects > .fl-loop-grid:has(~ .fl-loop-grid)  {
		margin-bottom: 40px !important;
	}
}
@media (max-width: 768px) {
	.wea-posts.wea-grid.wea-projects > .fl-loop-grid:has(~ .fl-loop-grid)  {
		margin-bottom: 20px !important;
	}
}

/* PP CONTENT GRID */

.wea-posts.wea-grid .fl-photo-content a {
	border-radius: 20px;
	overflow: hidden;
}
.wea-posts.wea-grid .fl-photo-content img {
	aspect-ratio: 1.4;
	object-fit: cover;
}

.wea-posts.wea-grid .pp-carousel-nav {
	position: absolute;
	top: -80px;
	right: 0;
	display: flex;
	gap: 20px;
}
.wea-posts.wea-grid .pp-content-posts-inner {
	width: calc(100% + 40px);
	margin-left: -20px;
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button {
	position: unset;
	width: auto;
	height: auto;
	line-height: 1;
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button span {
	display: none;
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-next::after, 
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-prev::after {
	font-family: "Weave-Icons";
	font-size: 38px;
	color: var(--primary);
	opacity: .3;
	transition: var(--transition-1);	
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-next::after {
	content: "\e901";
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-prev::after {
	content: "\e900";
}
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-next:hover::after, 
.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-prev:hover::after {
	opacity: 1;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	.wea-posts.wea-grid .fl-photo-content a {
		border-radius: 15px;
	}
	.wea-posts.wea-grid .pp-carousel-nav {
		top: -65px;
		gap: 15px;
	}
	.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-next::after, 
	.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-prev::after {
		font-size: 32px;
	}
}
@media (max-width: 768px) {
	.wea-posts.wea-grid .fl-photo-content a {
		border-radius: 10px;
	}
	.wea-posts.wea-grid .pp-carousel-nav {
		top: -50px;
		gap: 10px;
	}
	.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-next::after, 
	.wea-posts.wea-grid .pp-content-post-carousel .owl-nav button.owl-prev::after {
		font-size: 28px;
	}
}

/*--------------------------
POST GRID: BLOG
--------------------------*/

.wea-posts.wea-grid.wea-blog > .fl-loop-grid {
	grid-template-columns: repeat(3, 1fr);
}
body:not(:has(.wpgb-page)) .wea-posts.wea-grid.wea-blog.wea-featured > .fl-loop-grid > li:first-of-type,
body:has(.wpgb-page > a[data-page="1"][aria-current="true"]) .wea-posts.wea-grid.wea-blog.wea-featured > .fl-loop-grid > li:first-of-type {
	grid-column: span 2;
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.wea-posts.wea-grid.wea-blog {
		display: flex;
		justify-content: center;
	}
}

/*--------------------------
POST GRID (GLOBAL)
--------------------------*/

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.wea-posts.wea-grid.wea-projects > .fl-loop-grid, 
	.wea-posts.wea-grid.wea-blog > .fl-loop-grid {
		grid-template-columns: 1fr;
		max-width: 420px;
	}
	.wea-posts.wea-grid.wea-projects > .fl-loop-grid > li, 
	.wea-posts.wea-grid.wea-blog > .fl-loop-grid > li {
		grid-column: unset !important;
	}
	.wea-posts.wea-grid .fl-loop-grid .wea-feat-img img, 
	.wea-posts.wea-grid .fl-loop-grid.wea-projects .wea-feat-img img {
		display: flex;
		width: auto;
		max-height: clamp(300px, 60vw ,400px);
	}
}

/*--------------------------
BB BUTTON GROUP
--------------------------*/

.fl-builder-content [data-node] .fl-button-group-button .fl-button .fl-button-text {
	transition: var(--transition-1);
}

/*--------------------------
CALL TO ACTION
--------------------------*/

.wea-cta .wea-text {
	width: clamp(215px, 100%, 600px);
}
:is(.wea-cta, .wea-cta-narrow) .wea-heading > p {
	font-family: var(--gp-font--recife-display); 
	font-size: clamp(35px, 7vw, 130px);
	line-height: 1em;
	transform: translateY(clamp(4px, .7vw, 19px));
}
.wea-cta-narrow .wea-heading > p {
	font-size: clamp(21px, 4.5vw, 90px);
}

/*--------------------------
TESTIMONIALSS
--------------------------*/

/* LAYOUT */

.wea-testimonials .wea-swiper {
	overflow: hidden;
}
.wea-testimonials .wea-swiper .swiper-wrapper {
	padding-bottom: 4vw;
}
.fl-builder-edit .wea-testimonials .wea-swiper .swiper-wrapper {
	flex-direction: column;
}
.fl-builder-edit .wea-testimonials .swiper-slide {
	height: auto;
	margin-bottom: 2vw;
}
.wea-testimonials .swiper-slide .wea-text {
	margin-bottom: 4vw;
}

/* PAGINATION */

.wea-testimonials .swiper-pagination {
	position: initial;
	text-align: left;
}

/* NAVIGATION */

.wea-testimonials .wea-swiper .wea-navigation {
	display: flex;
	gap: 20px;
}
.wea-testimonials .wea-swiper .swiper-button-prev, 
.wea-testimonials .wea-swiper .swiper-button-next {
	position: initial;
	margin-top: 0;
	width: auto;
}
.wea-testimonials .swiper-button-next:after, 
.wea-testimonials .swiper-button-prev:after {
	font-family: "Weave-Icons";
	font-size: 38px;
	color: var(--primary);
	opacity: .3;
	transition: var(--transition-1);
}
.wea-testimonials .swiper-button-next:hover:after, 
.wea-testimonials .swiper-button-prev:hover:after {
	opacity: 1;
}
.wea-testimonials .wea-swiper .swiper-button-prev:after, 
.wea-testimonials .wea-swiper .swiper-rtl .swiper-button-next:after {
	content: "\e900";
}
.wea-testimonials .wea-swiper .swiper-button-next:after, 
.wea-testimonials .wea-swiper .swiper-rtl .swiper-button-prev:after {
	content: "\e901";
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	.wea-testimonials .wea-swiper .wea-navigation {
		gap: 15px;
	}
	.wea-testimonials .swiper-button-next:after, 
	.wea-testimonials .swiper-button-prev:after {
		font-size: 32px;
	}
}
@media (max-width: 768px) {
	.wea-testimonials .wea-swiper .wea-navigation {
		gap: 10px;
	}
	.wea-testimonials .swiper-button-next:after, 
	.wea-testimonials .swiper-button-prev:after {
		font-size: 28px;
	}
}

/* ---------------------------------
PP IMAGE SCROLL
--------------------------------- */

/* LAYOUT */ 

.fl-module[class*="wea-project-"] .fl-module-photo img, 
.fl-module-pp-image-scroll .pp-image-scroll-container {
	aspect-ratio: 0.85;
	overflow: hidden;
}
.fl-module[class*="wea-project-"] .fl-photo-content, 
.fl-module-pp-image-scroll .fl-module-content {
	position: relative;
	z-index: 0;
}

/* OVERLAY */ 

.fl-module-pp-image-scroll .pp-image-scroll-container::-webkit-scrollbar {
	/*display: none;*/
	scrollbar-width: none;
}
.fl-module-pp-image-scroll .pp-overlay-content {
	aspect-ratio: 1/1;
	width: 3.5rem;
	display: flex;
	justify-content: center;
	align-items: center;
}
.fl-module-pp-image-scroll .pp-overlay-content .pp-overlay-icon {
	font-size: 2rem;
}

/* DECORATION */ 

.fl-module[class*="wea-project-"] .fl-module-content::after {
	content: "";
	display: block !important;
	position: absolute;
	top: -8%;
	right: -8%;
	bottom: 40%;
	left: -8%;
	z-index: -1;
	border-radius: 20px;
}
.fl-module.wea-project-gh .fl-module-content::after {
	background-color: #CAD5B2;
}
.fl-module.wea-project-resilience .fl-module-content::after {
	background-color: #9A7442;
}
.fl-module.wea-project-olw .fl-module-content::after {
	background-color: #0D3A4D;
}

/*--------------------------
SIMPLE AUTHOR BOX
--------------------------*/

/* LAYOUT */ 

.sabox-authors {
	margin-top: clamp(60px, 10vw, 120px);
	margin-bottom: clamp(20px, 3vw, 40px);
}
.sabox-authors .saboxplugin-wrap {
	border: 1px solid var(--secondary);
	border-radius: 10px;
}
.sabox-authors .saboxplugin-authorname .fn {
	font-family: var(--gp-font--recife-display); 
	font-size: clamp(1.25rem, 1vw + 0.9rem, 1.625rem);
}
.sabox-authors .saboxplugin-tabs-wrapper, 
.sabox-authors .sab-edit-settings a {
	font-size: 14px;
	text-decoration: none;
}

/* LATEST POSTS */ 

.sabox-authors .saboxplugin-tab-latest_posts li {
	font-size: 90%;
}
.sabox-authors .saboxplugin-tab-latest_posts a {
	text-decoration: none;
}
.sabox-authors .saboxplugin-tab-latest_posts a::before {
	content: "\e905";
	display: inline-block;
	font-family: "Weave-Icons";
	font-size: 90%;
	width: 2em;
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.sabox-authors .saboxplugin-tab {
		padding: 20px 0;
	}
}

/*--------------------------
BT POST NAVIGATION
--------------------------*/

.fl-module-fl-post-navigation .nav-links {
	justify-content: space-between;
	align-items: center;
	gap: 10px;
}
.fl-module-fl-post-navigation .nav-links .nav-previous, 
.fl-module-fl-post-navigation .nav-links .nav-next {
	margin: 0;
}
.fl-module-fl-post-navigation .nav-links a {
	display: inline-flex;
	gap: clamp(10px, 3vw, 20px);
	align-items: center;
	text-decoration: none;
	text-wrap: balance;
}
.fl-module-fl-post-navigation .nav-links a img {
	aspect-ratio: 1;
	width: clamp(50px, 8vw ,80px);
	border-radius: 5px;
}
.fl-module-fl-post-navigation .nav-links a .post-title {
	display: flex;
	gap: clamp(5px, 2vw, 12px);
	align-items: center;
}
.fl-module-fl-post-navigation .nav-links .nav-previous a .post-title::before, 
.fl-module-fl-post-navigation .nav-links .nav-next a .post-title::after {
	display: inline-block;
	font-family: "Weave-Icons";
	font-size: 90%;
}
.fl-module-fl-post-navigation .nav-links .nav-previous a .post-title::before {
	content: "\e904";
}
.fl-module-fl-post-navigation .nav-links .nav-next a .post-title::after {
	content: "\e905";
}
.fl-module-fl-post-navigation .nav-links a img {
	transition: var(--transition-1);
}
.fl-module-fl-post-navigation .nav-links a:hover img {
	opacity: .8;
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.fl-module-fl-post-navigation .nav-links {
		display: flex;
	}
}
@media (max-width: 620px) {
	.fl-module-fl-post-navigation .nav-links {
		flex-direction: column;
	}
}

/*--------------------------
WP GRIDBUILDER
--------------------------*/

/* LAYOUT */

html .wpgb-facet > fieldset:last-child {
	margin-bottom: 0;
}
body.tax-industry .wea-facets .fl-module-box {
	padding-left: 0;
	border-left: none;
}

/* FACETS */

html .wpgb-facet .wpgb-az-index-label, 
html .wpgb-facet .wpgb-button-label, 
html .wpgb-facet .wpgb-checkbox-label, 
html .wpgb-facet .wpgb-hierarchy-label, 
html .wpgb-facet .wpgb-radio-label, 
html .wpgb-facet .wpgb-rating-label {
	font-size: clamp(0.9375rem, .435vw + 0.85rem, 1.25rem);
}

html .wpgb-facet .wpgb-hierarchical-list li:not(:first-child) {
	margin-top: .5em !important;
}

html .wpgb-facet .wpgb-hierarchy-facet .wpgb-hierarchy {
	align-items: center;
}
html .wpgb-facet .wpgb-hierarchy-facet .wpgb-hierarchy[aria-pressed=true] input:not([value=""])~.wpgb-hierarchy-label {
    font-weight: inherit;
}
html .wpgb-facet .acplt-clear, 
html .wpgb-facet .wpgb-clear-button, 
html .wpgb-facet .wpgb-hierarchy .wpgb-hierarchy-control, 
html .wpgb-facet .wpgb-input-icon, 
html .wpgb-facet .wpgb-rating-reset .wpgb-rating-control, 
html .wpgb-facet .wpgb-select button, 
html .wpgb-facet .wpgb-select-controls {
	color: var(--coral);
}
html .wpgb-facet .wpgb-hierarchy-facet .wpgb-hierarchy-control svg {
	stroke-width: 2px;
}

html .wpgb-facet.wpgb-style-1 button.wpgb-button:disabled:hover {
	background-color: var(--secondary-light);
}

/* LOADER */

.wpgb-enabled .fl-loop-item {
	opacity: 1;
	transition: var(--transition-2);
}
.wpgb-enabled.wpgb-loading .fl-loop-item {
	opacity: .3;
}
.wpgb-enabled {
	/* display: flow-root; */
	position: relative;
}
.wpgb-enabled.wpgb-loading::after {
	content: "";
	display: block !important;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	animation: rotateLoader infinite 1s linear;
	box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.925), 0 -20px rgba(33, 117, 155, 0.8), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.675), 20px 0 rgba(33, 117, 155, 0.55), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.425), 0 20px rgba(33, 117, 155, 0.3), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.175), -20px 0 rgba(33, 117, 155, 0.05);
	transition: box-shadow 200ms ease;
	opacity: 1;
}

@keyframes rotateLoader {
	0% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.925), 0 -20px rgba(33, 117, 155, 0.8), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.675), 20px 0 rgba(33, 117, 155, 0.55), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.425), 0 20px rgba(33, 117, 155, 0.3), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.175), -20px 0 rgba(33, 117, 155, 0.05);
	}
	12.5% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.05), 0 -20px rgba(33, 117, 155, 0.925), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.8), 20px 0 rgba(33, 117, 155, 0.675), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.55), 0 20px rgba(33, 117, 155, 0.425), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.3), -20px 0 rgba(33, 117, 155, 0.175);
	}
	25% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.175), 0 -20px rgba(33, 117, 155, 0.05), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.925), 20px 0 rgba(33, 117, 155, 0.8), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.675), 0 20px rgba(33, 117, 155, 0.55), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.425), -20px 0 rgba(33, 117, 155, 0.3);
	}
	37.5% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.3), 0 -20px rgba(33, 117, 155, 0.175), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.05), 20px 0 rgba(33, 117, 155, 0.925), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.8), 0 20px rgba(33, 117, 155, 0.675), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.55), -20px 0 rgba(33, 117, 155, 0.425);
	}
	50% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.425), 0 -20px rgba(33, 117, 155, 0.3), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.175), 20px 0 rgba(33, 117, 155, 0.05), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.925), 0 20px rgba(33, 117, 155, 0.8), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.675), -20px 0 rgba(33, 117, 155, 0.55);
	}
	62.5% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.55), 0 -20px rgba(33, 117, 155, 0.425), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.3), 20px 0 rgba(33, 117, 155, 0.175), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.05), 0 20px rgba(33, 117, 155, 0.925), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.8), -20px 0 rgba(33, 117, 155, 0.675);
	}
	75% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.675), 0 -20px rgba(33, 117, 155, 0.55), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.425), 20px 0 rgba(33, 117, 155, 0.3), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.175), 0 20px rgba(33, 117, 155, 0.05), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.925), -20px 0 rgba(33, 117, 155, 0.8);
	}
	87.5% {
		box-shadow: -14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.8), 0 -20px rgba(33, 117, 155, 0.675), 14.1422712488px -14.1422712488px rgba(33, 117, 155, 0.55), 20px 0 rgba(33, 117, 155, 0.425), 14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.3), 0 20px rgba(33, 117, 155, 0.175), -14.1422712488px 14.1422712488px rgba(33, 117, 155, 0.05), -20px 0 rgba(33, 117, 155, 0.925);
	}
}

/*--------------------------
IMAGE COMPARISON
--------------------------*/

/* V2 - PP DEVICE */ 

.fl-module-pp-devices .pp-device-media {
	border-width: 0 1px 1px;
	border-style: solid;
	border-color: var(--secondary);	
	border-radius: 0 0 10px 10px;
}
.fl-module-pp-devices[data-node] .pp-image-fit .pp-device-media-screen figure img {
	object-position: top;
}

:is(.wea-before, .wea-after) .fl-module-content {
	text-align: center;
}
.wea-before .fl-module-content::before {
	content: "Before";
}
.wea-after .fl-module-content::before {
	content: "After";
}
:is(.wea-before, .wea-after) .fl-module-content::before {
	display: inline-block;
	margin-bottom: 20px;
	line-height: 1;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
	:is(.wea-before, .wea-after) .fl-module-content::before {
		margin-bottom: 15px;
		padding: 8px 12px;
		font-size: 12px;
	}
}
@media (max-width: 768px) {
	:is(.wea-before, .wea-after) .fl-module-content::before {
		margin-bottom: 10px;
		padding: 5px 8px;
		font-size: 11px;
	}
}

/* V1 - PP IMAGE COMPARISON */ 

.fl-module-pp-image-comparison .fl-module-content {
	border-radius: 10px;
	overflow: hidden;
}
.fl-module-pp-image-comparison .twentytwenty-container img {
	height: inherit;
}
.single-project .fl-module-pp-image-comparison .twentytwenty-container img {
	object-position: top;
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.fl-module-pp-image-comparison .fl-module-content {
		border-radius: 5px;
	}
}

/*--------------------------
GRAVITY FORMS
--------------------------*/

html .gform_wrapper.gravity-theme .gform_fields {
	grid-row-gap: 1em;
}
html .gform_wrapper.gravity-theme .gfield_label {
	margin-bottom: 0;
}
html .gform_wrapper.gravity-theme input[type=color], 
html .gform_wrapper.gravity-theme input[type=date], 
html .gform_wrapper.gravity-theme input[type=datetime-local], 
html .gform_wrapper.gravity-theme input[type=datetime], 
html .gform_wrapper.gravity-theme input[type=email], 
html .gform_wrapper.gravity-theme input[type=month], 
html .gform_wrapper.gravity-theme input[type=number], 
html .gform_wrapper.gravity-theme input[type=password], 
html .gform_wrapper.gravity-theme input[type=search], 
html .gform_wrapper.gravity-theme input[type=tel],
html .gform_wrapper.gravity-theme input[type=text] , 
html .gform_wrapper.gravity-theme input[type=time], 
html .gform_wrapper.gravity-theme input[type=url], 
html .gform_wrapper.gravity-theme input[type=week], 
html .gform_wrapper.gravity-theme select, 
html .gform_wrapper.gravity-theme textarea {
	padding: .3em 1em;
}
.wea-bt-margin-t .gform_wrapper.gravity-theme .gform_footer, 
.wea-bt-margin-t .gform_wrapper.gravity-theme .gform_page_footer {
	margin-top: 2.5em;
}

/* VALIDATION */

html .gform_wrapper.gravity-theme .gfield_required {
	color: var(--error);
}
html .gform_wrapper.gravity-theme .gform_validation_errors {
	background: none;
	box-shadow: unset;
}
html .gform_wrapper.gravity-theme .gform_validation_errors:focus {
	outline: unset;
}
html .gform_wrapper.gravity-theme .gform_validation_errors > h2 {
	font-family: var(--gp-font--bricolage-grotesque);
	font-size: 15px;
	text-wrap: unset;
}
html .gform_wrapper.gravity-theme .gfield_validation_message, 
html .gform_wrapper.gravity-theme .validation_message, 
html .pp-gf-content .gform_wrapper .gfield .gfield_description.validation_message {
	background: none;
	padding: 4px 0;
	border: none;
}
html .gform_wrapper.gravity-theme .gfield_error .gfield_repeater_cell label, 
html .gform_wrapper.gravity-theme .gfield_error label, 
html .gform_wrapper.gravity-theme .gfield_error legend, 
html .gform_wrapper.gravity-theme .gfield_validation_message, 
html .gform_wrapper.gravity-theme .validation_message, 
html .gform_wrapper.gravity-theme [aria-invalid=true]+label, 
html .gform_wrapper.gravity-theme label+[aria-invalid=true] {
	color: var(--error);
}
[data-node] .pp-gf-content .gform_wrapper .gfield_error input:not([type='radio']):not([type='checkbox']):not([type='submit']):not([type='button']):not([type='image']):not([type='file']), 
[data-node] .pp-gf-content .gform_wrapper .gfield_error .ginput_container select, 
[data-node] .pp-gf-content .gform_wrapper .gfield_error .ginput_container textarea {
	border-color: var(--secondary);
}


/*/////////////////////////////////////////////////////
5. PROJECTS
/////////////////////////////////////////////////////*/

/* --------------------------
SINGLE
-------------------------- */

.wea-post-terms-list > div {
	display: flex;
	gap: .75em;
	flex-wrap: wrap;
}
.wea-post-terms-list > div > span {
	display: inline-flex;
}
.wea-post-terms-list > div > span a {
	padding: .4em 1em;
	background-color: var(--secondary-light);
	font-weight: 400;
	text-decoration: none;
	/* white-space: nowrap; */
	color: var(--secondary-dark);
	border-radius: 50px;
}
.wea-post-terms-list > div > span a:hover,
.wea-post-terms-list > div > span a:focus  {
	background-color: var(--coral);
	color: white;
}


/*/////////////////////////////////////////////////////
6. INSIGHTS (BLOG)
/////////////////////////////////////////////////////*/

/* --------------------------
SINGLE
-------------------------- */

.entry-content:not(:first-child), 
.entry-summary:not(:first-child), 
.page-content:not(:first-child) {
	margin-top: 0;
}

.fl-theme-builder-singular-blog-single .site-content h2 {
	/* Fake H4 */
	font-size: clamp(1.125rem, 1.4vw + 1rem, 2.25rem); 
}
.fl-theme-builder-singular-blog-single .site-content h3 {
	/* Fake H5 */
	font-size: clamp(1rem, 1.2vw + 0.85rem, 2rem);
	font-weight: 300;
}
.fl-theme-builder-singular-blog-single .wea-meta-cat p, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat p {
	display: flex; 
	justify-content: center;
	gap: 2em;
}
.fl-theme-builder-singular-blog-single .wea-meta-cat a, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat a {
	position: relative;
	padding-bottom: .2rem;
	text-decoration: none;
	color: var(--coral);
}
.fl-theme-builder-singular-blog-single .wea-meta-cat a:hover, 
.fl-theme-builder-singular-blog-single .wea-meta-cat a:focus, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat a:hover, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat a:focus {
	color: var(--primary);
}
.fl-theme-builder-singular-blog-single .wea-meta-cat a::after, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat a::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	border-bottom: 1px solid var(--coral);
	transition: var(--transition-1);
}
.fl-theme-builder-singular-blog-single .wea-meta-cat a:hover::after, 
.fl-theme-builder-archive-blog-archive .wea-meta-cat a:hover::after {
	border-color: var(--primary);
	transform: scaleX(0);
}


/*/////////////////////////////////////////////////////
7. SEARCH RESULTS
/////////////////////////////////////////////////////*/

.search-results [data-node] .pp-content-post .pp-post-image {
	width: 20%;
}
.search-results [data-node] .pp-content-post .pp-content-body {
	width: 80%;
}
.relevanssi-query-term {
	position: relative;
	z-index: 0;
	padding-bottom: .25em;
}
.relevanssi-query-term::after {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	right:0;
	bottom: 0;
	left: 0;
	border-bottom: 2px solid var(--green);
}

/* --- RESPONSIVE --- */

@media (max-width: 768px) {
	.search-results .rs-posts.rs-grid .pp-content-post {
		margin-bottom: 0;
	}
	.search-results [data-node] .pp-content-post .pp-post-image {
		max-width: 160px;
		width: auto;
	}
	.search-results [data-node] .pp-content-post .pp-content-body {
		width: 100%;
		padding-left: 0;
	}
}


/*/////////////////////////////////////////////////////
8. MISC
/////////////////////////////////////////////////////*/

.fl-builder-block-thumbnail {
	display: none;
}

/* --- responsive embed --- */
.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.embed-container iframe, .embed-container object, .embed-container embed, .embed-container video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* --------------------------
GLOBAL COLOR PALETTE
-------------------------- */

/* TEMP */ 

html .gp-color-box {
	height: 190px; /* Remove */
	height: auto; /* Temp */
	padding: 40px 20px; /* Updt - previously 20px */
}
html .gp-color-info-alt {
	gap: .6em; /* Updt - Previously 12px */
}
html .gpbi-color-label {
	font-size: 130%; /* Remove */
	font-size: inherit; /* Temp */
}
html .gp-color-var-alt, 
html .gp-color-hex-alt {
	padding: 0;
	font-size: 80%; /* Previously 0.9em */
}


/*/////////////////////////////////////////////////////
9. STYLES TEMPLATE
/////////////////////////////////////////////////////*/

[class*="av-demo-font-"] {
	font-size: 24px;
}
[class*="av-demo-font-"] h2, 
[class*="av-demo-font-"] h3 {
	margin-bottom: .75em; 
}
.av-demo-font-1, 
.av-demo-font-1 h2, 
.av-demo-font-1 h3 {
	font-family: var(--gp-font--recife-display); 
}
.av-demo-font-2, 
.av-demo-font-2 h2, 
.av-demo-font-2 h3 {
	font-family: var(--gp-font--bricolage-grotesque); 
}