/*
	Theme Name: KIOO Project V2
	Theme URI: kiooproject.org
	Description: WP Theme for KIOO Project based on the Charity Foundation Wordpress Theme
	Version: 2.029
	Author: Squatch Creative
	Author URI: https://squatchcreative.com

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/


:root {
	--kioo-blue: #0000ff;
	--kioo-purple: #3d0087;
	--kioo-green: #5cd85a;
	--kioo-geranium: #f1185c;
	--kioo-yellow: #dbfd23;
	--kioo-light-gray: #a3a3a3;
	--kioo-dark-gray: #3e3e3e;
	
	--row:1366px;
	--transition:200ms ease all;
	--header:104px;
	--header-scrolled:88px;
	
	--caveat: "Caveat Brush", cursive;
}

body {
	margin:0px; 
	padding:0px;
	font-family:"Poppins", sans-serif; 
	background:#fff;
	color:#000;
} 

/*WP CORE
=========================*/

*,:after,:before{-moz-box-sizing:border-box;box-sizing:border-box;-webkit-font-smoothing:antialiased;font-smoothing:antialiased;text-rendering:optimizeLegibility}.wp-caption{background:#FFF;border:1px solid #F0F0F0;max-width:96%;padding:5px 3px 10px;text-align:center}.wp-caption.alignleft,.wp-caption.alignnone{margin:5px 20px 20px 0}.wp-caption.alignright{margin:5px 0 20px 20px}.wp-caption img{border:0;height:auto;margin:0;max-width:98.5%;padding:0;width:auto}.gallery-caption,.wp-caption .wp-caption-text{font-size:11px;line-height:17px;margin:0;padding:0 4px 5px}

.alignfull, .container.alignfull {
	width:100%;
	max-width:100%;
	margin:0;
}

.alignwide,
.container.alignwide {
	width: var(--row);
	max-width: calc(100% - 2rem);
	position: relative;
	left: 0;
	margin:0 auto;
}

article > *:not(.alignwide, .alignfull) {
    width: 968px;
    margin: 0 auto;
	max-width: calc(100% - 2rem);
}

.wp-block-image {
	margin-bottom:0;
}

.wp-block-image img {
    max-width: 100%;
    display: block;	
}

.wp-block-columns {
    margin-bottom: 0;
}

::selection {
    background-color:#000;
    color: #ffffff;
}

html {
	font-size:18px;
}


div { 
	display:block; 
	position:relative; 
	margin:0px; 
	padding:0px; 
}
.body-wrapper {
	max-width:100%;
	width:100%; 
	overflow:clip; 
}
.container {
	float:none; 
	clear:both; 
	margin:0px auto; 
	padding:0px 1rem;
	width:100%; 
	height:auto; 
	max-width:unset;
}
section[id*='squatch-block'] .container {
	margin: 0;
	padding: 0;
}
.row {
	margin:0px auto; 
	padding:0px; 
	width:100%; 
	height:auto; 
	display:flex;
	flex-flow:row wrap;
	justify-content:flex-start;
	align-items:stretch;
	max-width:var(--row); 
}
div[class*='span'] {
	margin:0px; 
	padding:0;
	height:auto;
}
.span5 { width:5%; }
.span10 { width:10%; }
.span15 { width:15%; }
.span20 { width:20%; }
.span25 { width:25%; }
.span30 { width:30%; }
.span33 { width:33%; }
.span35 { width:35%; }
.span40 { width:40%; }
.span45 { width:45%; }
.span50 { width:50%; }
.span55 { width:55%; }
.span60 { width:60%; }
.span65 { width:65%; }
.span66 { width:66%; }
.span70 { width:70%; }
.span75 { width:75%; }
.span80 { width:80%; }
.span85 { width:85%; }
.span90 { width:90%; }
.span100 { width:100%; }

h1 {
	font-size:3.5rem;
	line-height:110%;
	margin:1.5rem 0;
	font-weight: 900;
}

h2 {
	font-size:2.75rem;
	line-height:110%;
	margin:1.5rem 0;
	font-weight: 900;
}

h3 {
	font-size:1.75rem;
	line-height:115%;
	margin:1.5rem 0;
	font-weight: 900;
}

h4 {
	font-size: 1.5rem;
	line-height: 135%;
	margin: 1rem 0;
	font-weight: 900;
}

p {
	font-size:1rem;
	line-height:160%;
	margin:1.1rem 0;
	padding:0;
}
article ul li {
    font-size: 1rem;
    line-height: 150%;
}
a {
	transition: var(--transition); 
	text-decoration:none;
	color:var(--kioo-blue);
}
a:hover {
	color:var(--kioo-green);
	text-decoration:none;
}
a.large-link {
	display:block;
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:5;
}
image-overlay {
	display:block;
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:2;
	background:rgba(0,0,0,0.5);
}
figure {
	display:block;
	position:relative;
	margin:0 auto;
}
figure img, a img {
	display:block;
	width:100%;
	height:auto;
}
img {
	display:inline-block; 
	max-width:100%; 
	height:auto; 
	border:0px;
	padding:0px;
	margin:0px;
}
svg {
	display:block;
	position:relative;
	width:100%;
	height:auto;
	max-width:100%;
}
small {font-size:70%;}
.bold, strong {font-weight:bold;}
.italic, em { font-style:italic;}
.hidden { display:none; }
.clear {	clear:both; float:none; display:block; position:relative; }
.text-center { text-align:center; }
.text-right { text-align:right; } 
.text-balance { text-wrap:balance; }
.no-gap { margin:0px auto !important; padding:0px !important; } 
hr.wp-block-separator {
    display: block;
    clear: both;
    position: relative;
    max-width: 100%;
    border: 0px;
    height: 1px;
    margin: 0 auto;
}

/* FORMS & BUTTONS
============================== */

form-fields {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 1.65rem;
}

form-fields span {
	display: block;
	width: 100%;
}

input, textarea, select {
   	box-sizing: border-box;
	display:block;
	max-width:100%;
	width:100%;
	height:auto;
	padding:0.888889rem 1.75rem;
	margin:0; 
	border-radius:4px;
	font-size:1rem;
	line-height:100%;	
	border:1px #000 solid; 
	color:#000;
}

a.button, 
input[type="submit"], 
button, 
.wp-block-button a, 
.theme-btn {
	display: inline-flex;
	position: relative;
	padding: 0.89999rem 2.2rem;
	width: auto;
	font-size: 0.888889rem;
	font-weight: bold;
	line-height: 100%;
	border: 0px;
	color: white;
	transition: var(--transition);
	background: var(--kioo-blue);
	height: auto;
	border-radius: 100px;
	cursor:pointer;
}

a.button:hover, 
button:hover,
input[type="submit"]:hover,
.wp-block-button a:hover,
.theme-btn:hover {
	background:var(--kioo-green);
	color:white;
}

.button.green-button {
	background:var(--kioo-green);
}

.button.green-button:hover {
	background:var(--kioo-geranium);
}

.theme-btn.minimal-btn {
	border-color: var(--kioo-blue);
	color: var(--kioo-blue);
}

.theme-btn.minimal-btn:hover {
	border-color: var(--kioo-green);
	color: var(--kioo-green);
	background: transparent;
}

.anchor-header {
	scroll-margin-top: var(--header);
}

ul.wp-block-list {
	list-style: disc;
	padding: 0 0 0 40px;
	display: flex;
	flex-flow: column;
	gap: 1rem;
}

ul.wp-block-list li {
	list-style: disc;
}

ul.wp-block-list.legend-list {
	position: sticky;
	top: var(--header);
	text-wrap: balance;
	display: flex;
	flex-flow: column;
	gap: 0.777778rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

ul.wp-block-list.legend-list li {
	padding-left: 28px;
	position: relative;
	line-height: 115%;
	list-style:none;
}

ul.wp-block-list.legend-list li:before {
	content: "\f192";
	font-family: "Font Awesome 6 Free";
	font-weight: 900; /* 900 = solid, 400 = regular */
	display: inline-block;
	position: absolute;
	top: 1px;
	left: 0;
	font-size: 0.777778rem;
}

ul.wp-block-list.legend-list li a {
	color: #3a3a3a;
	font-size: 0.888889rem;
}

ul.legend-list li:nth-child(5n+1)::before {
	color: var(--kioo-green);
}

ul.legend-list li:nth-child(5n+2)::before {
	color: var(--kioo-blue);
}

ul.legend-list li:nth-child(5n+3)::before {
	color: var(--kioo-purple);
}

ul.legend-list li:nth-child(5n+4)::before {
	color: var(--kioo-geranium);
}

ul.legend-list li:nth-child(5n)::before {
	color: var(--kioo-yellow);
}

.wp-block-button.is-style-file-style {
	flex: 1 0 33.3333%;
}

.wp-block-button.is-style-newsletter-style {
	flex: 1 0 100%;
}

.wp-block-button.is-style-file-style a.wp-block-button__link,
.wp-block-button.is-style-newsletter-style a.wp-block-button__link {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	line-height: 120%;
	height: 100%;
	margin: 0;
	justify-content: center;
	text-align: center;
}

.wp-block-button.is-style-file-style a.wp-block-button__link:hover,
.wp-block-button.is-style-newsletter-style a.wp-block-button__link:hover {
	border-color:var(--wp--preset--color--red);
}

.wp-block-button.is-style-file-style a.wp-block-button__link:before,
.wp-block-button.is-style-newsletter-style a.wp-block-button__link:before {
	content: '';
	background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"%3E%3C!--!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc.--%3E%3Cpath d="M64 464l48 0 0 48-48 0c-35.3 0-64-28.7-64-64L0 64C0 28.7 28.7 0 64 0L229.5 0c17 0 33.3 6.7 45.3 18.7l90.5 90.5c12 12 18.7 28.3 18.7 45.3L384 304l-48 0 0-144-80 0c-17.7 0-32-14.3-32-32l0-80L64 48c-8.8 0-16 7.2-16 16l0 384c0 8.8 7.2 16 16 16zM176 352l32 0c30.9 0 56 25.1 56 56s-25.1 56-56 56l-16 0 0 32c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-48 0-80c0-8.8 7.2-16 16-16zm32 80c13.3 0 24-10.7 24-24s-10.7-24-24-24l-16 0 0 48 16 0zm96-80l32 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-32 0c-8.8 0-16-7.2-16-16l0-128c0-8.8 7.2-16 16-16zm32 128c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-16 0 0 96 16 0zm80-112c0-8.8 7.2-16 16-16l48 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0 0 32 32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0 0 48c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-64 0-64z" fill="white" /%3E%3C/svg%3E');
	display: block;
	width: 38px;
	height: 40px;
	flex:0 0 38px;
	background-size: 80% auto;
	background-position: center left;
	background-repeat: no-repeat;
}

.wp-block-button.is-style-newsletter-style a.wp-block-button__link:before {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' %3E%3C!--!Font Awesome Free 6.5.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--%3E%3Cpath d='M168 80c-13.3 0-24 10.7-24 24V408c0 8.4-1.4 16.5-4.1 24H440c13.3 0 24-10.7 24-24V104c0-13.3-10.7-24-24-24H168zM72 480c-39.8 0-72-32.2-72-72V112C0 98.7 10.7 88 24 88s24 10.7 24 24V408c0 13.3 10.7 24 24 24s24-10.7 24-24V104c0-39.8 32.2-72 72-72H440c39.8 0 72 32.2 72 72V408c0 39.8-32.2 72-72 72H72zM176 136c0-13.3 10.7-24 24-24h96c13.3 0 24 10.7 24 24v80c0 13.3-10.7 24-24 24H200c-13.3 0-24-10.7-24-24V136zm200-24h32c13.3 0 24 10.7 24 24s-10.7 24-24 24H376c-13.3 0-24-10.7-24-24s10.7-24 24-24zm0 80h32c13.3 0 24 10.7 24 24s-10.7 24-24 24H376c-13.3 0-24-10.7-24-24s10.7-24 24-24zM200 272H408c13.3 0 24 10.7 24 24s-10.7 24-24 24H200c-13.3 0-24-10.7-24-24s10.7-24 24-24zm0 80H408c13.3 0 24 10.7 24 24s-10.7 24-24 24H200c-13.3 0-24-10.7-24-24s10.7-24 24-24z' fill='white' /%3E%3C/svg%3E");
}

.wp-block-media-text>.wp-block-media-text__content {
	padding: 5rem 10%;
}









/* HEADER
================================*/

header {
	position: fixed;
	top: 0;
	z-index: 999;
}

.header {
    background: transparent;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    height: var(--header);
    transition: var(--transition);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
	z-index:999;
}

body.header-scrolled .header {
    background: black;
}

.header-spacer {
    width: 100%;
    height: var(--header);
}

body.home .header-spacer {
	height:0;
}

.header .row {
    justify-content: space-between;
    align-items: center;
	max-width:100%;
	gap:1rem;
}

figure.header-logo {
	width: 188px;
	height: 67px;
	max-width: 100%;
	margin: 0;
	z-index: 999;
	margin-right: auto;
}

body.header-scrolled figure.header-logo {
    overflow: hidden;
}

figure.header-logo a {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

body.header-scrolled .header {
    top: 0;
    height: var(--header-scrolled);
    background: black;
}

figure.header-logo svg path {
    fill: white;
    transition: var(--transition);
}

figure.header-logo:hover path:nth-of-type(1) {
  transition-delay: 0ms;
  fill: var(--kioo-blue);
}

figure.header-logo:hover path:nth-of-type(2) {
  transition-delay: 50ms;
  fill: var(--kioo-blue);
}

figure.header-logo:hover path:nth-of-type(3) {
  transition-delay: 100ms;
  fill: var(--kioo-blue);
}

figure.header-logo:hover path:nth-of-type(4) {
  transition-delay: 150ms;
  fill: var(--kioo-blue);
}

ul.menu {
	list-style:none; 
	margin:0px; 
	padding:0px;
	display:flex;
	position:relative;
	flex-flow:row wrap;
	gap:1rem;
}

ul.menu li {
	display: flex;
	position: relative;
	justify-content: center;
	align-items: center;
}

ul.menu li a {
    display: flex;
    align-items: center;
    height: var(--header-scrolled);
    width: auto;
    margin: 0px;
    padding: 0.8888889rem 0.7777778rem;
    color: white;
    text-decoration: none;
    font-size: 0.888889rem;
	font-weight: bold;
    line-height: 100%;
}

ul.menu li a:hover {
	color:var(--kioo-green);
}

ul.menu li.header-button > a {
	background: var(--kioo-blue);
	padding-left: 2.2rem;
	padding-right: 2.2rem;
	height: auto;
	border-radius: 100px;
}

ul.menu li.header-button > a:hover {
	background: var(--kioo-green);
	color:white;
}

.menu-toggle {
	display:none;
}

.header ul.sub-menu li {
	display:block; 
	float:none; 
	clear:both;
}
@media all and (min-width:1081px) {
	body.header-scrolled .header ul.sub-menu {
		box-shadow: 0px 2px 10px rgba(0,0,0,0.25);
	}
	.header ul.sub-menu {
		display: block;
		position: absolute;
		z-index: -1;
		background: #fff;
		top:calc(100% + 3rem);
		left: -4px;
		padding:0;
		margin: 0px;
		list-style: none;
		text-align: left;
		box-shadow: none;
		border-top: 4px var(--kioo-green) solid;
		transition:z-index 0s linear, opacity 90ms ease, pointer-events 0s linear, top 90ms ease;
		pointer-events: none;
		opacity: 0.0;
	}
	.header ul.menu li:hover > ul.sub-menu {
		opacity:1.0;
		pointer-events:auto;
		top:100%;
		z-index:100;
	}
	.header ul.sub-menu li a {
		width: 220px;
		color: black;
		height: auto;
		padding:1.1rem;
	}
	.header ul.sub-menu li:nth-of-type(odd) a {
		background: #f5f5f5;
	}
	.header ul.sub-menu li a:hover {		
		background-color:var(--kioo-green);
	}
}

.wp-block-cover.hero-title {
	padding: 5rem 1rem 1rem 1rem;
}

pre.wp-block-verse {
	font-family: 'Poppins';
	font-size: clamp(1.4rem, 3vw, 3rem);
	font-weight:700;
	line-height: 110%;
	text-wrap: balance;
	overflow: hidden;
	display: block;
}

.wp-block-pullquote blockquote p {
	font-family: 'Poppins';
	font-size: clamp(1.4rem, 3vw, 3rem);
	font-weight:700;
	line-height: 110%;
	text-wrap: balance;
	overflow: hidden;
	display:block;
}

























/* HERO CAROUSEL 
=============================== */

.hero-block video {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

ul.hero-slider-carousel {
    list-style: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
	background:black;
	z-index:2;
}

.has-video ul.hero-slider-carousel {
	background:transparent;
}

ul.hero-slider-carousel li {
    display: flex !important;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    position: relative;
    overflow: hidden;
    margin: 0;
	padding-top: var(--header);
}

.row.slider-content {
    z-index: 10;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    padding: 0 1rem;
    text-align: center;
}

.row.slider-content > * {
	opacity: 0.0;
    transform: translate(0,100px);
    transition: 1.25s cubic-bezier(0.4, 0.32, 0.18, 0.96) all;
}

.slick-active .row.slider-content > * {
    opacity: 1.0;
    transform: translate(0,0);
}

.slick-current.reset-animation .row.slider-content > * {
	transition:0ms linear all;
	opacity:0.0;
	transform: translate(0,100%);
	transition-delay:0ms !important;
}

.row.slider-content h1 {
    margin: 0;
	color: white;
	font-size: clamp(2rem, 6vw, 5rem);
	text-transform: uppercase;
    transition-delay: 700ms !important;
}

.row.slider-content p {
    max-width: 100%;
	color: white;
    text-wrap: balance;
	font-weight:700;
	margin:0 0 1.1111rem 0;
}

.row.slider-content p.description {
	transition-delay:1000ms !important;
}

.row.slider-content p.slider-button {
	transition-delay:1300ms !important;
}

ul.hero-slider-carousel img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
	z-index:1;
	transition: 0.25s .5s cubic-bezier(.23,1,.32,1) all;
}

ul.hero-slider-carousel li.slick-active img {
    transform: scale(1.2);
    transition:15s cubic-bezier(.23,1,.32,1) all;
}

.hero-slider-carousel image-overlay {
    opacity: 0.65;
}

ul.hero-slider-carousel .slick-current.reset-animation img {
	transition:0.000001ms linear all;
	transform: scale(1);
	transition-delay:0ms !important;
}

ul.hero-slider-carousel .slick-track {
    display: flex;
}

ul.hero-slider-carousel .slick-track .slick-slide {
    display: flex;
}

.hero-cover h1 {
    font-size: 13rem;
    font-weight: 700;
    line-height: 110%;
    color: white;
    position: relative;
	animation: zoomup 5s ease infinite;
}

@keyframes zoomup {
  0%,
  20%,
  100% {
    filter: blur(0);
    color: transparent;
    text-shadow: none;
  }
  10% {
    color: #ffb703;
    filter: blur(0.5px);
    text-shadow: 0 0 10px #ffb703, 0 0 20px #ffb703, 0 0 30px #ffb703,
      0 0 40px #ffb703, 0 0 50px #ffb703, 0 0 60px #ffb703;
  }
}

button.slick-arrow {
    background: transparent;
    padding: 0;
    width: 50px;
    height: 100%;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    height: 100%;
	cursor:pointer;
	transition:var(--transition);
}

button.slick-arrow:before {
    display: none;
}

button.slick-arrow svg {
    width: 24px;
    height: 24px;
    object-fit: contain;
    fill: #ffffff;
}

button.slick-prev.slick-arrow {
    left: -100px;
}

button.slick-next.slick-arrow {
    right: -100px;
}

ul.slick-dots {
    list-style: none;
    margin: 2rem 0 0 0;
    padding: 0;
    border: 0;
    display: flex;
    flex-flow: row;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
}

ul.slick-dots li {
    border: 0;
    width: 12px;
    height: 12px;
    overflow: hidden;
    padding: 0;
    font-size: 0px;
    color: transparent;
    border-radius: 100px;
    position: relative;
    margin: 0;
	transition:var(--transition);
}

ul.slick-dots li button {
    border: 0;
    background: #FFFFFF;
    padding: 0;
    font-size: 0px;
    color: transparent;
    position: absolute;
    top: 0;
    left: 0;
    width: 12px;
    height: 12px;
	padding:0;
	transition:var(--transition);
	cursor:pointer;
}

ul.slick-dots li button:before {
    display: none;
}

ul.slick-dots li.slick-active,
ul.slick-dots li.slick-active button {
    width:20px;
}

.hero-slider-carousel ul.slick-dots {
    position: absolute;
    bottom: 2rem;
    left: 0;
    width: 100%;
    margin: 0;
    opacity: 1;
}

.hero-slider-carousel button.slick-prev.slick-arrow {
    left: 0;
    z-index: 15;
}

.hero-slider-carousel button.slick-next.slick-arrow {
    right: 0;
    z-index: 15;
}









/* MULTI PICTURE SUMMARY
=============================== */
.about-us-section:not(.about-us-two, .about-us-three) {
	padding-top: 120px;
}

.about-main-img img {
	width: 100%;
	max-width: 570px;
}
.section-title h2 {
	margin: 0;
}
.about_left_content .section-title span {
	color: #3a3a3a;
}
.section-title>span i {
	color: var(--kioo-blue);
}

.about_left_content p {
	margin-top: 12px;
}

.about-us-section .about-shots .our-experience {
	bottom: 24px;
	border-radius: 50%;
	width: 216px;
	height: 216px;
	background:  var(--kioo-blue);
}

.about_left_content .section-title h1 span, 
.checked-list li::before {
	color: var(--kioo-blue);
}

.about-us-two .about_left_content {
	margin-top: 0;
}

.about-us-two .about-img {
    flex: 1;
}

.about-us-section .about-shots .about-top-img {
	z-index: 4;
}
.checked-list li {
	color: black;
}
.checked-list li::before {
	font-weight: 900;
}

@media all and (min-width:768px) {
	.about-us-section.about-us-three .about-top-img {
		top: unset;
		bottom: 0;
		left: 0;
		transform: translate(0,0);
	}

	.about-us-section.about-us-three .about-main-img {
		display: flex;
		justify-content: flex-end;
		align-items: flex-end;
		transform: translate(0, -120px);
	}
}





/* CARD BLOCK
============================ */

.single-service-item {
	height: 100%;
	display: flex;
	flex-flow: column;
	justify-content: flex-start;
	align-items: flex-start;
}

.single-service-item .icon {
	width: 128px;
	height: 128px;
	max-width: 100%;
	margin-bottom: 0;
}
.single-service-item .icon svg,
.single-service-item .icon img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: contain;
}

.single-service-item .icon svg {
	fill: var(--highlight);
}

.single-service-item::before {
	border: 30px solid #d3d3d3;
	background: transparent;
}

.single-service-item:hover::before {
	border-color: var(--highlight);
	background: transparent;
}

.service-details {
	flex: 1;
	display: flex;
	flex-flow: column;
	gap: 1rem;
}

.single-service-item .service-details h2 {
	margin-bottom: 0;
	letter-spacing: 0;
	font-size: 2rem;
	transition: var(--transition);
}

.single-service-item .service-details h2:hover {
	color:black;
}
.single-service-item:hover .service-details>a,
.single-service-item:hover .service-details>a i {
	color: var(--highlight);
	border-color: var(--highlight);
}
.single-service-item:hover .service-details>a i {
	transform: rotate(45deg);
}

.single-service-item .service-details>a {
	color: #686868;
	margin-top: auto;
}


/* TILE BLOCK
================================ */

.tile-block {
	position: relative;
	display: flex;
	flex-flow: column;
	justify-content: flex-end;
	align-items: flex-start;
	padding: 2rem;
	height: 100%;
	min-height: 300px;
	width: 100%;
	overflow:clip;
	aspect-ratio:1/1;
}

.tile-block image-overlay {
	opacity: 0.55;
	mix-blend-mode: multiply;
}

.tile-block image-overlay.overlay2 {
	/*
	opacity: 0.85;
	mix-blend-mode: unset;
	*/
}

.tile-block figure, .tile-block figure img {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 1.25s cubic-bezier(0.4, 0.32, 0.18, 0.96) all;
}

.tile-block figure {
	overflow:hidden;
}

.tile-block:hover figure img {
	transform:scale(1.2);
}



.tile-details {
	display: flex;
	flex-flow: column;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 1rem;
	position: relative;
	z-index: 3;
}

.tile-details * {
	margin: 0;
	color: white;
}

.tile-details h3 {
	font-size: 2rem;
	line-height: 120%;
}

.tile-details p {
	font-size: 0.88889rem;
}




/* SCROLLING PHOTOS
================================== */
.scrolling-photos {
    width: 100%;
    overflow: clip;
    position: relative;
	height:500px;
}

.scrolling-photos > figure {
    display: flex;
    animation: scroll 30s linear infinite;
    margin: 0;
	height:500px;
	width:165vw;
}

.scrolling-photos > figure img {
    display: block;
	flex: 1;
	min-width: calc(100% / var(--count));
	object-fit: cover;
	height: 500px;
}

.scrolling-photos image-overlay {
	opacity: 0.55;
	mix-blend-mode: multiply;
}

.scrolling-photos image-overlay.overlay2 {
	opacity: 0.45;
	mix-blend-mode: unset;
}

.scrolling-photos.scroll-style > figure {
	animation: scroll linear forwards;
	animation-timeline: view();
	animation-range-start: 0%;
	animation-range-end: 200%;
}

@keyframes scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}

@keyframes scrollY {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-50%);
    }
}



