/******************************************************************
Theme Name: Perron
Theme URI: https://www.perron.co.uk
Author: Andrew Perron
Author URI: https://www.andrewperron.com
Description: Web Design & Development
Version: 210114
License: Commercial
License URI: https://www.perron.co.uk
Tags: perron
Text Domain: perron 
******************************************************************/

/***
VARS
***/
:root { 
    --dark:  8,8,8;
    --grey:  51,51,51;
	--grey2: 102,102,102;
	--grey3: 153,153,153;
	--grey4: 204,204,204;
    --pink:  247, 150,247;
    --lite:  247,247,247;
	--red: 	 233,30,99;
	--blue:  3,169,244;
		
    --text: rgba(var(--grey));
    --primary: rgba(var(--grey2)); 
    --secondary: rgba(var(--blue));
    
    --font-sys: -apple-system, BlinkMacSystemFont, "Segoe UI", "Oxygen", "Oxygen-Sans", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
    --lineheight: 1.5;
    
    --width-max:     1920px;
    --width-content: 1680px;    
    --width-text:    1280px;
    --headerheight: 184; /* set using JS if height varies responsively */
    --fullheight: 0;
    --bannerheight: 0;
    
    --vh:0;
    --uivh: calc(var(--vh,1vh) * 100px); /* --vh calculated by script */
    --adminbarheight: 0;
    --scrollbarwidth: calc(100vw - 100%);
    --uivw:calc(100vw - var(--scrollbarwidth));
    
    --transition-attr:all;
    --transition-time:0.2s;
    --transition-type:ease;
	
	--gridgap: 0;
	--pad: 30px;
}

/* FIX GTRANSLATE */
html body {
	position: static !important;
	min-height:100vh !important;
	top: auto !important;
}
#gtranslate_wrapper {
	left:5% !important;
}

