/* ==================================================
   Reset CSS + Clearfix
================================================== */

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}table{border-collapse:collapse;border-spacing:0}
.clearfix:before,.clearfix:after{content:".";display:block;height:0;overflow:hidden}.clearfix:after{clear:both}.clearfix{zoom:1}

/* ==================================================
   Colours
================================================== */

:root
{
    --dark: #191919;
    --lightergrey: #F5F5F5;
    --lightgrey: #EEEEEE;
    --darkgrey: #595959;
    --white: #FFFFFF;
    
    --lightgreen: #009fa5;
    --darkgreen: #009fa5;
    
    --lightbrown: #c37455;
    --darkbrown: #a66348;
}

/* ==================================================
   Cookie Script Styles
================================================== */

.cc-window{opacity:1;transition:opacity 1s ease}.cc-window.cc-invisible{opacity:0}.cc-animate.cc-revoke{transition:transform 1s ease}.cc-animate.cc-revoke.cc-top{transform:translateY(-2em)}.cc-animate.cc-revoke.cc-bottom{transform:translateY(2em)}.cc-animate.cc-revoke.cc-active.cc-bottom,.cc-animate.cc-revoke.cc-active.cc-top,.cc-revoke:hover{transform:translateY(0)}.cc-grower{max-height:0;overflow:hidden;transition:max-height 1s}
.cc-link,.cc-revoke:hover{text-decoration:underline}.cc-revoke,.cc-window{position:fixed;overflow:hidden;box-sizing:border-box;font-family:Helvetica,Calibri,Arial,sans-serif;font-size:16px;line-height:1.5em;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;z-index:9999}.cc-window.cc-static{position:static}.cc-window.cc-floating{padding:2em;max-width:24em;-ms-flex-direction:column;flex-direction:column}.cc-window.cc-banner{padding:1em 1.8em;width:100%;-ms-flex-direction:row;flex-direction:row}.cc-revoke{padding:.5em}.cc-header{font-size:18px;font-weight:700}.cc-btn,.cc-close,.cc-link,.cc-revoke{cursor:pointer}.cc-link{opacity:.8;display:inline-block;padding:.2em}.cc-link:hover{opacity:1}.cc-link:active,.cc-link:visited{color:initial}.cc-btn{display:block;padding:.4em .8em;font-size:.9em;font-weight:700;border-width:2px;border-style:solid;text-align:center;white-space:nowrap}.cc-banner .cc-btn:last-child{min-width:140px}.cc-highlight .cc-btn:first-child{background-color:transparent;border-color:transparent}.cc-highlight .cc-btn:first-child:focus,.cc-highlight .cc-btn:first-child:hover{background-color:transparent;text-decoration:underline}.cc-close{display:block;position:absolute;top:.5em;right:.5em;font-size:1.6em;opacity:.9;line-height:.75}.cc-close:focus,.cc-close:hover{opacity:1}
.cc-revoke.cc-top{top:0;left:3em;border-bottom-left-radius:.5em;border-bottom-right-radius:.5em}.cc-revoke.cc-bottom{bottom:0;left:3em;border-top-left-radius:.5em;border-top-right-radius:.5em}.cc-revoke.cc-left{left:3em;right:unset}.cc-revoke.cc-right{right:3em;left:unset}.cc-top{top:1em}.cc-left{left:1em}.cc-right{right:1em}.cc-bottom{bottom:1em}.cc-floating>.cc-link{margin-bottom:1em}.cc-floating .cc-message{display:block;margin-bottom:1em}.cc-window.cc-floating .cc-compliance{-ms-flex:1;flex:1}.cc-window.cc-banner{-ms-flex-align:center;align-items:center}.cc-banner.cc-top{left:0;right:0;top:0}.cc-banner.cc-bottom{left:0;right:0;bottom:0}.cc-banner .cc-message{-ms-flex:1;flex:1}.cc-compliance{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:justify;align-content:space-between}.cc-compliance>.cc-btn{-ms-flex:1;flex:1}.cc-btn+.cc-btn{margin-left:.5em}
@media print{.cc-revoke,.cc-window{display:none}}@media screen and (max-width:900px){.cc-btn{white-space:normal}}@media screen and (max-width:414px) and (orientation:portrait),screen and (max-width:736px) and (orientation:landscape){.cc-window.cc-top{top:0}.cc-window.cc-bottom{bottom:0}.cc-window.cc-banner,.cc-window.cc-left,.cc-window.cc-right{left:0;right:0}.cc-window.cc-banner{-ms-flex-direction:column;flex-direction:column}.cc-window.cc-banner .cc-compliance{-ms-flex:1;flex:1}.cc-window.cc-floating{max-width:none}.cc-window .cc-message{margin-bottom:1em}.cc-window.cc-banner{-ms-flex-align:unset;align-items:unset}}
.cc-floating.cc-theme-classic{padding:1.2em;border-radius:5px}.cc-floating.cc-type-info.cc-theme-classic .cc-compliance{text-align:center;display:inline;-ms-flex:none;flex:none}.cc-theme-classic .cc-btn{border-radius:5px}.cc-theme-classic .cc-btn:last-child{min-width:140px}.cc-floating.cc-type-info.cc-theme-classic .cc-btn{display:inline-block}
.cc-theme-edgeless.cc-window{padding:0}.cc-floating.cc-theme-edgeless .cc-message{margin:2em 2em 1.5em}.cc-banner.cc-theme-edgeless .cc-btn{margin:0;padding:.8em 1.8em;height:100%}.cc-banner.cc-theme-edgeless .cc-message{margin-left:1em}.cc-floating.cc-theme-edgeless .cc-btn+.cc-btn{margin-left:0}

