/* ==================================================
   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: #222222;
    --lightgrey: #EEEEEE;
    --lightergrey: #F5F5F5;
    --white: #FFFFFF;
    
    --orange: #89001a;
    --darkorange: #750016;
    --grey: #222222;
}

/* ==================================================
   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: "Barlow", Arial, Verdana, Helvetica, sans-serif !important;
	font-size: 0.94em !important;
	line-height: 1.2em !important;
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}

	.cc-window .cc-message
	{
		padding-right: 20px !important;
	}

@media only screen and (max-width: 414px)
{
	
	.cc-window .cc-message
	{
		padding-right: 0px !important;
	}
	
}

/* ==================================================
   Misc Styles
================================================== */

.redtext
{
    color: var(--orange);
    font-size: 115%;
    line-height: 1.4em;
    font-family: "Tilt Warp";
}

/* ==================================================
   Images
================================================== */

img
{
	display: block;
	
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-ms-backface-visibility: hidden;
	
	outline: 1px solid transparent;
}

/* ==================================================
   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 20px 0;
}

	.section p.largertext
	{
		font-size: 130%;
	}

.section strong, .section b
{
	font-weight: 700;
}

.section em, .section i
{
	font-style: italic;
}

.section h1, .section h2, .section h3, .section h4, .section h5, .section h6
{
	margin: 0 0 20px 0;
    text-transform: none;
    font-family: "Tilt Warp";
    font-weight: 400;
	line-height: 1em;
}

	.section h1
	{
		font-size: 2.2em;
	}
	
	.section h2
	{
		font-size: 1.8em;
	}
	
	.section h3
	{
		font-size: 1.7em;
	}
	
	.section h4
	{
		font-size: 1.6em;
	}
	
	.section h5
	{
		font-size: 1.5em;
	}
	
	.section h6
	{
		font-size: 1.4em;
	}

.section hr
{
	clear: both;
	border: 0;
	height: 0;
	margin: 0 0 25px 0;
	border-top: 1px dotted #DDD;
}

.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: 800px;
}

.nothome .fancyhr
{
    display: flex;
    width: 100%;
    max-width: 100%;
}

.nothome #homepageimgbanner .fancyhr
{
    max-width: 800px;
}

    .hr-line
    {
        width: 100%;
        position: relative;
        margin: 15px;
        border-bottom: 1px dotted rgba(0,0,0,0.4);
    }
    
        .hr-line.white-line
        {
            border-bottom: 1px dotted rgba(255,255,255,0.4);
        }
    
    .fa-solid
    {
        position: relative;
        top: 3px;
        font-size: 1.6em;
        color: var(--orange);
    }
			
/* ==================================================
   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: 3;
        -webkit-columns: 3;
        -moz-columns: 3;
    }

        .onecolumn ul li, 
        .twocolumns ul li, 
        .threecolumns ul li
        {
            position: relative;
            padding-left: 0;
            line-height: 1.4em;
            padding-top: 6px;
            padding-bottom: 6px;
        }
        
            .onecolumn ul li::before, 
            .twocolumns ul li::before, 
            .threecolumns ul li::before
            {
                position: relative;
                padding-right: 10px;
                font-family: "Font Awesome 6 Free"; font-weight: 900; content: "\f14a";
                color: var(--orange);
            }
            
@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;
    }
    
}

/* ==================================================
   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: 12px 15px;
	margin: 0;
	overflow: hidden;
	width: auto;
	max-width: auto;
	text-decoration: none !important;
	border: none; 
	font-size: 1em !important;
	text-align: center;
	font-weight: 400 !important;
	font-family: "Tilt Warp";
	text-transform: uppercase;
	line-height: 1em;
	color: #FFF !important;
	cursor: pointer;
	letter-spacing: 0.08em;
	
	-webkit-border-radius: 0px;
	-moz-border-radius: 0px;
	border-radius: 0px;
	
	-webkit-appearance: none;

	background: var(--orange);
	background-image: linear-gradient(to bottom, transparent 50%, var(--darkorange) 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%;
		color: #FFF !important;
	}
	
		.mybutton.fullbutton
		{
			width: 100%;
		}

.mybutton.fullbutton
{
	max-width: 100%;
}

.mybutton.whitebutton
{
	background: var(--white);
	color: var(--orange) !important;
	background-image: linear-gradient(to bottom, transparent 50%, var(--white) 50%);
	background-size: 100% 200%;
}

	.mybutton.whitebutton:hover
	{
		background-position: 0 -100%;
		color: var(--orange) !important;
	}

/* ==================================================
   Loading screen
================================================== */

#spinner
{
    background: var(--orange);
    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; }
}

/* ==================================================
   Scrolltop Button
================================================== */

.scrollToTop
{
	position: fixed;
	display: none;
	bottom: 20px;
	right: 20px;
	background: var(--darkorange);
	width: 42px;
	height: 42px;
	text-align: center;
	line-height: 42px;
	font-size: 1em;
	text-decoration: none;
	z-index: 997;
	font-weight: 300;
	
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

	.scrollToTop span
	{
		color: var(--white) !important;
        font-weight: 300;
		font-size: 1.2em;
	}