/* SPLASH SCREEN */
:root {
	--scrollPos:0; /* updated by script */
	--scrollPosDeg: 0;
	--fader: calc(((calc(calc(var(--vh,1) * 100) - var(--scrollPos)) / calc(var(--vh,1) * 100))));
}
.splash {
	  min-height: 14vmin;
	  height: 100vh;
	  height: var(--uivh,100vh);
	  width: 100%;
	  display: flex;
	  overflow: hidden;
	background: rgb(0,39,79);
	  position: relative;
   }
	.splash::after {
		content: "";
		position: absolute;
			z-index: 2;
			top: 0;
		bottom:0;
			left: 0;
			right: 0;
		background: transparent url(assets/images/energy-bg2.jpg?ver=1610667633) 50% 57% no-repeat scroll;
		background-size: 100vmax 100vmax;
		will-change: transform;
		transform: translateY(calc(var(--scrollPos,0) * 0.5px));
		min-height: 14vmin;
	}
	.splash-inner {
		flex: 1 1 auto;
		margin-top: calc(var(--scrollPos,0) * 1px);
		display: -webkit-box;
		display: -webkit-flex;
		display: -moz-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-webkit-align-items: center;
		   -moz-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		   -moz-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-flex-direction: column;
		   -moz-box-orient: vertical;
		   -moz-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		/*background: rgb(0,39,79) url(assets/images/energy-bg2.jpg?ver=1610667633) 50% 50% no-repeat scroll;
		background-size: 100vmax 100vmax;*/
		overflow: hidden;
			min-height: 14vmin;
			height: calc(var(--uivh,100vh) - calc(var(--scrollPos,0) * 1px));
			max-height: var(--uivh,100vh);
			 -webkit-transform:translatez(0);
			  transform:translatez(0);
		will-change: transform;
			position: relative;
			z-index: 3;
		cursor: pointer;
		}
	.splash-text {
		position: relative;
		z-index: 5;
		font-weight: 300;
	}
	.splash-text span {
		text-transform: lowercase;
	}
	.splash-animated{
		display: inline-block;
		display: block;
		width: 100%;
		text-align: center;
	}	
    .splash-animated span{
        -ms-animation: topToBottom 8s linear infinite 0s;
        -webkit-animation: topToBottom 8s linear infinite 0s;
        animation: topToBottom 8s linear infinite 0s;
        opacity: 0;
		  z-index: 5;
        display: inline-block;
		  text-align: center;
		  white-space: nowrap;
        -ms-animation-delay: 2s;
        -webkit-animation-delay: 2s;
		  animation-delay: 2s;
      }

      .splash-animated span:nth-child(3n+1){
        -ms-animation-delay: 2s;
        -webkit-animation-delay: 2s;
        animation-delay: 2s;
      }

      .splash-animated span:nth-child(3n+2){
        -ms-animation-delay: 4s;
        -webkit-animation-delay: 4s;
        animation-delay: 4s;
      }

      .splash-animated span:nth-child(3n+3){
        -ms-animation-delay: 6s;
        -webkit-animation-delay: 6s;
        animation-delay: 6s;
      }

      @-moz-keyframes topToBottom{
        0% { opacity: 0; }
        5% { opacity: 0; -moz-transform: translateY(-16px); }
        10% { opacity: 1; -moz-transform: translateY(0px); }
        25% { opacity: 1; -moz-transform: translateY(0px); }
        30% { opacity: 0; -moz-transform: translateY(16px); }
        80% { opacity: 0; }
        100% { opacity: 0; }
      }
      @-webkit-keyframes topToBottom{
        0% { opacity: 0; }
        5% { opacity: 0; -webkit-transform: translateY(-16px); }
        10% { opacity: 1; -webkit-transform: translateY(0px); }
        25% { opacity: 1; -webkit-transform: translateY(0px); }
        30% { opacity: 0; -webkit-transform: translateY(16px); }
        80% { opacity: 0; }
        100% { opacity: 0; }
      }
      @-ms-keyframes topToBottom{
        0% { opacity: 0; }
        5% { opacity: 0; -ms-transform: translateY(-16px); }
        10% { opacity: 1; -ms-transform: translateY(0px); }
        25% { opacity: 1; -ms-transform: translateY(0px); }
        30% { opacity: 0; -ms-transform: translateY(16px); }
        80% { opacity: 0; }
        100% { opacity: 0; }
      }
      @keyframes topToBottom{
        0% { opacity: 0; }
        5% { opacity: 0; transform: translateY(-16px); }
        10% { opacity: 1; transform: translateY(0px); }
        25% { opacity: 1; transform: translateY(0px); }
        30% { opacity: 0; transform: translateY(16px); }
        80% { opacity: 0; }
        100% { opacity: 0; }
      }
		
		@media (prefers-reduced-motion: reduce) {
			.splash-animated span {
				opacity:1;
			}
		}
		
	.splash-locations {
		position: absolute;
		left:0;right:0;
		width:100%;
		text-align: center;
		max-width: 49ch;
		margin: 0 auto;
		bottom: 15vh;
		padding: 0 20px;
		opacity: calc(var(--fader,1.5) - 0.35);
		color:#fff;
		font-size: calc(3.5vmin * var(--fader));
	   text-shadow: 0px 0px 5px rgba(0,0,0,0.5);
		mix-blend-mode: screen;
	}
		
		
   .down {
	  display: block;
	 font-family: auto;
	  position: absolute;
	 z-index: 5;
	 bottom: 0;
	   margin-bottom: 20px;
	 background: none;
	 border: none;
	 box-shadow: none;
	 text-decoration: none;
	 color: #fff;
	 left: 50%;
	 cursor: pointer;
	 opacity: calc(var(--fader,1.5) - 0.75);
	 font-size: 4rem;
	 width:6rem;
	 text-align: center;
	 margin-left: -3rem;
	   pointer-events: all;
   }
   :focus:not(:focus-visible) { outline: none; }
   .bounce {
   -moz-animation: bounce 2s infinite;
   -webkit-animation: bounce 2s infinite;
   animation: bounce 2s infinite;
  }

  @keyframes bounce {
   0%, 20%, 50%, 80%, 100% {
	 transform: translateY(0);
   }
   40% {
	 transform: translateY(-30px);
   }
   60% {
	 transform: translateY(-15px);
   }
  }

   .splash h1 {
	 font-size: 9vmin;      
	 font-weight: 300;
	 /*background: radial-gradient(#ffffff, #232323);
     background-size: 38% 100%;
     background-position: 60% 50%;
	 -webkit-background-clip: text;
	 background-clip: text;
	 -webkit-text-fill-color: transparent;
	 text-fill-color: transparent;*/
	 position: relative;
	 z-index: 3;
	     /*mix-blend-mode: screen;*/
    color: #fff;
    text-shadow: 4px 2px 1px rgba(0,0,0,0.5);
	   letter-spacing: 0.025em;
	 margin: 0 auto;
  	 padding: 0.5rem;
	 pointer-events: none;
	 line-height: 1;
     /*font-family: "Open Sans", var(--fontsys);*/
   }
   .splash h1 span {
     font-size: 8vmin;   
   }
   .splash p {
	  color:#fff;
	 font-size: 5vmin;
	   font-weight: 300;
	 /*mix-blend-mode: screen;*/
	   text-shadow: 0px 0px 10px rgba(0,0,0,0.5);
	 margin: 0 auto;
  	 padding: 0;
	 pointer-events: none;
	 line-height: 1.2;
	 position: relative;
	 z-index: 3;
	 /*opacity: calc(var(--fader,1) * 1);*/
  	  /*font-family: "Open Sans", var(--fontsys);*/
   }