.cc-window
{
	font-family: inherit, Arial, Verdana, Helvetica, sans-serif !important;
	font-size: 0.85em !important;
	line-height: 1.2em !important;
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

	.cc-window .cc-message
	{
		padding-right: 20px !important;
	}

@media only screen and (max-width: 576px)
{
	
	.cc-window .cc-message
	{
		padding-right: 0px !important;
		text-align: center;
	}
	
}

/* ==================================================
   Images
================================================== */

img
{
	display: block;
	
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-ms-backface-visibility: hidden;
	
	outline: 1px solid transparent;
}

/* ==================================================
   Loading screen
================================================== */

#spinner
{
    background: var(--lightgreen);
    opacity: 0;
    visibility: hidden;
    transition: opacity .5s ease-out, visibility 0s linear .5s;
    z-index: 99999;
}

#spinner.show
{
    transition: opacity .5s ease-out, visibility 0s linear 0s;
    visibility: visible;
    opacity: 1;
}

/* ==================================================
   Spinner
================================================== */

.sk-folding-cube
{
	margin: 40px auto;
	width: 40px;
	height: 40px;
	position: relative;
	
	-webkit-transform: rotateZ(45deg);
	transform: rotateZ(45deg);
}

.sk-folding-cube .sk-cube
{
	float: left;
	width: 50%;
	height: 50%;
	position: relative;
	
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}

.sk-folding-cube .sk-cube:before
{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--white);
	
	-webkit-animation: sk-foldCubeAngle 2.4s infinite linear both;
	animation: sk-foldCubeAngle 2.4s infinite linear both;
	-webkit-transform-origin: 100% 100%;
	-ms-transform-origin: 100% 100%;
	transform-origin: 100% 100%;
}

.sk-folding-cube .sk-cube2
{
	-webkit-transform: scale(1.1) rotateZ(90deg);
	transform: scale(1.1) rotateZ(90deg);
}

.sk-folding-cube .sk-cube3
{
	-webkit-transform: scale(1.1) rotateZ(180deg);
	transform: scale(1.1) rotateZ(180deg);
}

.sk-folding-cube .sk-cube4
{
	-webkit-transform: scale(1.1) rotateZ(270deg);
	transform: scale(1.1) rotateZ(270deg);
}

.sk-folding-cube .sk-cube2:before
{
	-webkit-animation-delay: 0.3s;
	animation-delay: 0.3s;
}

.sk-folding-cube .sk-cube3:before
{
	-webkit-animation-delay: 0.6s;
	animation-delay: 0.6s;
}

.sk-folding-cube .sk-cube4:before
{
	-webkit-animation-delay: 0.9s;
	animation-delay: 0.9s;
}

@-webkit-keyframes sk-foldCubeAngle
{
	0%, 10% {
	-webkit-transform: perspective(140px) rotateX(-180deg);
	transform: perspective(140px) rotateX(-180deg);
	opacity: 0; }
	25%, 75% {
	-webkit-transform: perspective(140px) rotateX(0deg);
	transform: perspective(140px) rotateX(0deg);
	opacity: 1; }
	90%, 100% {
	-webkit-transform: perspective(140px) rotateY(180deg);
	transform: perspective(140px) rotateY(180deg);
	opacity: 0; }
}

