/* ==================================================
   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: #000000;
    --lightgrey: #EEEEEE;
    --lightergrey: #F5F5F5;
    --midgrey: #AAAAAA;
    --white: #FFFFFF;
    --darkgrey: #151515;
    --primarycolour: #053622;
    --primarycolourlight: #075234;
	--primarycolourlighter: #10b16f;
    
    --fontprimary: "Catamaran";
    --fontsecondary: "Source Sans 3";
    
}

.bg-lightgrey
{
    background: var(--lightergrey);
}

.colour-green
{
    color: var(--primarycolourlighter);
}

.fontheading
{
	font-weight: 800 !important;
	font-family: var(--fontprimary), Arial, Verdana, Helvetica, sans-serif !important;
    letter-spacing: -0.01em;
}

/* ==================================================
   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:800px){.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: "var(--fontsecondary)", Arial, Verdana, Helvetica, sans-serif !important;
	font-size: 0.9em !important;
	line-height: 1.1em !important;
	padding-top: 20px !important;
	padding-bottom: 20px !important;
}

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

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

/* ==================================================
   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(--primarycolour);
    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(--primarycolourlighter);
	
	-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; }
}

/* ==================================================
   LazySizes
================================================== */

.lazyloading:not(iframe)
{
	opacity: 0;
}

.lazyloaded
{
	opacity: 1;
	transition: 400ms opacity;
}

[data-expand].lazyload
{
	opacity: 0;
	transform: scale(0.8);
}

[data-expand].lazyloaded
{
	opacity: 1;
	transition: all 700ms;
	transform: scale(1);
}

img.lazyloaded, 
img.lazyload
{
	display: block;
	width: 100%;
	max-width: 1000px;
}

/** <img class="lazyload" src="images/img-small.jpg" data-srcset="images/img-small.jpg 768w, images/img-large.jpg 1024w" alt="" /> **/

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

.section p
{
	margin: 0 0 25px 0;
	overflow-wrap: break-word;
}

	.section .largertext
	{
		font-size: 130%;
		font-family: var(--fontprimary), Arial, Verdana, Helvetica, sans-serif !important;
		font-weight: 800 !important;
	}

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

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

h1, h2, h3, h4, h5, h6
{
	margin: 0 0 30px 0;
	font-weight: 800 !important;
	font-family: var(--fontprimary), Arial, Verdana, Helvetica, sans-serif !important;
	line-height: 1em;
    letter-spacing: -0.01em;
}

	h1
	{
		font-size: 2em;
	}
	
	h2
	{
		font-size: 1.8em;
	}
	
    	h2 span
    	{
    		color: var(--primarycolour);
    	}
	
	h3
	{
		font-size: 1.6em;
	}
	
	h4
	{
		font-size: 1.4em;
	}
	
	h5
	{
		font-size: 1.3em;
	}
	
	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(--primarycolour);
	}

    #footercont.section hr
    {
        border-top: 1px solid rgba(255,255,255,0.1);
    }
    
/* ==================================================
   Tick UL list
================================================== */

#maincont .tickmenu ul
{
	margin: 0 0 20px 30px;
	padding: 0;
	list-style-type: none;
}

	#maincont .tickmenu ul li
	{
		margin-bottom: 8px;
		font-weight: 400;
	}

		#maincont .tickmenu ul li:before
		{
			content: '\f418';
			font-family: 'Genericons';
			float: left;
			font-size: 1.6em;
			font-weight: 400;
			color: var(--primarycolour);
			margin-left: -32px;
		}

@media only screen and (max-width: 768px)
{

	.panel-grid #maincont .tickmenu .so-widget-sow-editor:first-child ul
	{
		margin-bottom: 0 !important;
	}

}
    