/***
BASE
***/
html {
    /*height: var(--uivh,100vh);*/
	height: 100%;
	margin: 0;
    padding: 0;
    font-size: 62.5%;
	background-color: #000;
    -ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
*,
*::after,
*::before {
    -webkit-box-sizing: inherit;
            box-sizing: inherit;
}
html, body {
	max-width: 100vw;
	scroll-behavior: smooth;
}
body {
	font-weight: 400;
    /*font-size: calc( 1.25rem + 0.5vw);
    font-size: clamp(1.6rem, 2vw, 1.5rem);*/
    font-size: 1.2rem;
    line-height: var(--lineheight, 1.5);
	font-family: "Open Sans",var(--font-sys,sans-serif);
	color: var(--text);
	-webkit-font-smoothing: antialiased;
    background-color: #fff;
	overflow-y: scroll;
	overflow-x: hidden;
    min-height:100vh;
	margin: 0;
    padding: 0;
}
p {
	font-family: var(--font-sys,sans-serif);
	font-weight: inherit;
	text-rendering: optimizeSpeed;
    line-height: var(--lineheight,1.5);
	margin: 0 0 1em 0;
    /*font-size: calc( 1.25rem + 0.5vw);
    font-size: clamp(1.6rem, 2vw, 1.7rem);*/
	font-size: 1.2rem;
}
body.admin-bar {
    --adminbarheight: 32;
}
@media screen and (max-width: 782px) {
    body.admin-bar {
        --adminbarheight: 46;
    }
}
@media screen and (max-width: 959px) {
    :root {
        --headerheight: 184; /* may need JS to set if height varies responsively */
    }
}
@media only screen and (max-device-width : 1024px) and (orientation : portrait) {
    .fullheight {
        height: 100vh; /* fallback */
    }
    .fullheight {
        --fullheight:calc(var(--uivh) - var(--adminbarheight) * 1px);
        height: var(--fullheight,100vh);
    }
}
/*@supports ( backdrop-filter: blur(3px) ) {
    #wpadminbar {
        -webkit-backdrop-filter: blur(3px) contrast(.8) hue-rotate(45deg);
        backdrop-filter: blur(3px) contrast(.8) hue-rotate(45deg);
        background: rgba(0,0,0,0.7);
    }
}*/

body.logged-in.admin-bar #wpadminbar {
	background: #000;
}
body.logged-in.admin-bar.lg-on {
	overflow: hidden !important;
}
body.logged-in.admin-bar.lg-on #wpadminbar {
	display: none !important;
	--adminbarheight:0;
}