@keyframes sk-foldCubeAngle
{
	0%, 10% {
	-webkit-transform: perspective(140px) rotateX(-180deg);
	transform: perspective(140px) rotateX(-180deg);
	opacity: 0; }
	25%, 75% {
	-webkit-transform: perspective(140px) rotateX(0deg);
	transform: perspective(140px) rotateX(0deg);
	opacity: 1; }
	90%, 100% {
	-webkit-transform: perspective(140px) rotateY(180deg);
	transform: perspective(140px) rotateY(180deg);
	opacity: 0; }
}

/* ==================================================
   Fancy HR
================================================== */

.fancyhr
{
    display: flex;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    width: 100vw !important;
}

    .hr-line
    {
        width: 100%;
        position: relative;
        margin: 0;
        border-bottom: 1px dashed #CCC;
    }
    
    .fa-solid
    {
        position: relative;
        top: 6px;
        font-size: 1.8em;
        color: var(--lightgreen);
    }

/* ==================================================
   Typography
================================================== */

.section p
{
	margin: 0 0 20px 0;
}

	.section p.largertext
	{
		font-size: 120%;
		font-weight: 500;
	}

.section strong, .section b
{
	font-weight: 700;
}

.section em, .section i
{
	font-style: italic;
}

.section blockquote
{
    background: var(--lightergrey);
}

h1, h2, h3, h4, h5, h6
{
	margin: 0 0 30px 0;
	font-weight: 700;
    text-transform: none;
    font-family: "Outfit";
	line-height: 1em;
    letter-spacing: 0em;
}

	h1
	{
		font-size: 2em;
	}
	
	h2
	{
		font-size: 1.8em;
	}
	
	h3
	{
		font-size: 1.6em;
	}
	
	h4
	{
		font-size: 1.4em;
	}
	
	h5
	{
		font-size: 1.2em;
	}
	
	h6
	{
		font-size: 1.2em;
	}

.section hr
{
	clear: both;
	border: 0;
	height: 0;
	margin: 0 0 25px 0;
	border-top: 1px dotted #888;
}

	.section hr.specialhr
	{
		clear: both;
		border: 0;
		height: 0;
		margin: 0 auto 30px auto;
		width: 100%;
		max-width: 100px;
		border-top: 3px dotted var(--hydrogreen);
	}

    #footercont.section hr
    {
        border-top: 1px solid rgba(255,255,255,0.1);
    }
    
p.caption
{
    margin-bottom: 0;
    line-height: 1.2em;
    color: #666;
    font-size: 70%;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}
    
.section .dotteddivider
{
    display: block;
    margin: 0 auto;
    margin-top: 20px;
    width: auto;
}

    .section .dotteddivider span
    {
        display: inline-block;
        width: 20px;
        height: 4px;
        background: var(--hydrogreen);
        margin-left: 5px;
        margin-right: 5px;
        margin-bottom: 25px;
        
        -webkit-border-radius: 30px;
        -moz-border-radius: 30px;
        border-radius: 30px;
    }

.section ul
{
	margin: 0 0 20px 25px;
	list-style-type: square;
}

	.section ul li
	{
		padding: 0;
	}

		.section ul ul
		{
			margin: 0 0 0 20px;
		}

.section ol
{
	margin: 0 0 20px 25px;
	list-style-type: decimal;
}

	.section ol li
	{
		padding: 0;
	}

		.section ol ol
		{
			margin: 0 0 0 20px;
		}

.section .treemenu, .section .treemenu ul, .section .treemenu li
{
     position: relative;
}

	.section .treemenu ul
	{
		list-style: none;
		margin: 0 0 20px 0;
		line-height: 1.4em;
		padding-left: 15px;
	}
	
	.section .treemenu ul ul
	{
		padding-top: 5px;
		padding-left: 20px;
		margin: 0 0 5px 0;
	}
	
		.section .treemenu ul li
		{
			padding: 1px 0;
		}
		
			.section .treemenu li::before,
			.section .treemenu li::after
			{
				content: "";
				position: absolute;
				left: -15px;
			}

			.section .treemenu li::before
			{
				border-top: 1px solid #AAA;
				top: 12px;
				width: 8px;
				height: 0;
			}
			
			.section .treemenu li::after
			{
				border-left: 1px solid #AAA;
				height: 100%;
				width: 0px;
				top: 2px;
			}

/* ==================================================
   Columns
================================================== */			