#maincont ul.tickulnormal
{
	margin: 0 0 20px 30px;
	list-style-type: none;
}

	#maincont ul.tickulnormal.nobottom
	{
		margin: 0 0 0 30px;
	}
	
		#maincont ul.tickulnormal li
		{
			margin-bottom: 8px;
			line-height: 1.6em;
		}
	
			#maincont ul.tickulnormal li:before
			{
				content: '\f418';
				font-family: 'Genericons';
				float: left;
				font-size: 1.6em;
				color: var(--primarycolour);
				margin-left: -32px;
			}
    
p.caption
{
    margin-bottom: 0;
    line-height: 1.2em;
    color: #666;
    font-size: 70%;
    letter-spacing: 0.02em;
}
    
.section .dotteddivider
{
    display: block;
    margin: 0 auto;
    margin-top: 20px;
    width: auto;
}

    .section .dotteddivider span
    {
        display: inline-block;
        width: 20px;
        height: 4px;
        background: var(--primarycolour);
        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;
			}
			
/* ==================================================
   Fancy HR
================================================== */

.home .fancyhr
{
    display: flex;
    width: 100%;
    max-width: 500px;
}

.nothome .fancyhr
{
    display: flex;
    width: 100%;
    max-width: 100%;
}

.nothome #homepageimgbanner .fancyhr
{
    max-width: 500px;
}

    .fancyhr .hr-line
    {
        width: 100%;
        position: relative;
        margin: 15px;
        border-bottom: 1px solid var(--primarycolourlighter);
    }
    
        #homepageimgbanner .hr-line
        {
            border-bottom: 1px solid rgba(255,255,255,0.3);
        }
    
    .fancyhr .fa-solid
    {
        position: relative;
        top: 3px;
        font-size: 1.4em;
        color: var(--primarycolourlighter);
    }
			
/* ==================================================
   Columns
================================================== */

#maincont ul.splitul2 
{
    -webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
}

	#maincont ul.splitul2 li
	{
        padding-right: 30px;
        break-inside: avoid-column;
	}
		
#maincont ul.splitul3
{
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
}

	#maincont ul.splitul3 li
	{
        padding-right: 30px;
        break-inside: avoid-column;
	}
		
@media only screen and (max-width: 768px)
{

	#maincont ul.splitul3
	{
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
	}
	
}

@media only screen and (max-width: 576px)
{

	#maincont ul.splitul2
	{
        -webkit-column-count: 1;
        -moz-column-count: 1;
        column-count: 1;
	}
	
    	#maincont ul.splitul2 li
    	{
            padding-right: 0;
    	}
	
	#maincont ul.splitul3
	{
        -webkit-column-count: 1;
        -moz-column-count: 1;
        column-count: 1;
	}

        #maincont ul.splitul3 li
    	{
            padding-right: 0;
    	}

}

/* ==================================================
   Parent Page Styles
================================================== */

#maincont .parentcont
{
    
}

    #maincont .parentcont a
    {
        background: var(--lightgrey);
        text-decoration: none;
    }
    
        #maincont .parentcont a:hover
        {
            background: #E5E5E5;
            text-decoration: none;
        }

    #maincont .parentcont a h3
    {
        color: var(--primarycolourlight);
    }

    #maincont .parentcont a p
    {
        color: var(--darkgrey);
        opacity: 0.75;
    }
    
        #maincont .parentcont a:hover p
        {
            color: var(--darkgrey);
        }
            
            #maincont .parentcont a p span
            {
                color: var(--primarycolourlight) !important;
                display: block;
                font-family: var(--fontprimary) !important;
                font-size: 0.8em;
                margin-top: 15px;
                letter-spacing: 0.05em;
                font-weight: 800;
                text-transform: uppercase;
                opacity: 1;
            }
            
/* ==================================================
   Page CTA Section
================================================== */

#maincont .featuretextbox
{
    background: var(--lightgrey);
    color: var(--dark);
}

    #maincont .featuretextbox a:hover
    {
        color: var(--dark);
        text-decoration: underline;
    }
    
#maincont .featuretext
{
    font-size: 120%;
	font-family: var(--fontprimary), Arial, Verdana, Helvetica, sans-serif !important;
	font-weight: 700 !important;
}

    #maincont .featuretext p:last-child
    {
        margin-bottom: 0;
    }

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

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