@media screen and (min-width:1280px){
	:root {margin-top:0 !important;}
	body.logged-in.admin-bar {
        padding-top: 32px;
	}
    /*body.logged-in.admin-bar #wpadminbar {
		opacity: 0.05;
		display: block;
		transition: opacity 0.3s;
		pointer-events: none;
	}
	body.logged-in.admin-bar #wpadminbar:hover,
	body.logged-in.admin-bar #wpadminbar:focus {
		opacity: 1;
	}
	body.logged-in.admin-bar #wpadminbar a {
		pointer-events: all;
	}

	body.logged-in.admin-bar #wpadminbar { background-color: rgba(0,0,0,1); display: block; transition: opacity  0.3s ease; opacity:0.05; box-shadow: 0 0 15px 15px rgba(0,0,0,0); }
	body.logged-in.admin-bar #wpadminbar:hover { background-color: rgba(0,0,0,1); box-shadow: 0 0 15px 15px rgba(0,0,0,0.5); opacity: 1; }*/
}
body {
	display: grid;
	grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr auto auto;
	align-items: center;
	justify-content: stretch;
	background: rgb(0,39,79);
	background: #d6d3cc;
	/*background: rgb(0,39,79) url(assets/images/energy-bg2.jpg?ver=1610667633) 50% 50% no-repeat fixed;
	background-size: cover;*/
}
/*@supports (-webkit-overflow-scrolling: touch) {
}*/
/*@supports (-webkit-touch-callout: none) {
	body {
		background: none;
	}
	body::after {
		content:"";
		display: block;
		position: fixed;
		z-index: -1;
		top:0;
		right: 0;
		bottom:0;
		left:0;
		background: rgb(0,39,79) url(assets/images/energy-bg2.jpg?ver=1610667633) 50% 50% no-repeat scroll;
		background-size: cover;
	}
}*/
body > header,
body > footer {
	display: grid;
	align-items: center;
	justify-content: stretch;
	height: 100%;
	position: relative;
}
body > main {
	background: rgba(255,255,255,0.9);
	border-top-left-radius: 50px;
    border-bottom-right-radius: 50px;
    /*border: 25px solid #5cace2;*/
    /*border: 25px solid rgba(0,39,79,1);*/
	overflow: hidden;
	display: grid;
	align-items: start;
	justify-content: stretch;
	/*height: 100%;*/
	position: relative;
	max-width: var(--width-text);
	width:100%;
	margin: var(--pad) auto;
    padding: var(--pad);
    --gridgap: var(--pad);
	gap: var(--gridgap);
	grid-template-columns: 2fr 1fr !important;
}
body > main > article:only-child {
	grid-column: 1/-1 !important;
}
@media screen and (max-width:1320px) {
    body > main {
        padding: calc(var(--pad) / 2);
		border-top-left-radius: 24px;
		border-bottom-right-radius: 24px;
		/*border: 12px solid #5cace2;*/
		margin: 25px;
		width: calc(100% - 50px);
    }
}
@media screen and (max-width:767px) {
    body > main {
        padding: calc(var(--pad) / 4);
		border-top-left-radius: 12px;
    	border-bottom-right-radius: 12px;
		/*border: 6px solid #5cace2;*/
		margin: 12px;
		width: calc(100% - 24px);
		grid-template-columns: 1fr !important;
    }
}
main > article {
    /*min-height: 100%;*/
    margin: 0 0 auto 0;
}
footer {
    color: rgba(var(--lite),1);
    background: rgba(var(--dark),0.7);
	background: rgb(0,39,79);
    /*background-image: -webkit-linear-gradient(rgba(247,247,247,0.2), #000);
    background-image: -o-linear-gradient(rgba(247,247,247,0.2), #000);
    background-image: linear-gradient(rgba(247,247,247,0.2), #000);*/
	width: 100%;
    padding: var(--pad);
	font-size: 1.6rem;
}
footer .menu li {
	display: inline-block;
}
footer a:hover {
	color: var(--secondary);
}