.onecolumn ul, 
.twocolumns ul, 
.threecolumns ul
{
    list-style-type: none;
    margin: 0 0 20px 0;
    padding: 0;
}

    .onecolumn ul
    {
        columns: 1;
        -webkit-columns: 1;
        -moz-columns: 1;
    }

    .twocolumns ul
    {
        columns: 2;
        -webkit-columns: 2;
        -moz-columns: 2;
    }
    
    .threecolumns ul
    {
        columns: 2;
        -webkit-columns: 2;
        -moz-columns: 2;
    }

        .onecolumn ul li, 
        .twocolumns ul li, 
        .threecolumns ul li
        {
            position: relative;
            padding-left: 35px;
            line-height: 1.4em;
            padding-top: 6px;
            padding-bottom: 6px;
            font-weight: 700;
        }
        
            .onecolumn ul li::before, 
            .twocolumns ul li::before, 
            .threecolumns ul li::before
            {
                position: absolute;
                font-size: 100%;
                left: 0;
                font-family: "Font Awesome 6 Free"; font-weight: 900; content: "\f00c";
                color: var(--lightgreen);
            }
            
@media only screen and (max-width: 768px)
{
    
    .twocolumns ul
    {
        columns: 1;
        -webkit-columns: 1;
        -moz-columns: 1;
    }
    
    .threecolumns ul
    {
        columns: 1;
        -webkit-columns: 1;
        -moz-columns: 1;
    }
    
        .onecolumn ul li, 
        .twocolumns ul li, 
        .threecolumns ul li
        {
            position: relative;
            padding-left: 0px;
        }
        
            .onecolumn ul li::before, 
            .twocolumns ul li::before, 
            .threecolumns ul li::before
            {
                display: none;
                /**
                position: relative;
                left: auto;
                padding-right: 15px;
                **/
            }
    
}

/* ==================================================
   Button
================================================== */
    
.newbutton
{
    display: inline-block;
    padding: 16px 20px;
    font-size: 1.05em;
    font-weight: 700;
    color: var(--white) !important;
    border: 0;
    cursor: pointer;
    line-height: 1em !important;
    position: relative;
    background-color: var(--lightgreen);
    text-decoration: none !important;
    overflow: hidden;
    z-index: 1;
    font-family: "Outfit";
    text-transform: none;
    letter-spacing: 0.04em;
    
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}

    .newbutton::before
    {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background-color: #1e1e1e;
        transform: translateX(-100%);
        transition: all 0.2s;
        z-index: -1;
    }
    
    .newbutton:hover::before
    {
        transform: translateX(0);
    }

/* ==================================================
   Scrolltop Button
================================================== */
	