.imgleftdiv
{
    float: left;
    max-width: 280px;
    margin: 0 20px 15px 0;
}
	
    .imgleftdiv img
	{
        width: 100%;
        display: block;
        margin: 0 0 8px 0;
    }
        
.imgrightdiv
{
    float: right;
    margin: 0 0 15px 20px;
}
        
    .imgrightdiv img
	{
        width: 100%;
        display: block;
        margin: 0 0 8px 0;
    }

.imgfull
{
	width: 100%;
}

@media only screen and (max-width: 768px)
{
	
	.imgleftdiv
	{
		float: none;
		margin: 0 0 20px 0;
	}
	
	.imgrightdiv
	{
		float: none;
		margin: 0 0 20px 0;
	}
	
}

/**

<div class="imgrightdiv" style="max-width:400px">
	<img src="https://unsplash.it/600/400/?random" alt="">
</div>

**/

/* ==================================================
   Button
================================================== */

.mybutton
{
	position: relative;
	display: inline-block;
	padding: 17px 23px !important;
	margin: 0 !important;
	overflow: hidden;
	width: auto;
	max-width: auto;
	text-decoration: none !important;
	border: none; 
	font-size: 1em !important;
	text-align: center;
	font-weight: 800 !important;
	font-family: var(--primary);
	text-transform: none;
	line-height: 1em !important;
	color: var(--white) !important;
	cursor: pointer;
	letter-spacing: 0em !important;
	
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
	
	-webkit-appearance: none;

	background: var(--primarycolourlighter);
	background-image: linear-gradient(to bottom, transparent 50%, var(--primarycolourlight) 50%);
	background-size: 100% 200%;
	
	-webkit-transition: background 200ms cubic-bezier(0.77, 0, 0.175, 1);
	transition: background 200ms cubic-bezier(0.77, 0, 0.175, 1);
}

	.mybutton:hover
	{
		background-position: 0 -100%;
	}
	
.mybutton span
{
    display: flex;
    align-items: center;
}

    .mybutton span i
    {
        font-style: normal !important;
        font-size: 0.9em !important;
        margin-top: 0px !important;
        color: var(--white) !important;
        font-weight: 800 !important;
    }

/* ==================================================
   Scrolltop Button
================================================== */