/*****
HEADER 
*****/
header.header {
	text-align:center;
    grid-template-columns: 1fr auto;
	background: rgba(var(--lite),0.2);
    color: rgba(var(--lite),1);
	width: 100%;
	position: -webkit-sticky;
    position: sticky;
    top: calc(var(--adminbarheight,0) * 1px);
    z-index: 3;
	padding: 0 var(--pad);
	min-height: 69px;
}
@media screen and (max-width:600px){
    header.header {
        top:0;
    }
}
.sitelogo {
    display: block;
    width: 69px;
    height: 69px;
    padding: 5px !important;
    -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
@media screen and (min-width:1025px){
    .sitelogo {
        margin: 0 auto;
    }
}
.sitelogo img ,
.sitelogo svg {
	position: relative;
	z-index: 3;
	width: 100%;
	height: auto;
	display: block;
	border-radius: 0 !important;
	border-top-left-radius: 50% !important;
    border-bottom-right-radius: 50% !important;
	overflow: hidden;
}

/*.nav-primary .menu-item-home ,
.nav-primary .menu-item-145 ,*/
.mobilesitelogo {
    display: none;
}
@media screen and (max-width:1024px) {
    .mobilesitelogo {
        display: block;
    position: relative;
    z-index: 2;
    top: 0;
    left: var(--pad);
        -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
         -o-transform: translateX(-50%);
            transform: translateX(-50%);
    }
	.js-nav-active .mobilesitelogo {
    	z-index: 1;
	}
}

.banner {
	background:rgba(50, 50, 50,0.5) url() 50% 50% no-repeat scroll;
	background-size: cover;
	padding: 138px 0 69px 0;
	min-height: 50vmin;
}
header.header+.banner {
	margin-top: -69px;
}
.banner-caption {
    font-size: 7vmin;
    font-weight: 300;
    color: #fff;
    text-shadow: 4px 2px 1px rgb(0 0 0 / 50%);
    letter-spacing: 0.025em;
    margin: auto auto 0.5rem auto;
    padding: 0.5rem;
    pointer-events: none;
	text-transform: none;
    line-height: 1;
    font-family: "Open Sans", var(--fontsys);
}
.banner h1.heading .logo {
	display: inline-block;
    vertical-align: middle;
    max-height: 2em;
    margin: -0.15em 0.5em 0 0;
    border-top-left-radius: 50%;
    border-bottom-right-radius: 50%;
    overflow: hidden;
	pointer-events: all;
}
.banner h1.heading .logo img {
	display: inline-block;
	max-height: 2em;
}
.banner h1.heading span {
	background: rgba(0,0,0,0.4);
    color: rgba(247,247,247,1);
    background-image: -webkit-linear-gradient(rgba(32,32,32, 0.5), rgba(0,0,0, 0.5));
    background-image: -o-linear-gradient(rgba(32,32,32, 0.5), rgba(0,0,0, 0.5));
    background-image: linear-gradient(rgba(32,32,32, 0.5), rgba(0,0,0, 0.5));
    text-shadow: 4px 3px 2px rgba(127,127,127,0.5);
    letter-spacing: 0.04em;
    padding: 0.4rem 1rem;
	margin: -0.4rem -1rem;
    line-height: 1.36;
    text-transform: uppercase;
    font-weight: 300;
    pointer-events: none;
    -webkit-box-decoration-break: clone;
    -ms-box-decoration-break: clone;
    -o-box-decoration-break: clone;
    box-decoration-break: clone;
}

/*****
PAGE 
*****/
.wp-block-column p,
[class*="grad-"] p {
    text-align: justify;
}
/*.blocks-gallery-item img {
    box-shadow: 0 2px 2px 2px rgba(0,0,0,0.5);
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -moz-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}  
.blocks-gallery-item a:hover img {
    box-shadow: 0 5px 5px 5px rgba(0,0,0,0.5);
    filter: contrast(1.5);
}*/

.wp-block-quote {
	border-left: 5px solid var(--secondary);
	margin: var(--pad) auto;
}
.wp-block-quote p {
    font-size: 120%;
}
.wp-block-quote strong {
	color: rgba(0,39,79,1);
	font-size: 150%;
}

.page-id-364 article.article p {
	margin: 0 0 1em 0;
	max-width: none;
}
.page-id-364 .wpjb-fieldset-apply legend , /*submit CV*/
.page-id-364 aside #custom_php {
	display: none;
}
.page-id-364 input.wpjb-submit { /*submit CV*/
	cursor: pointer;
}
.page-id-364 #wpjb-widget-alerts-3 { /*submit CV*/
	border: none;
	margin-top: 0;
	padding-top: 0;
}
  