/* TEAM BLOCK
==================================== */

.team-block {
	display: flex;
	flex-flow:row wrap;
	justify-content: center;
	align-items:stretch;
	--gap: 2.5rem;
	--columns: 4;
	gap: var(--gap);
}

.team-profile {
	width: calc((100% / var(--columns)) - var(--gap) + (var(--gap) / var(--columns)));
	display: flex;
	flex-flow: column;
	justify-content: flex-start;
	align-items: center;
	text-align: center;
	gap: 0.6rem;
}

.team-profile-info {
	display: flex;
	flex-flow: column;
	justify-content: flex-start;
	align-items: center;
	text-align: center;
	gap: 0.6rem;
}

.team-profile profile-email,
.team-profile ul.social,
.team-profile profile-profile {
	display: none;
}

.team-profile figure {
	display: block;
	margin: 0;
	width: 100%;
	max-width:240px;
	height: auto;
	aspect-ratio: 1/1;
	border-radius: 50%;
	overflow: clip;
}

.team-profile figure img {
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.team-profile h3 {
	margin: 0;
}

.team-profile profile-title {
	display: block;
	font-size: 0.77778rem;
	line-height: 100%;
	text-wrap: balance;
	font-weight: 700;
	color: var(--kioo-dark-gray);
}

.fancybox-slide--html {
	text-align: center;
}

.fancybox-navigation .fancybox-button {
	position: fixed;
}

.team-profile.pop-out-card.fancybox-content {
	width: 968px;
	max-width: 100%;
	height: auto;
	display: inline-flex;
	margin: 0 auto;
	flex-flow: row wrap;
	align-items: flex-start;
	text-align: left;
	padding: 2.5rem;
	gap: 4rem;
}

.pop-out-card .team-profile-info {
	align-items: flex-start;
	text-align: left;
	flex: 1;
}

.team-profile.pop-out-card .team-profile ul.social {	
	margin: 0;
}

.team-profile.pop-out-card profile-email {
	display: block;
	font-size: 0.88889rem;
	line-height: 100%;
	font-weight:bold;
}

.team-profile.pop-out-card profile-profile {
	display: block;
	order: 2;
}

.team-profile.pop-out-card.fancybox-content a.large-link {
	display: none;
	pointer-events: none;
}

















/* SHOP
================================ */

.header-cart {
    display: flex;
	z-index:999;
}

.header-cart a {
    display: flex;
    width: 48px;
    align-items: center;
    justify-content: center;
}

.header-cart a svg {
	width: 38px;
	height: auto;
    fill: white;
    transition: var(--transition);
}

.header-cart a span {
    display: inline-flex;
    position: absolute;
    top: -14px;
	right: 7px;
    font-size: 12px;
    line-height: 100%;
    color: white;
    background: black;
	border: 2px solid var(--kioo-green);
    font-weight: 700;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.header-cart a:hover svg {
    fill: var(--kioo-green);
}

.woocommerce-page.single-product main > article {
	display: flex;
	flex-flow: column;
	gap: 50px;
}

.woocommerce .quantity .qty {
	width: 80px;
	padding: 8px 8px;
	height: 52px;
}

.woocommerce div.product form.cart .button {
	border-radius: 100px;
	height: 52px;
	background: var(--kioo-blue);
	padding: 16px 32px;
}

.woocommerce div.product form.cart .button:hover {
	background: var(--kioo-green);
}

.product_meta {
	font-size: 0.77778rem;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) ul.products li.product .price, .woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product p.price, .woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product span.price {
	color: var(--kioo-green);
	font-weight: 700;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button {
	background: var(--kioo-blue);
	border-radius: 100px;
	color: white;
}

.woocommerce ul.products li.product a.woocommerce-loop-product__link {
	color: black;
}

.woocommerce ul.products li.product .button {
    margin-top: 0;
    font-size: 0.777778rem;

}

.woocommerce ul.products li.product a img,
.wc-block-components-product-image img {
	aspect-ratio: 1/1;
	object-fit: cover;
}

.wp-block-button.wc-block-components-product-button .wc-block-components-product-button__button {
	background: var(--kioo-blue);
}

.wp-block-button.wc-block-components-product-button .wc-block-components-product-button__button:hover {
	background: var(--kioo-green);
}

.woocommerce [class^="col-"], 
.woocommerce [class*=" col-"] {
	max-width: 100%;
}

.woocommerce form .form-row span {
	width: 100%;
}

span.woocommerce-input-wrapper {
	width: 100%;
}

input[type=checkbox], 
input[type=radio] {
	width: 24px;
	height: 24px;
}

li:has(input[type="radio"]), 
li:has(input[type="checkbox"]) {
	display: flex;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit.alt, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.alt, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit.alt, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt {
	background: var(--kioo-blue);
	color:white;
}

.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit:hover, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button:hover, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button:hover, .woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button:hover, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit:hover, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button:hover, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button:hover, :where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button:hover {
  background: var(--kioo-green);
  color:white;
}









/* CORE
========================== */

.wp-block-cover.is-style-hero-banner {
	transform: translate(0,-50%);
	z-index: 10;
	box-shadow: 0px 0px 26px 2px rgba(0,0,0,0.45);
}

.wp-block-cover.is-style-hero-banner form {
	display: flex;
	flex-flow: row;
	justify-content: flex-start;
	align-items: stretch;
	gap: 1rem;
}

.wp-block-cover.is-style-hero-banner form input:not([type="submit"]) {
	background: #FFFFFF21;
	color: white;
	border-color: #00000040;
}

.wp-block-cover.is-style-hero-banner form input::placeholder {
	color:#a3a3a3;
}

.wp-block-cover.is-style-parallax-scroll {
	text-wrap: balance;
}

.wp-block-cover.is-style-parallax-scroll img.wp-block-cover__image-background {
	height: 200%;
	animation: scrollY linear forwards;
	animation-timeline: view();
	animation-range-start: 0%;
	animation-range-end: exit;
}

blockquote.wp-block-quote {
	display: flex;
	flex-flow: column;
	gap: 2rem;
}

blockquote.wp-block-quote * {
	margin: 0;
	text-align: center;
	text-wrap: balance;
}

blockquote.wp-block-quote p {
	font-size: clamp(1.4rem,2.3vw,1.8rem);
	line-height: 150%;
	font-weight: 700;
}

blockquote.wp-block-quote cite {
	display: block;
	font-size: 0.777778rem;
	font-style: normal;
	line-height: 100%;
	letter-spacing: 1px;
	font-weight: 700;
}

blockquote.wp-block-quote:before {
	display: block;
	content: '\f10e';
	font-family: 'Font Awesome 6 Free';
	font-weight: 700;
	margin: 0 auto;
	font-size: 48px;
	line-height: 50%;
	overflow: visible;
}







/* POSTS
===================================== */

ul.pagination {
    padding: 1.25rem 0;
    margin:1.25rem auto;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    list-style: none;
    gap: 0.75rem;
}

ul.pagination li a {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: center;
    line-height: 100%;
    gap: 0.65rem;
}

ul.pagination li a svg {
    width: 14px;
    height: auto;
}

li.next-link {
    margin-left: auto;
}

li.prev-link svg {
    transform: rotate(180deg);
}












/* FOOTER
================================ */

.footer {
	background: #7e7e7e;
	padding: 4rem 1rem;
}

footer .row {
	z-index: 10;
}

img.bg-image {
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	left: 0;
	filter: grayscale(0.5);
}

footer image-overlay {
	mix-blend-mode: multiply;
	background: #3e3e3e;
	opacity: 1;
}

footer img.bg-image {
	opacity: 0.2;
}



figure.footer-logo {
	width: 164px;
	margin: 0;
}

figure.footer-logo svg {
	fill: white;
}

p.site-info {
	color: #A4A4A4;
	font-size: 0.777778rem;
	line-height: 170%;
	margin: 1.5rem 0;
	text-wrap: balance;
}

p.site-info a {
	color: white;
}

ul.footer-contact {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 1.4444rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

ul.footer-contact li {
	display: flex;
	flex-flow: row;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 1rem;
	color: white;
	font-size: 0.77777778rem;
	line-height: 180%;
	font-weight: 500;
	letter-spacing: 1px;
}

ul.footer-contact li a {
	color: white;
}

ul.footer-contact li a:hover {
	color:#a3a3a3;
}

ul.footer-contact li i {
	font-size: 14px;
	display: block;
	margin: 7px 0 0 0;
}

ul.footer-contact li:nth-of-type(1) i {
	color: var(--kioo-geranium);
}

ul.footer-contact li:nth-of-type(2) i {
	color: var(--kioo-yellow);
}

ul.footer-contact li:nth-of-type(3) i {
	color: var(--kioo-green);
}

ul.social {
	display: flex;
	flex-flow: row;
	justify-content: flex-start;
	align-items: center;
	list-style: none;
	margin: 1.4rem 0;
	padding: 0;
	gap: 1.4rem;
}

ul.social li a {
	font-size: 1.77778rem;
	line-height: 100%;
}

ul.social li a:hover {
	
}

.has-text-align-center ~ ul.social {
	justify-content: center;
}

ul.social.footer-social {
	padding: 0 0 0 32px;
}

ul.footer-social.social li a {
	color: #a3a3a3;
}

ul.footer-social.social li a:hover {
	color: white;
}

footer h4 {
	color: #FFFFFF;
}

ul.partner-logos {
	display: flex;
	flex-flow: row;
	justify-content: center;
	align-items: center;
	list-style: none;
	margin: 0 0 40px 0;
	padding: 0;
	gap: 40px;
}
ul.partner-logos li {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

ul.partner-logos li img {
	display: block;
	object-fit: contain;
}
footer form {
	display: flex;
	flex-flow: row;
	justify-content: flex-start;
	align-items: stretch;
	gap: 1rem;
}

footer form input {
	background: #FFFFFF21;
	color: white;
}

.footer-bottom {
	background: white;
	padding: 1rem;
}
.footer-bottom .row {
	align-items: center;
	justify-content: space-between;
}

div[class*='span'].footer-meta {
	display: flex;
	flex-flow: row;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
}

p.copyright {
	margin: 0;
	font-size: 0.7777778rem;
	color: #5c5c5c;
}

nav.footer-nav ul.menu li a {
	font-size: 0.7777778rem;
	line-height: 140%;
	color: #5c5c5c;
	font-weight: 400;
	padding: 0;
	height: unset;
}

nav.footer-nav ul.menu {
	gap: 6px;
}

nav.footer-nav ul.menu li a:hover {
	color: var(--kioo-green);
}


.builtby {
	position: relative;
	max-width: 96px;
	padding: 0;
	margin: 0 0 0 auto;
	display: block;
	float: none;
	clear: both;
	z-index: 99;
	opacity: 0.45;
}

.builtby svg {
	display:block;
	width:100%;
	height:auto;
}

.builtby svg path {
	fill:#000000;
}

.builtby:hover {
	animation: shake .2s 1;
	opacity:1.0; 
}

@keyframes shake {
	0% { transform: translate(2px, 1px) rotate(0deg); }
	10% { transform: translate(-1px, -2px) rotate(-1deg); }
	20% { transform: translate(-3px, 0px) rotate(1deg); }
	30% { transform: translate(0px, 2px) rotate(0deg); }
	40% { transform: translate(1px, -1px) rotate(1deg); }
	50% { transform: translate(-1px, 2px) rotate(-1deg); }
	60% { transform: translate(-3px, 1px) rotate(0deg); }
	70% { transform: translate(2px, 1px) rotate(-1deg); }
	80% { transform: translate(-1px, -1px) rotate(1deg); }
	90% { transform: translate(2px, 2px) rotate(0deg); }
	100% { transform: translate(1px, -2px) rotate(-1deg); }
}






/**** MEDIA QUERIES *****/
/**** MEDIA QUERIES *****/
/**** MEDIA QUERIES *****/
@media all and (max-width:1080px) {
	
	:root {
		--header: 84px;
		--header-scrolled: 70px;
	}
	
	h1 {
		font-size:2.5rem;
	}
	
	h1.impact {
		font-size: clamp(2.4rem, 11vw, 7rem);
	}
	
	h2 {
		font-size:2rem;
	}
	
	h3 {
		font-size:1.75rem;
	}
	
	p {
		font-size: 0.88889rem;
	}
	
	input, textarea, select {
		padding: 0.88889rem;
		font-size: 16px;
	}
	
	article p a {
		word-wrap: break-word;
		word-break: break-all;
	}

	div[class*='span'] {
		float:none; 
		clear:both; 
		width:100%; 
	}
	
	.wp-block-group.is-layout-constrained {
		padding: 1rem;
	}
	
	
	figure.header-logo {
		width: 148px;
		height: 52px;
	}

	.menu-toggle {
		display: flex;
		z-index: 999;
		color: white;
		width: 48px;
		height: 48px;
		cursor: pointer;
		transition: var(--transition);
		justify-content: center;
		align-items: center;
	}
	
	.menu-toggle svg {
		fill: white;
		width: 24px;
		height: 24px;
		object-fit: contain;
		transition:var(--transition);
	}
	
	.header.opened .menu-toggle {
		color:#fff;
	}	
	
	body.nav-opened {
		height: 100vh;
		overflow: hidden;
	}

	nav.nav {
		z-index: 998;
		display: flex;
		flex-flow: column;
		justify-content: flex-start;
		align-items: flex-start;
		border-right: 1px solid black;
		position: fixed;
		top: 0;
		left: calc(-100vw - 1rem);
		width: 100%;
		height: 100%;
		background: black;
		overflow: scroll;
		transition: var(--transition);
		padding: var(--header) 1rem 5rem 1rem;
	}
	
	body.nav-opened nav.nav {
		left: 0;
	}

	
	nav.nav ul.menu {
		width:100%;
		flex-flow: column;
		gap: 0;
	}
	
	ul.menu li {
		justify-content: flex-start;
		align-items: flex-start;
		flex-flow: column;
	}

	nav.nav ul.menu li a {
		padding: 0.75rem 1rem 0.65rem 1rem;
		height: auto;
		font-size: 1.25rem;
	}

	nav.nav ul.menu li.header-button > a {
		padding: 1rem 2rem;
		margin-top: 1rem;
	}
	
	nav.nav ul.menu li ul.sub-menu {
		padding: 0 0 0.5rem 1.5rem;
		margin: 0;
		list-style: none;
		display: flex;
		flex-flow: column;
	}

	nav.nav ul.menu li ul.sub-menu li a {
		font-size: 1.1rem;
		padding: 0.5rem;
	}

	.scrolling-photos,
	.scrolling-photos > figure,
	.scrolling-photos > figure img {
		height: 120px;
	}
	
	.team-block {
		--columns: 2;
	}
	
	div[class*='span'].footer-meta {
		flex-flow: column;
		align-items: flex-start;
		gap: 4px;
	}

	.footer-bottom .row {
		gap: 1rem;
	}

	.text-right {
		text-align: left;
	}

	a.builtby {
		margin: 0 auto 0 0;
	}
	
	

}

@media all and (max-width:475px) {
	.team-block {
		--columns: 1;
	}
	ul.partner-logos {
		gap: 12px;
	}
	.wp-block-cover.is-style-hero-banner form {
		flex-flow: column;
	}
}

/**** MEDIA QUERIES *****/
/**** MEDIA QUERIES *****/
/**** MEDIA QUERIES *****/