.scrollToTop
{
	position: fixed;
	display: none;
	bottom: 20px;
	right: 20px;
	background: var(--lightgreen);
	width: 42px;
	height: 42px;
	text-align: center;
	line-height: 42px;
	font-size: 1em;
	text-decoration: none;
	z-index: 997;
	
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

	.scrollToTop span
	{
		color: var(--white) !important;
        font-weight: 700;
		font-size: 1em;
	}

/* ==================================================
   Overlay
================================================== */

#closenowbutton
{
    position: fixed;
    top: 30px;
    right: 30px;
    cursor: pointer;
}

    #closenowbutton span
    {
        color: var(--white);
        font-style: normal;
        font-size: 2em;
    }

        #closenowbutton span:hover
        {
            color: var(--white);
        }

.overlay
{
	position: fixed;
	z-index: 9998;
	background: var(--darkgrey);
	color: var(--white);
	top: 0;
	left: 0;
	width: 100%;
	height: 0%;
	opacity: 1;
	padding-top: 0;
	padding-bottom: 0;
	visibility: hidden;
	overflow: hidden;
	
	-webkit-transition: opacity 0.2s, visibility 0.2s, height 0.2s;
	transition: opacity 0.2s, visibility 0.2s, height 0.2s;
}

	.overlay.open
	{
		opacity: 1;
		visibility: visible;
		height: 100%;
	}
	
		.overlay .container
		{
			height: 100%;
			max-width: 90%;
		}
	
	.overlay .overlayheight
	{
		display: table;
		width: 100%;
		height: 100%;
	}
	
		.overlay .overlayheight .overlaycentre
		{
			position: relative;
            display: table-cell;
			vertical-align: middle;
			text-align: left;
		}
		
.overlay ul
{
	float: left;
	width: 100%;
	margin: 0;
	list-style-type: none;
}

	.overlay ul li
	{
		float: left;
		width: 100%;
	}

	.overlay .overlaycentre > ul >  li:first-child
	{
		border-top: 0;
	}
		
		.overlay ul li a
		{
			float: left;
			width: 100%;
			color: var(--white);
			font-size: 1.4em;
			line-height: 1.1em;
			font-weight: 700;
			text-transform: none;
			text-decoration: none;
			padding: 5px 10px;
            letter-spacing: 0em;
			font-family: "Outfit";
		}

            .overlay ul li a:hover
            {
                text-decoration: none;
            }
            
            .overlay ul li.active > a
            {
                color: var(--lightgreen) !important;
            }

		.overlay ul ul
		{
			margin-bottom: 10px;
		}
		
		.overlay ul ul li a
		{
			float: left;
			width: 100%;
			color: var(--white);
			font-size: 1.1em;
			line-height: 1em;
			font-weight: 700;
			text-transform: none;
			padding: 4px 0;
		}
		
.overlay ul:hover li a
{
	color: var(--white);
}

	.overlay ul:hover li a:hover
	{
		color: var(--lightgreen);
	}

/* ==================================================
   Searchbox
================================================== */

.sb-search
{
	position: relative;
	float: left;
	width: 100%;
}

	.sb-search form
	{
		float: left;
		width: 100%;
	}
	
		.sb-search form input.sb-search-input
		{
			float: left;
			width: 100%;
			height: 55px;
			background: #E5E5E5;
			padding: 0 70px 0 15px;
			line-height: 1em;
			font-size: 0.95em;
			border: 1px solid #E5E5E5;
			outline: none;
			font-family: inherit;
			
			-webkit-appearance: none;
			
			-webkit-border-radius: 0;
			-moz-border-radius: 0;
			border-radius: 0;
			
            -webkit-transition: all 0.2s ease-in-out;
            -moz-transition: all 0.2s ease-in-out;
            -ms-transition: all 0.2s ease-in-out;
            -o-transition: all 0.2s ease-in-out;
			
            outline: none;
		}
		
			.sb-search form input.sb-search-input:focus
			{
                box-shadow: 0 0 5px rgba(243,139,0,1);
                border: 1px solid rgba(243,139,0,1);
			}
		
		.sb-search form button.formbutton
		{
			position: absolute;
			top: 0;
			right: 0;
			width: 100%;
			height: 55px;
			max-width: 55px;
			line-height: 1em;
			font-size: 1.3em;
			background: var(--hydrogreen);
			color: var(--white);
			border: none;
			cursor: pointer;
		}
		
/* ==================================================
   Contact Form
================================================== */

.wpcf7-form-control-wrap { display: block !important; }
.wpcf7-spinner { display: none !important; }
.wpcf7-not-valid-tip { 
    background: #E8222D;
    color: #FFF;
    padding: 8px;
    font-size: 14px;
    margin-top: -10px;
    margin-bottom: 10px;
}

/* Base style for the response box */
.wpcf7-response-output {
    margin: 20px 0 !important;
    padding: 15px 20px !important;
    border-radius: 4px;
    font-weight: 500;
    text-align: center;
    border: 2px solid transparent; /* Placeholder for status colors */
}

/* 1. Validation Error (The "One or more fields" message) */
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.unconfirmed .wpcf7-response-output {
    background-color: #fff5f5;
    border-color: #ff5e5e;
    color: #d93025;
}

/* 2. Success Message (Thank you for your message) */
.wpcf7-form.sent .wpcf7-response-output {
    background-color: #f0fdf4;
    border-color: #22c55e;
    color: #15803d;
}

/* 3. Spam or Technical Error Message */
.wpcf7-form.spam .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output {
    background-color: #fffbeb;
    border-color: #f59e0b;
    color: #b45309;
}

.quform-outer .form-check
{
    padding: 0 !important;
}

.quform-outer
{
    width: 100%;
    padding: 0;
    margin: 0;
}

.quform-outer input[type=text],
.quform-outer input[type=tel],
.quform-outer input[type=email],
.quform-outer textarea {
    padding: 1em;
    width: 100%;
    border: 0;
    background: #FFF;
    text-align: left;
    margin: 0 0 10px 0;
    font-family: inherit;
    font-weight: 400;
    font-size: 16px !important;
    color: #444;
    outline: 0;
    appearance: none;
    transition: all 0.2s ease-in-out;
    
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}

.quform-outer input:focus,
.quform-outer textarea:focus
{
    box-shadow: 0 0 5px rgba(0,159,165,1);
    border: 0 !important;
}

.quform-outer textarea
{
    height: 180px;
    transition: height 0.2s linear;
}

.quform-outer textarea:focus
{
    height: 200px;
}

.quform-outer label
{
    display: block;
    font-weight: 700;
    font-size: 0.95em;
    margin-bottom: 8px !important;
}

.quform-outer label.nobold
{
    font-weight: 500;
    font-size: 0.9em;
    line-height: 1em !important;
    display: inline;
}

.quform-required
{
    color: #e74c3c;
}

.quform-submit .newbutton
{
    margin-top: 20px;
}