/******
UTILITY
******/
.frost {
    --blur: 4px;
    --saturate: 600%;
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    pointer-events: none;
}
.frost.dark {
    box-shadow: rgba(var(--dark),0.4) 0px 10px 10px 5px;
}
.frost::after {
    content:"";
    position: absolute;
    z-index: 2;
    top: calc(var(--blur) * -1);
    right: calc(var(--blur) * -1);
    bottom: calc(var(--blur) * -1);
    left: calc(var(--blur) * -1);
    background-color: rgba(247,247,247,0.9);
    -webkit-transition: background-color 0.5s cubic-bezier(0.28, 0.11, 0.32, 1);
    transition: background-color 0.5s cubic-bezier(0.28, 0.11, 0.32, 1);
    -webkit-transition-property: background-color, -webkit-backdrop-filter;
    transition-property: background-color, -webkit-backdrop-filter;
    transition-property: background-color, backdrop-filter;
    transition-property: background-color, backdrop-filter, -webkit-backdrop-filter;
}
.frost.dark::after {
    background-color: rgba(8,8,8,0.9);
}
header.header {
    background-color: rgba(0,39,79,0.7);
}
header.header:hover {
    background-color: rgba(0,39,79,1);
}
header.header:hover .frost::after {
    background-color: rgba(251,251,251,0.9);
}
header.header:hover .frost.dark::after {
    background-color: rgba(4,4,4,0.9);
}
@supports ((-webkit-backdrop-filter: initial) or (backdrop-filter: initial)) {
    .frost::after {
        -webkit-backdrop-filter:saturate(var(--saturate)) blur(var(--blur));
        backdrop-filter: saturate(var(--saturate)) blur(var(--blur));
        background-color: rgba(247,247,247,0.7);
    }
    .frost.dark::after {
        background-color: rgba(8,8,8,0.7);
    }
    .frost.noblur::after {
        -webkit-backdrop-filter: initial;
        backdrop-filter: initial;
		background-color: rgba(247,247,247,0.9);
    }
	.frost.dark.noblur::after {
		background-color: rgba(8,8,8,0.9);
	}
    header.header:hover .frost::after {
        --blur: 8px;
        background-color: rgba(251,251,251,0.8);
    }
    header.header:hover .frost.dark::after {
        background-color: rgba(4,4,4,0.8);
    }
}
.js .fade-in header.header .frost {
    position: fixed;
}
.js .fade-in .nav-primary {
    background-color: rgba(8,8,8,0.5);
}
@media only screen and (max-width: 1024px) {
    .js .js-nav-active header.header .frost ,
    .js .fade-in header.header .frost {
        position: fixed;
    }
    .js .js-nav-active .nav-primary ,
    .js .fade-in .nav-primary {
        background-color: rgba(8,8,8,0.9);
    }
}
.rotate {

}
.fade-in .sitelogo img,
.rotate:hover {
	 -webkit-animation: rotate 1s linear infinite;
        -moz-animation: rotate 1s linear infinite;
          -o-animation: rotate 1s linear infinite;
             animation: rotate 1s linear infinite;
}
@-webkit-keyframes rotate {
    from{ -webkit-transform: rotate(0deg); }
    to{   -webkit-transform: rotate(360deg); }
}
@-moz-keyframes rotate {
    from{ -webkit-transform: rotate(0deg); }
    to{   -webkit-transform: rotate(360deg); }
}
@-o-keyframes rotate {
    from{ -webkit-transform: rotate(0deg); }
    to{   -webkit-transform: rotate(360deg); }
}
@keyframes rotate {
    from{ -webkit-transform: rotate(0deg); }
    to{   -webkit-transform: rotate(360deg); }
}
.content.max,
.alignfull {
	margin: 0;
	max-width: var(--width-max);
}
.content {
	margin: 0 auto;
	max-width: var(--width-content);
    padding: 0 var(--pad);
}
.content.text {
	max-width: var(--width-text);
}
.primary {
    color: var(--primary);
}
.secondary {
    color: var(--secondary);
}
aside {
	/*padding-top: 85px;*/
}
.widget + .widget {
	margin-top: var(--pad);
	padding-top: var(--pad);
	border-top: 2px solid rgba(var(--blue),1);
}
h1, h2, h3, h4, h5, h6 {
    display: block;
    text-rendering: optimizelegibility;
	line-height: 1.2;
	margin: 0 0 0.5em 0;
    font-weight: 300;
    letter-spacing: 0.075em;
    color: rgba(var(--blue),1);
    font-size: inherit;
/*    text-transform: uppercase;
*/}
h1,.h1 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(2.5rem, 2vw, 3.2rem);
    text-transform: none;
    text-align: left;
}
h2,.h2 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(2.3rem, 2vw, 2.8rem);
}
h3,.h3 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(2.1rem, 2vw, 2.5rem);
}
h4,.h4 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(1.9rem, 2vw, 2.3rem);
}
h5,.h5 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(1.7rem, 2vw, 2.1rem);
}
h6,.h6 {
    font-size: calc( 3rem + 1vw);
    font-size: clamp(1.5rem, 2vw, 1.9rem);
}
.textcenter {
	text-align: center;
}
a {
	text-decoration: none;
	color: inherit;
    display: inline-block;
}
a:active, a:hover {
	outline: none;
}
:focus:not(:focus-visible) { outline: none !important; }
article.article {
    overflow-wrap: break-word;
    word-break: break-word;
	text-align: justify;
}
article.article li {
    text-align: inherit;
}
article.article:only-child h1 {
    text-align: left;
    display: block;
    margin: 0 auto 1em auto;
    max-width: 605px;
}
article.article h3 {
    margin: var(--pad) auto;
}
article.article p ,
article.article ul,
.privacy-policy article.article {
    overflow-wrap: break-word;
	word-break: normal;
    max-width: 605px;
    margin: 0 auto 1em auto !important;
	padding: 0;
}
article.article p a {
    overflow-wrap: break-word;
	word-break: break-all;
	display: inline;
	color: rgba(var(--blue),1);
	text-decoration: none;
}
.wp-block-gallery a ,
article.article p .lightgallery a ,
article.article p a.lightgallery {
	display: inline-block;
}
main a:hover {
    color: var(--secondary);
    text-decoration-color: var(--secondary);
}
button, .btn {
    unset: all;
    display: inline-block;
    background: none;
	border: none;
}
.btn {
    border: 2px solid var(--secondary);
    color: var(--primary);
    background-color: #fff;
    padding:0.6em 2em;
    text-decoration: none !important;
	text-transform: uppercase;
	text-align: center;
    font-family: var(--font-sys);
	font-weight: 400;
	font-size: 1.6rem;
	letter-spacing: 0.075em;
    border-radius: var(--pad);
}
article.article p.btn {
	padding:0.6em 2em;
}
.btn:hover ,
main .btn:hover a {
    background-color: var(--secondary) !important;
    color: #fff !important;
}
.pad {
    padding: var(--pad);
}
.icon {
    display:inline-block;
    width:40px;
    height:40px;
	--col: currentColor; /* fallback */
    background: var(--col);
	color: #fff;
    fill: currentColor;
	padding: 5px;
	vertical-align: middle;
    border-radius: 5px;
    margin-right: 15px;
    border:1px solid transparent;
}
.icon:hover {
	background: #fff;
    border-color: rgba(0,39,79,0.7);
	color: var(--col);
}