.scrollToTop
{
	position: fixed;
	display: none;
	bottom: 20px;
	right: 20px;
	background: var(--primarycolourlighter);
	width: 42px;
	height: 42px;
	text-align: center;
	line-height: 42px;
	font-size: 1em;
	text-decoration: none;
	z-index: 997;
	font-weight: 300;
	cursor: pointer;
	
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

	.scrollToTop i
	{
		color: var(--white) !important;
        font-weight: 600;
		font-size: 1em;
		font-style: normal;
	}

/* ==================================================
   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(--primarycolour);
	color: var(--white);
	top: 0;
	left: 0;
	width: 100%;
	height: 0%;
	opacity: 1;
	padding-top: 30px;
	padding-bottom: 0px;
	visibility: hidden;
	overflow: hidden;
	overflow-y: auto;
	
	-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 0 30px 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.5em;
			line-height: 1.3em;
			font-weight: 800;
			text-align: center;
			padding: 3px 10px;
            letter-spacing: 0em;
            text-decoration: none !important;
			font-family: var(--fontprimary), Arial, Verdana, Helvetica, sans-serif !important;
		}

            .overlay ul li a:hover
            {
                text-decoration: none;
            }
            
        	.overlay ul > li.current_page_item > a, 
        	.overlay ul > li.current_page_parent > a, 
        	.overlay ul > li.current-page-ancestor > a
            {
                color: var(--primarycolourlighter) !important;
            }

		.overlay ul ul
		{
			margin: 0px;
			padding: 5px 0;
		}
		
		.overlay ul ul li a
		{
			float: left;
			width: 100%;
			color: var(--white);
			font-size: 1em;
			line-height: 1.1em;
			font-weight: 600;
			padding: 2px 0;
		}
		
.overlay ul:hover li a
{
	color: var(--white);
}

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


/* ==================================================
   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(1,116,190,1);
                border: 1px solid rgba(1,116,190,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(--primarycolour);
			color: var(--white);
			border: none;
			cursor: pointer;
		}

/* ==================================================
   Blog Styles
================================================== */

#maincont .blogdiv
{
	padding-top: 10px;
	margin: 0 0 30px 0;
}

	#maincont .blogdiv p:last-child
	{
		margin: 0;
	}
	
@media only screen and (max-width: 768px)
{
	
	#maincont .blogdiv img
	{
		margin-bottom: 20px;
	}
	
}

#maincont .metadetails
{
	margin: -10px 0 15px 0;
}

	#maincont .metadetails ul
	{
		list-style-type: none;
		margin: 0;
		padding: 0;
	}
	
		#maincont .metadetails ul li
		{
			display: block;
			float: left;
			padding: 0;
			margin-right: 15px;
			font-size: 90%;
			text-indent: 0;
		}
		
		#maincont .metadetails ul li:before
		{
			display: none;
		}
		
			#maincont .metadetails ul li span
			{
				font-weight: 700;
				line-height: 16px;
			}

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

#maincont .socialicons
{
	float: left;
	width: 100%;
	margin: 0 0 10px 0;
}

	#maincont .socialicons ul
	{
		float: left;
		list-style-type: none;
		width: 100%;
		
		width: -moz-calc(100% + 20px);
		width: -webkit-calc(100% + 20px);
		width: -o-calc(100% + 20px);
		width: calc(100% + 20px);
		
		margin: 0 -10px;
		padding: 0;
	}
	
		#maincont .socialicons ul li
		{
			float: left;
			width: 20%;
			padding: 0 10px;
			margin: 0 0 20px 0;
			text-indent: 0;
		}

		#maincont .socialicons ul li:before
		{
			display: none;
		}
		
			#maincont .socialicons ul li a
			{
				float: left;
				width: 100%;
				text-align: center;
				font-size: 1.4em;
				line-height: 1em;
				color: var(--primarycolour);
				padding: 12px 0;
					
				background-size: 100% 200%;
				background-image: linear-gradient(to top, var(--primarycolour) 50%, rgb(1,116,190,0.15) 50%);
				
				-webkit-transition: background-position 0.2s, color 0.2s;
				-moz-transition: background-position 0.2s, color 0.2s;
				transition: background-position 0.2s, color 0.2s;
			}
			
				#maincont .socialicons ul li a:hover
				{
					background-position: 50% -100%;
					color: #FFF;
				}

@media only screen and (max-width: 992px)
{
	
	#maincont .socialicons ul li
	{
		width: 33.33%;
	}
	
}

@media only screen and (max-width: 576px)
{
	
	#maincont .socialicons ul li
	{
		width: 33.33%;
	}
	
}

/* ==================================================
	Tags
================================================== */

#tagscont
{
	float: left;
	width: 100%;
}

	#tagscont ul
	{
		float: left;
		width: 100%;
		margin: 0 0 10px 0;
	}
	
		#tagscont ul li
		{
			float: left;
			list-style-type: none;
			margin: 0 10px 10px 0;
			padding: 0 !important;
			text-indent: 0 !important;
		}

			#tagscont ul li:before
			{
				display: none;
			}

				#tagscont ul li a
				{
					float: left;
					width: 100%;
					text-align: center;
					font-size: 1em;
					line-height: 1em;
					color: var(--primarycolour);
					padding: 10px 14px;
					font-weight: 800;

					background-size: 100% 200%;
					background-image: linear-gradient(to top, var(--primarycolour) 50%, rgb(1,116,190,0.15) 50%);

					-webkit-transition: background-position 0.2s, color 0.2s;
					-moz-transition: background-position 0.2s, color 0.2s;
					transition: background-position 0.2s, color 0.2s;
				}

					#tagscont ul li a:hover
					{
						background-position: 50% -100%;
						color: #FFF;
						text-decoration: none;
					}

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

.alignleft
{
	float: left;
	margin: 10px 20px 10px 0;
}

.alignright
{
	float: right;
	margin: 10px 0 10px 20px;
}

.aligncenter
{
	clear: both;
	display: block;
	margin: 10px auto;
}

a.fancybox img
{
	-webkit-transition: opacity 0.1s ease-out 0.05s;
	-moz-transition: opacity 0.1s ease-out 0.05s;
	-o-transition: opacity 0.1s ease-out 0.05s;
	transition: opacity 0.1s ease-out 0.05s;
}

	a:hover.fancybox img
	{
		opacity: 0.7;
	}

.wp-caption
{
	margin-bottom: 20px;
}

	.wp-caption p.wp-caption-text
	{
		margin-top: 10px;
		font-size: 0.85em;
		font-style: normal;
		line-height: 1.3em;
		color: #767676;
		
		-webkit-box-sizing: border-box;
		-moz-box-sizing:    border-box;
		box-sizing:         border-box;
	}

@media only screen and (max-width: 768px)
{
	
	.imgwrap
	{
		float: left;
		width: 100%;
	}
	
	.alignleft
	{
		float: none;
		margin: 10px 0;
	}

	.alignright
	{
		float: none;
		margin: 10px 0;
	}

	.aligncenter
	{

	}
	
	.wp-caption
	{
		width: auto !important;
	}
	
}

/* ==================================================
   Search Box
================================================== */

.sb-search
{
	position: relative;
	float: left;
	width: 100%;
	margin: 0 0 20px 0;
}

	.sb-search form
	{
		float: left;
		width: 100%;
	}
	
		.sb-search form input.sb-search-input
		{
			float: left;
			width: 100%;
			height: 55px;
			background: #E5E5E5;
			border: 1px solid #E5E5E5;
			padding: 0 70px 0 15px;
			color: #222;
			line-height: 1em;
			font-size: 16px;
			outline: none;
			font-family: inherit;
			
			-webkit-border-radius: 0;
			-moz-border-radius: 0;
			border-radius: 0;

			-webkit-appearance: none;

			-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;
		}

			.sb-search form input.sb-search-input:focus
			{
				box-shadow: 0 0 5px rgba(1,116,190,1) !important;
				border: 1px solid rgba(1,116,190,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(--primarycolour);
			color: #FFF;
			border: none;
			cursor: pointer;
		}
		
    		.sb-search form button.formbutton:hover
    		{
    			background: var(--primarycolour);
    		}

/* ==================================================
   Image Gallery
================================================== */

.gallery
{
    display: flex !important;
    flex-wrap: wrap !important;
    /** justify-content: center !important; **/
    margin: -20px !important;
}

.gallery img
{
    display: block !important;
    width: 100% !important;
    max-width: 600px !important;
    height: auto !important;
    border: 0 !important;
}

.gallery .gallery-caption
{
    font-weight: 600 !important;
}

.gallery .gallery-item
{
    padding: 20px !important; /* Adjust this value as needed */
    box-sizing: border-box !important;
    width: 25% !important; /* Adjust this value as needed */
    max-width: 600px !important; /* Adjust this value as needed */
}

@media screen and (max-width: 992px)
{

    .gallery .gallery-item
    {
        width: 33.33% !important;
    }

}

@media screen and (max-width: 576px)
{
    
    .gallery .gallery-item
    {
        width: 50% !important;
    }

}

/* ==================================================
   Pagination
================================================== */

.pagination
{
	float: left;
	width: 100%;
	padding: 30px 0 20px 0;
}

	.pagination a
	{
		text-decoration: none !important;
	}

	.pagination a:hover
	{
		text-decoration: none !important;
	}

	.pagination .nav-links
	{
		float: left;
		width: 100%;
	}
	
		.pagination .nav-links .page-numbers
		{
			float: left;
			width: 100%;
			max-width: 46px;
			line-height: 46px;
			background: #E5E5E5;
			color: var(--primarycolour);
			text-align: center;
			font-size: 1.05em;
			font-weight: 700;
			font-family: inherit;
			margin-right: 10px;
		}
		
			.pagination .nav-links .page-numbers span
			{
				line-height: 40px;
			}
		
				.pagination .nav-links .page-numbers.current
				{
					background: var(--primarycolour);
					color: #FFF;
				}
				
				.pagination .nav-links a:hover.page-numbers
				{
					background: var(--primarycolour);
					color: #FFF;
				}
	
				.pagination .nav-links .page-numbers.dots
				{
					background: none;
					color: var(--primarycolour);
				}
				
/* ==================================================
   Contact Form
================================================== */

.cf7-acceptance-flex-wrapper label
{
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.cf7-acceptance-flex-wrapper input[type="checkbox"]
{
    flex-shrink: 0;
    margin-top: 0;
}

/** Warning/Success Messages **/

.wpcf7 form .wpcf7-response-output
{
    display: block;
    color: #FFF;
    font-size: 16px;
    padding: 16px;
    margin: 0 0 20px 0 !important;
    font-weight: 700;
    line-height: 1.3em;
    text-transform: uppercase;
    font-family: var(--bodyfont) !important;
	font-style: normal;
}

    .wpcf7 form.init .wpcf7-response-output
    {
    	display: none;
    }
    
    .wpcf7 form.sent .wpcf7-response-output
    {
    	background: #15B392 !important;
    	border: 0 !important;
    	color: #FFF;
    	font-weight: 700;
    }
    
    .wpcf7 form.failed .wpcf7-response-output, 
    .wpcf7 form.aborted .wpcf7-response-output, 
    .wpcf7 form.spam .wpcf7-response-output, 
    .wpcf7 form.invalid .wpcf7-response-output, 
    .wpcf7 form.unaccepted .wpcf7-response-output
    {
    	background: #FC2947 !important;
    	border: 0 !important;
    	color: #FFF;
    }

/** Main Styles **/

.screen-reader-response
{
    display: none;
}

.wpcf7-list-item
{
    margin: 0 !important;
}

.wpcf7-form
{
    background: none;
}

.wpcf7-form label
{
    font-weight: 700;
}

.gdrpbox label
{
    overflow: hidden;
}

    .gdrpbox label input[type="checkbox"]
    {
        display: inline-block;
        margin-right: 10px;
    }

    .gdrpbox label span
    {
        display: block;
        font-weight: 400;
        font-size: 15px;
        line-height: 1em !important;
    }

.wpcf7-form .reqstar
{
    font-weight: 700;
    color: #FC2947;
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea, 
.wpcf7-form select
{
    display: block;
    width: 100%;
    padding: 12px 16px;
    margin: 0;
    border: 2px solid #FFF;
    font-size: 16px;
    background: #FFF;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color 0.3s ease;
    
    -webkit-appearance: none;
    
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}

.wpcf7-form option
{
    font-family: inherit !important;
    font-size: 15px;
}

    .wpcf7-form input[type="text"]:focus,
    .wpcf7-form input[type="email"]:focus,
    .wpcf7-form input[type="tel"]:focus,
    .wpcf7-form textarea:focus
    {
        border-color: #10b16f;
        outline: none;
    }
    
        .wpcf7-form textarea
        {
            height: 180px;
            margin: 0 !important;
            transition: height 0.3s ease;
        }
        
            .wpcf7-form textarea:focus
            {
                height: 200px;
            }

.wpcf7-not-valid-tip
{
    display: inline-block;
    background: #FC2947;
    color: #FFF;
    font-size: 15px;
    padding: 10px;
    font-weight: 600;
    line-height: 1em;
    width: 100%;
}