.post-article {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-webkit-flex-direction: column;
   -moz-box-orient: vertical;
   -moz-box-direction: normal;
    -ms-flex-direction: column;
        flex-direction: column;
}
.post-article .post-link {
    margin-top: auto;
    padding-top: var(--pad);
        display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}
.post-article .post-link .btn {
    margin-left: auto;
}
.post-article .post-thumb {
    margin-bottom: var(--pad);
}
.post-article .post-title h3 {
    font-weight: 900;
    margin-bottom: calc(var(--pad) / 2);
}
.blog-date ,
.post-date {
    color: var(--secondary);
	font-weight: 700;
	text-transform: uppercase;
    margin-bottom: calc(var(--pad) / 2);
}


.grid.masonry {
    align-items: start;
    grid-template-rows: masonry;
}
/*@supports (grid-template-rows: masonry) {
    .grid.masonry {
        align-items: start;
        grid-template-rows: masonry;
    }
}*/

.wpjb-submit,
.wpjb .wpjb-job-apply .wpjb-button,
.wpjb .wpjb-widget-alert-save{
    text-transform: uppercase;
    background-color: #fff;
    color: var(--primary);
    padding: 0.6em 2em;
	border: 2px solid  var(--secondary);
    border-radius: var(--pad);
}
#custom_html-2 .btn {
    background-color: rgba(0,39,79,1);
	color: #fff;
}
.wpjb-submit:hover,
.wpjb .wpjb-job-apply .wpjb-button:hover,
.wpjb .wpjb-widget-alert-save:hover {
    background-color: var(--secondary);
    color: #fff;
	border: 2px solid  var(--secondary);
}
#custom_html-2 .btn:hover {
    background-color: var(--secondary);
    color: #fff;
	border: 2px solid  var(--secondary);
}
@media screen and (max-width:640px){
    .wpjb-submit,
	.wpjb .wpjb-job-apply .wpjb-button,
	.wpjb .wpjb-widget-alert-save {
        padding: 0.4em 1em;
    }
}
.wp-block-image img {
	border-top-left-radius: 25px;
    border-bottom-right-radius: 25px;
	overflow: hidden;
}

.wp-block-image .aligncenter {
    max-width: 605px;
}

.post-nav a {
    text-transform: uppercase;
    background-color: #fff;
    color: var(--primary);
    padding: 0.6em 2em;
	border: 2px solid  var(--secondary);
    border-radius: var(--pad);
}
.post-nav a:hover {
    background-color: var(--secondary);
    color: #fff;
}
@media screen and (max-width:640px){
    .post-nav a {
        padding: 0.4em 1em;
    }
}

.leaflet-container{z-index:0;}

.custom-pagination {
    text-align: center;
    font-size: 2rem;
    margin-top: var(--pad);
}
.custom-pagination .page-num {
    display: none;
}
.custom-pagination span {
    display: inline-block;
}
.custom-pagination a,
.custom-pagination .current {
    padding: 0.4em 0.8em;
    display: inline-block;
}
.custom-pagination a:hover {
    background-color: #fff;
    color: var(--primary);
}
.custom-pagination .current {
    background-color: var(--secondary);
    color: #fff;
    cursor: default;
}



.transition-all, .ta  {
	-webkit-transition: var(--transition-attr,all) var(--transition-time,0.2s) var(--transition-type,ease);
	-moz-transition: var(--transition-attr,all) var(--transition-time,0.2s) var(--transition-type,ease);
	-o-transition: var(--transition-attr,all) var(--transition-time,0.2s) var(--transition-type,ease);
	-ms-transition: var(--transition-attr,all) var(--transition-time,0.2s) var(--transition-type,ease);
	transition: var(--transition-attr,all) var(--transition-time,0.2s) var(--transition-type,ease);
}

::-webkit-scrollbar {
	background: rgba(8, 8, 8, 0.5);
    width: 12px;
}
::-webkit-scrollbar-track {
/*    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3); 
*/    border-radius: 0;
}
::-webkit-scrollbar-thumb {
    border-radius: 5px;
	background: rgba(3, 169, 244, 0.5);
	-webkit-transition: all 0.5s ease-in-out;
       -moz-transition: all 0.5s ease-in-out;
        -ms-transition: all 0.5s ease-in-out;
         -o-transition: all 0.5s ease-in-out;
            transition: all 0.5s ease-in-out;
	/*	background: rgba(255,255,255,0.7);
	-webkit-box-shadow: inset 0 0 6px rgba(255,255,255,0.6); 
*/}
::-webkit-scrollbar-thumb:hover {
	background: rgba(3, 169, 244, 1);
}
::selection {
/*  background: #E91E63; */	
  background: rgba(var(--blue), 0.35);
}
::-moz-selection {
  background: rgba(var(--blue), 0.35);
}



.no-js #fader {
    display: none !important;
}
.js #fader {
    position: fixed;
    display: block !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 999999;
    pointer-events: none;
    color: rgba(var(--lite),1);
    background: rgba(0,0,0,0.9);
    background-image: -webkit-linear-gradient(rgba(247, 150, 247,0.2), #000);
    background-image: -o-linear-gradient(rgba(247, 150, 247,0.2), #000);
    background-image: linear-gradient(rgba(247, 150, 247,0.2), #000);
    animation-duration: 50ms;
    animation-timing-function: ease-in-out;
}

.js #fader:before {
    content: '';
}

@keyframes fade-out {
    from { opacity: 1 }
    to { opacity: 0 }
}

@keyframes fade-in {
    from { opacity: 0 }
    to { opacity: 1 }
}

.js #fader.fade-out {
    opacity: 0;
    animation-name: fade-out;
}

.js #fader.fade-in {
    opacity: 1;
    animation-name: fade-in;
}



.wpjb-box-mymembership, 
.wpjb-box-membership,
.wpjb-box-mypaymenthistory, 
.wpjb-box-payment_history, 
.wpjb-listing-type-cost,
.wpjb-widget-recent-jobs .wpjb-sub,
.wpjb-form-job-apply { display:none !important; }
#wpjb-form-job-apply { display:block !important; }
.wpjb-job-list * {
    font-size: inherit !important;
}
@media screen and (max-width:600px) {
	#wpjb-job-list td {
		display: block !important;
	}
}
@media screen and (max-width:1023px) {
	.wpjb-box {
		width: 48% !important;
	}
}


/************
THEME CHECKER
************/
.sticky {}
.gallery-caption {}
.bypostauthor {}