@charset "utf-8";
/* CSS Document */

/* v1.0 | 20080212 */
html, body, div, footer, header, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, address, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, 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, input {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	text-decoration: none;
	font-style: normal;
}

header, footer, article, section, div {
	position: relative;
}

.static {
	position: static;
}

article, aside, details, figcaption, figure, footer, header, hcollection, menu, nav, section {
display: block;
}


ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

/* remember to define focus styles! */
:focus {
	outline: 0;
}

/* remember to highlight inserts somehow! */
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}

/* tables still need 'cellspacing="0"' in the markup */
table {
	border-collapse: collapse;
	border-spacing: 0;
    font-size: inherit;
}


html, body {
}

body {
    height: 100%;
	line-height: 1;
	font-size: 20px;
}

small, sub, sup { font-size: 50%; line-height: 100% !important;}
sub             { vertical-align: sub !important; }
sup             { vertical-align: super !important;}



/* Display */
.mobileonly {display: none;}
.nomobile {display: block;}
.nobobileinblock {display: inline-block;}
.nomobileinline {display: inline;}
.invisible {display: none !important;}
.printonly,.lazy {display: none;}
.inline {display: inline-block !important;}

br.notmobile {display: inline-block;}
br.clear {clear: both;}

/* Layout */
.halfleft,.halfright,.left,.right {top: 0;}
.left {float: left;}
.right {float: right;}
.textleft {text-align: left;}
.textright {text-align: right;}

.halfleft {
	float: left;
	width: calc(50% - 8px);
	margin-right: 8px;
}

.halfright {
	float: right;
	width: calc(50% - 8px);
	margin-left: 8px;
}

.narrowtext {
	width: 800px;
	margin: 0 auto 0 auto;
}

.topshadow, .botshadow {
	position: absolute;
	left: 0px;
	width: 100%;
	height: 15px;
	background-repeat: repeat-x;
	z-index: 95;
}

.topshadow {
	top: 0px;
	background-image: url('/img_root/drop-shadow_top.png');
}

.botshadow {
	bottom: 0;
	background-image: url('/img_root/drop-shadow_bottom.png');
}


/* POSITION */
.bottom {
	position: absolute;
	bottom: 0;
}

.blockcentre {margin: inherit auto;}


/* Text */
.textright {text-align: right;}
.textleft {text-align: left;}
.centre, .textcentre {text-align: center;}

.marg72 {margin-bottom: 72px !important;}
.marg64 {margin-bottom: 64px !important;}
.marg48 {margin-bottom: 48px !important;}
.marg42 {margin-bottom: 42px !important;}
.marg36 {margin-bottom: 36px !important;}
.marg32 {margin-bottom: 32px !important;}
.marg24 {margin-bottom: 24px !important;}
.marg20 {margin-bottom: 20px !important;}
.marg18 {margin-bottom: 18px !important;}
.marg16 {margin-bottom: 16px !important;}
.marg14 {margin-bottom: 14px !important;}
.marg12 {margin-bottom: 12px !important;}
.marg10 {margin-bottom: 10px !important;}
.marg8 {margin-bottom: 8px !important;}
.marg6 {margin-bottom: 6px !important;}
.marg4 {margin-bottom: 4px !important;}
.marg3 {margin-bottom: 2px !important;}
.marg0 {margin-bottom: 0px !important;} 

.premarg36 {margin-top: 36px !important;}
.premarg24 {margin-top: 24px !important;}
.premarg16 {margin-top: 16px !important;}
.premarg12 {margin-top: 12px !important;}
.premarg8 {margin-top: 8px !important;}
.premarg4 {margin-top: 4px !important;}

.padding16 {padding: 16px;}
.padding12 {padding: 12px;}
.padding12 {padding: 8px;}

/* TEXT */
.upper {text-transform: uppercase;}
.lower {text-transform: lowercase;}
.smallcaps {font-variant: small-caps;}
.italic {font-style: italic;}
.underline {text-decoration: underline;}

.white {color: #ffffff !important;}
.black {color: #000000 !important;}
.red {color: red !important;}

.point2 {font-size: 10% !important;}
.point8 {font-size: 40% !important;}
.point10 {font-size: 50% !important;}
.point12 {font-size: 60% !important;}
.point13 {font-size: 65% !important;}
.point14 {font-size: 70% !important;}
.point15 {font-size: 75% !important;}
.point16 {font-size: 80% !important;}
.point18 {font-size: 90% !important;} 
.point20 {font-size: 100% !important;}
.point22 {font-size: 110% !important;}
.point24 {font-size: 120% !important;}
.point26 {font-size: 130% !important;}
.point28 {font-size: 140% !important;}
.point30 {font-size: 150% !important;}
.point32 {font-size: 160% !important;}
.point34 {font-size: 170% !important;}
.point36 {font-size: 180% !important;}
.point48 {font-size: 240% !important;}
.point60 {font-size: 300% !important;}

.letterspace1 {letter-spacing: 1px;}
.letterspace2 {letter-spacing: 2px;}
.letterspace3 {letter-spacing: 3px;}
.letterspace4 {letter-spacing: 4px;}

.weight100 {font-weight: 100;}
.weight300 {font-weight: 300;}
.weight400 {font-weight: 400;}
.weight500 {font-weight: 500;}
.weight600 {font-weight: 600;}
.weight700 {font-weight: 700;}
.weight800 {font-weight: 800;}
.weight900 {font-weight: 900;}

.line100 {line-height: 100%;}
.line110 {line-height: 110%;}
.line120 {line-height: 120%;}
.line130 {line-height: 130%;}
.line140 {line-height: 140%;}
.line150 {line-height: 150%;}

.letterspace1 {letter-spacing: 1px;}
.letterspace2 {letter-spacing: 2px;}
.letterspace4 {letter-spacing: 4px;}
.letterspace8 {letter-spacing: 8px;}
.letterspace10 {letter-spacing: 10px;}
.letterspace12 {letter-spacing: 12px;}


/* OPACITY */
.opacity30{opacity: 0.30; filter: alpha(opacity =30);}
.opacity30{opacity: 0.50; filter: alpha(opacity =50);}
.opacity30{opacity: 0.70; filter: alpha(opacity =70);}
.opacity30{opacity: 0.80; filter: alpha(opacity =80);}
.opacity30{opacity: 0.90; filter: alpha(opacity =90);}
.opacity30{opacity: 1.00; filter: alpha(opacity =100);}

.hoveropp, .hoveropp:active {opacity: 0.9; filter: alpha(opacity=90);}
.hoveropp:hover, .hoveropp:focus {opacity: 1; filter: alpha(opacity=100);}

/* Forms */
.width35 {width: 35px;}
.width50 {width: 50px;}
.width60 {width: 60px;}
.width75 {width: 75px;}
.width100 {width: 100px;}
.width150 {width: 150px;}
.width200 {width: 200px;}
.width250 {width: 250px;}
.width300 {width: 300px;}
.width400 {width: 400px;}
.width500 {width: 500px;}
.widthfull {width: 100%;}

/* CORNERS */
.allcorn {
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.botcorn {
	-webkit-border-bottom-right-radius: 5px;
	-webkit-border-bottom-left-radius: 5px;
	-moz-border-radius-bottomright: 5px;
	-moz-border-radius-bottomleft: 5px;
	border-bottom-right-radius: 5px;
	border-bottom-left-radius: 5px;
}

.topcorn {
	-webkit-border-top-left-radius: 5px;
	-webkit-border-top-right-radius: 5px;
	-moz-border-radius-topleft: 5px;
	-moz-border-radius-topright: 5px;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}

.leftcorn {
	-webkit-border-top-left-radius: 5px;
	-webkit-border-bottom-left-radius: 5px;
	-moz-border-radius-topleft: 5px;
	-moz-border-radius-bottomleft: 5px;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
}

.rightcorn {
	-webkit-border-top-right-radius: 5px;
	-moz-border-radius-topright: 5px;
	border-top-right-radius: 5px;
	-webkit-border-bottom-right-radius: 5px;
	-moz-border-radius-bottomright: 5px;
	border-bottom-right-radius: 5px;
}


/* v1.0 | 2020-02-24 */

body {
	-webkit-font-smoothing:antialiased;
	background-repeat: repeat-x;
	text-align: center;
}
body.topmargin {margin-top: 143px;}

.loadingimg {
	background-image: url('img_root/loading.svg');
	background-position: center;
	background-repeat: no-repeat;
}

.sitecontent, .fullcontent {
	min-height: 300px;
	margin: 0px auto;
	padding: 48px 72px;
}

/*General Text*/
h2 a,h3 a,h4 a,h5 a,h6 a,p,.bodyfont {text-transform: none;}

.blockhead {
	display: block;
	margin: 0;
	padding: 8px 0;
}

a {transition: 0.5s;}

p, address, ul {
	font-size: 80%;
	line-height: 140%;
}


/* Lists */
ul.bodylist {
	font-size: 80%;
	list-style-type: disc;
	list-style-position: inside;
}

ul.bodylist li {line-height: 130%;}
ul li ul {font-size: 100%;}


/* Forms */
div.formrow {padding: 2px 0; margin-bottom: 16px;}

label {
	display: block;
	padding: 3px;
	font-size: 80%;
	line-height: 140%;
	vertical-align: middle;
}

label span.error {
	display: inline-block;
	font-size: 12px;
	padding: 0 8px;
	border-radius: 10px;
	margin-left: 5px;
	top: 0;
	right: 0;
}

select, input, textarea {
	border-width: 1px;
	border-style: solid;
	font-size: 70%;
	margin-left: 3px;
	padding: 5px;
	text-align: center;
	vertical-align: middle;
}

input {height: 20px;}
select {height: 32px;}

input[type="file"] {
	border:	none;
	background-color: transparent;
}

textarea {
	height: 200px;
	width: 400px;
}

button,.button {
	border-width:1px;
	border-style: solid;
	display:inline-block;
	cursor:pointer;
	font-size:70%;
	padding: 8px 18px;
	text-decoration: none;
	text-transform: uppercase;
}

.g-recaptcha {
	height: 78px;
	background: #f2f2f2 url('img_root/loading.svg') center no-repeat;
	display: inline-block;
	margin: 0 auto;
}

/* CMS Body Text */
.cmsbody h1,.cmsbody h2,.cmsbody h3,.cmsbody h4 {
	line-height: 140%;	
	margin-bottom: 16px;
}

.cmsbody h1 {font-size: 130%;}

.cmsbody h2,.cmsbody h3,.cmsbody h4 {margin-top: 32px;}

.cmsbody h2 {font-size: 120%;}
.cmsbody h3 {font-size: 110%;}
.cmsbody h4 {font-size: 100%;}

.cmsbody p {
	font-size: 80%;
	margin-bottom: 16px;
}

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

.cmsbody.point16 {
	font-size: 80%;
}

.cmsbody ul {
	font-size: 80%;
	margin-bottom: 12px;
	margin-top: -12px;
}

.cmsbody ul li {
	line-height: 120%;
	list-style-type: disc;
	list-style-position: inside;
	margin-bottom: 8px;
}


/* Header */
header {
	top: 0;
	left: 0;
	z-index: 100;
	padding-top: 15px;
	transition: 0s;
	border-bottom-style: solid;
}

header.smaller {
	padding-top: 0px;
	height: 52px;
	position: fixed;
	width: 100%;
}

section#mainlogowrap {
	/*width: 176px;*/
	height: 80px;
	width: auto;
	text-align: center;
	margin: 5px auto 8px auto;
}

section#mainlogowrap .sitelogo {
	display: inline-block;
	height: 80px;
	width: auto;
}

header.smaller section#mainlogowrap {
	float: left;
	height: 40px;
	margin-top: 5px;
	margin-left: 72px;
}

header.smaller section#mainlogowrap .sitelogo {
	float: left;
	height: 40px;
}

section#mainlogowrap .sitelogo path {
	transition: 0.5s;
}

/* Top Navigation */
nav#topnav {
	margin-left: 0px;
	height: 50px;
	display: block;
	text-align: center;
	transition: right 1s;
}

nav#topnav a {
	display: inline-block;
	position: relative;
	padding: 0px 8px;
	height: 50px;
	line-height: 50px;
	font-size: 80%;
	transition: 1s;
}


/* Sidenav */
#sidenavigation {
	z-index: 200;
	/*display: none;*/
	transform: translate(-250px);
	position: fixed;
	top: 0;
	width: 250px;
	height: 100%;
	z-index: 102;
	transition: 1s;
}

#sidenavigation.open {
	transform: translate(0px);
}

#sidenavopen, #sidenavclose {
	display: block;
	width: 24px;
	height: 4px;
	top: 14px;
	left: 14px;
	text-indent: -9999px;
	background-color: transparent;
	z-index: 101;
	border-top-style: double;
	border-top-width: 12px;
	border-bottom-style: solid;
	border-bottom-width: 4px;
	cursor: pointer;
}

#sidenavopen {position: fixed;}
#sidenavclose {position: absolute;}

#sidenavlogowrap {
	display: inline-block;
	width: 176px;
	height: auto;
	margin: 56px auto 24px auto;
}

#sidenavlogowrap .sitelogo {
	display: inline-block;
	width: 176px;
	height: auto;
}

nav#mainnav a {
	display: block;
	font-size: 80%;
	width: 100%;
	padding: 4px 0;
	height: auto;
	line-height: 1;
}


/* Footer */
footer {width: 100%;}

article#footercalendar, article#newsletter {
	padding: 30px 10px;
	margin: 0 auto;
	text-align: center;	
}

form#newsletterform input {
	display: inline;
	border: 0;
	width: 100px;
	height: 18px;
	padding: 8px 16px;
	margin: 0 2px 7px 2px;
}

form#newsletterform input#email {width: 200px;}

form#newsletterform input.button {
	cursor: pointer;
	height: auto;
}

#footercollections {padding: 48px 24px;}

#colourfooter {
	min-height: 100px;
	padding: 30px 80px 40px 80px;
	text-align: left;
}

section#footerlogowrap {
	display: inline-block;
	width: 155px;
	height: auto;
	margin-right: 30px;
	vertical-align: top;
}

section#footerlogowrap .sitelogo {
	display: inline-block;	
	width: 155px;
	height: auto;
}

section#footerlogowrap .sitelogo path {transition: 1s;}

footer div#smwrap {
	display: inline-block;
	margin: 0 40px;
	width: calc(100% - 475px);
}

section.footsitemapcol {
	display: inline-block;
	width: 180px;
	padding: 0 12px;
	vertical-align: top;
	margin-bottom: 16px;
}

section.footsitemapcol h2 {margin-left: 8px;}
ul.smlist {font-size: 75%;}
ul.smlist li a {
	display: block;
	position: relative;
	line-height: 100%;
	padding: 4px 8px;

}

.footersocial {
	float: right;
	top: 0px;
	width: 200px;
	vertical-align: top;
}

.footsociallink {font-size: 160%;}
.footsociallink i, .footsociallink svg {transition: 0.5s;}
.footsociallink:hover .fa-facebook {color: #4267B2;}
.footsociallink:hover .fa-twitter {color: #1DA1F2;}
.footsociallink:hover .fa-instagram {color: #5851DB;}
.footsociallink:hover .fa-linkedin {color: #2867B2;}
.footsociallink:hover .fa-pinterest {color: #BD081C;}

article#legalfooter {
	padding: 10px 80px;
	height: 40px;
	line-height: 40px;
}

section#legalfootleft {
	float: left;
	width: 400px;
	height: 40px;
	line-height: 40px;
	margin: 0;
	text-align: left;
}

section#legalfootleft p {
	display: block;
	height: 40px;
	line-height: 40px;	
}

section#legalfootleft a:hover, section#legalfootleft a:focus {text-decoration: none;}


section#footarg {
	float: right;
	display: inline-block;
	width: auto;
	height: 40px;
}

#arglink {
	display: inline-block;
	height: 40px;
	width: auto;
}

#backtotop {
	display: inline-block;
	position: fixed;
	bottom: 15px;
	right: 15px;
	width: 35px;
	padding: 6px;
	border-radius: 5px;
	opacity: 0;
	transition: 1s;
}

#backtotop:hover, #backtotop:focus {
	opacity: 1 !important;
	cursor: pointer;
}

#backtotop p {
	font-size: 70%;
	line-height: 100%;
	margin-bottom: 0;
	font-variant: small-caps;
}

#sliders {
	width: 100%;
	overflow: hidden;
	position: relative;
}
#sliderwrap {
	height: 600px;
	position: relative;
	transition:all 1.0s ease;
}

#sliders.sliderloading {
	display: inline-block;
	background: url('img_root/loading.svg') 50% 50% no-repeat;
}

.slider {
	height: inherit;
	display: block;
	position: relative;
	overflow: hidden;
	background-position: center;
	background-size: cover;
	float: left;
	opacity: 0;
}

.slidernav {
	position: absolute;
	top: 50%;
	margin-top: -30px;
	opacity: 0;
	vertical-align: center;
}

#navleft {left: 30px;}
#navright {right: 30px;}

#sliders:hover .slidernav {opacity: 0.7;}
.slidernav:hover, .slidernav:focus {
	cursor: pointer;
}
.slidernav:hover path, .slidernav:focus path {fill: #572d41;}

#navbars {
	position: absolute;
	display: inline-block;
	bottom: 15px;
	right: 15px;
}

span.clicknav {
	display: inline-block;
	width: 12px;
	margin: 0 5px;
	height: 12px;
	text-indent: -9999px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;	
	opacity: 0.6;
}

span.clicknav:hover, span.clicknav:focus {
	cursor: pointer;
	opacity: 1;
}

span.clicknav.selected {}

.slidertext {padding: 30px;}

.slidertext.stleft {
	position: absolute;
	max-width: 30%;
	top: 45%;
	left: 8%;
	text-align: left;
}

.slidertext.stright {
	position: absolute;
	max-width: 30%;
	top: 25%;
	right: 10%;
	text-align: right;
}

.slidertext.stcentre {
	position: relative;
	width: 20%;
	margin: 15% auto;
	text-align: center;
}

.slidertext.stbottom {
	position: absolute;
    display: block;
    width: calc(100% - 60px);
    bottom: 10%;
    text-align: center;
}


.slidertext h2 {
	display: inline-block;
	clear: both;
	padding: 10px;
	font-size: 140%;
	line-height: 120%;
	margin-bottom: 24px;
}

.slidertext p {
	display: inline-block;
	clear: both;
	font-size: 110%;
	padding: 10px;
}

.slidertext a {
	height: 40px;
	line-height: 40px;
	padding: 6px 12px;
	text-transform: uppercase;
	font-size: 18px;
}

.slidertext a svg {
	margin-right: 8px;
}

@media only screen and (max-width: 1000px) {
	.slidertext {
		width: 25%;
		top: 20%;
	}

	.slidertext h2 {font-size: 100%;}
	.slidertext p {font-size: 90%;}
	.slidertext a {font-size: 90%; height: 30px; line-height: 30px;}
}

@media only screen and (max-width: 840px) {
	#sliderwrap {
		height: 350px;
	}

	.slidertext.stleft, .slidertext.stright, .slidertext.stcentre,.slidertext.stbottom {
		max-width: calc(100% - 40px);
		width: calc(100% - 40px);
		text-align: center;
		padding: 20px;
		top: auto;
		bottom: 30%;
		left: 0%;
		right: 0%;
	}

	.slidertext h2 {
		font-size: 90%;
		margin-bottom: 12px;
	}

	.slidertext p {
		font-size: 80%;		
	}

	.slidertext a {
		line-height: 25px;
		height: 25px;
		font-size: 80% !important;
	}
}


/* Banner Images */
.bannerwrap {
	height: 350px;
	overflow: hidden;
}

img.bannerimg {
	height: 350px;
	width: 2500px;
	position: absolute;
	left: 50%;
	margin-left: -1250px
}

#bannersuccess {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	z-index: 802;
}

#bannersuccess h2 {
	margin-top: 20%;
	z-index: 999;
	padding: 10px;
}

.closebannerimg {display: none;}

/*Breadcrumbs*/
article#breadcrumbs {height: 33px;}
p.breadcrumbs {
	display: block;
	line-height: 33px;
}

p.breadcrumbs a {}
p.breadcrumbs a:hover, p.breadcrumbs a:focus {
	text-decoration: none;
}


/* Albums & Collections */
.collectionpanel, .albumpanel {
	display: inline-block;
	position: relative;
	width: 220px;
	padding: 10px;
	font-size: 20px;
	margin: 0 4px 20px 4px;
	text-align: center;
	transition: 0.5s;
	vertical-align: bottom;
}
.collectionpanel {height: 320px;}
.albumpanel {height: 275px;}

.collectionpanelimgwrap, .albumpanelimgwrap{
	width: 220px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	background-image: url('img_root/loading.svg');
}
.collectionpanelimgwrap {height: 220px;}
.albumpanelimgwrap {height: 147px;}

.collectionpanelimgwrap img, .albumpanelimgwrap img {width: 220px;}
.collectionpanelimgwrap img {height: 220px;}
.albumpanelimgwrap img {height: 147px;}

.albuminfo {height: 105px;}

.collectionpaneltitlewrap, .albuminfo div.titlewrap, .albuminfo div.datewrap,.albuminfo div.locationwrap {
	width: 100%;
	display: table;
}

.collectionpaneltitlewrap {height: 60px;}
.albuminfo div.titlewrap {height: 50px;}
.albuminfo div.locationwrap {height: 20px;}
.albuminfo div.datewrap {height: 35px;}

.collectionpaneltitlewrap h3, .albuminfo h3,.albuminfo h4,.albuminfo h5 {
	width: 100%;
	display: table-cell;	
}
.albuminfo h3,.albuminfo h4,.albuminfo h5 {
	text-transform: none;
}

.collectionpaneltitlewrap h3 {
	height: 60px;
	vertical-align: middle;	
}

.albuminfo h3 {
	height: 50px;
	vertical-align: middle;
}

.albuminfo h4 {
	height: 16px;
	font-size: 60%;
	line-height: 100%;
	vertical-align: top;
}

.albuminfo h5 {
	height: 35px;
	font-size: 55%;
	line-height: 110%;
	vertical-align: top;
}

.collectionlink,.albumlink {
	display: block;
	position: absolute;
	width: 240px;
	left: 0px;
	top: 0px;
	text-indent: -9999px;
}
.collectionlink {height: 340px;}
.albumlink {height: 295px;}

.collectionpanel span.coverbutton, .albumpanel span.coverbutton {
	position: absolute;
	top: 16px;
	right: 16px;
	display: none;
}

.collectionpanel:hover span.coverbutton,
.collectionpanel:focus span.coverbutton, 
.albumpanel:hover span.coverbutton, 
.albumpanel:focus span.coverbutton {
	display: inline-block;
	cursor: pointer;
}


/* Photo Thumbnail*/
.thumbwrap {
	display: inline-block;
	margin: 4px; 
	overflow: hidden;
	max-width: calc(100% - 8px);
	border: 1px solid transparent;
}

.thumbwrap img {display: block;}

section.photowrap.selection .thumbwrap {
	opacity: 0.4;
	transition: 0.5s;
}

section.photowrap.selection article.thumbwrap:hover, 
section.photowrap.selection article.thumbwrap:focus,
section.photowrap.selection article.thumbwrap.selected {
	opacity: 1;
}

section.photowrap.selection article.thumbwrap.selected {}

.thumblink {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	text-indent: -9999px;
}

.thumbwrap .magnify {
	opacity: 1;
}

.thumbwrap:hover .magnify,
.thumbwrap:focus .magnify,
.photowrap:not(.selection) .thumbwrap:hover .removephoto,
.photowrap:not(.selection) .thumbwrap:focus .removephoto,
.photowrap:not(.selection) .thumbwrap:hover .select,
.photowrap:not(.selection) .thumbwrap:focus .select,
.photowrap:not(.selection) .thumbwrap:hover .toggle,
.photowrap:not(.selection) .thumbwrap:focus .toggle {
	width: 20px;
	height: 20px;
	text-align: center;
	position: absolute;
	top: 10px; 
	transition: 0.1s;
}

.thumbwrap:hover .magnify, .thumbwrap:focus .magnify {top: 8px; right: 8px;}
.photowrap:not(.selection) .thumbwrap:hover .select, .photowrap:not(.selection) .thumbwrap:focus .select {top: 32px; right: 8px;}
.photowrap:not(.selection) .thumbwrap:hover .removephoto, .photowrap:not(.selection) .thumbwrap:focus .removephoto {top: 56px; right: 8px;}

.photowrap:not(.selection) .thumbwrap:hover .favourite, .photowrap:not(.selection) .thumbwrap:focus .favourite {top: 8px; left: 8px;}
.photowrap:not(.selection) .thumbwrap:hover .personal, .photowrap:not(.selection) .thumbwrap:focus .personal {top: 32px; left: 8px;}
.photowrap:not(.selection) .thumbwrap:hover .showcase, .photowrap:not(.selection) .thumbwrap:focus .showcase {top: 56px; left: 8px;}

.photowrap:not(.selection) .thumbwrap:hover .select, 
.photowrap:not(.selection) .thumbwrap:focus .select, 
.photowrap:not(.selection) .thumbwrap:hover .removephoto, 
.photowrap:not(.selection) .thumbwrap:focus .removephoto, 
.photowrap:not(.selection) .thumbwrap:hover .toggle, 
.photowrap:not(.selection) .thumbwrap:focus .toggle {
	display: block;
}

.photowrap:not(.selection) .thumbwrap:hover .toggle.hidden, 
.photowrap:not(.selection) .thumbwrap:focus .toggle.hidden, 
.photowrap:not(.selection) .thumbwrap:hover .removephoto.hidden, 
.photowrap:not(.selection) .thumbwrap:focus .removephoto.hidden, 
.photowrap:not(.selection) .thumbwrap:hover .select.hidden, 
.photowrap:not(.selection) .thumbwrap:focus .select.hidden {
	display: none;
}

.photowrap:not(.selection) .thumbwrap:hover .toggle:hover,
.photowrap:not(.selection) .thumbwrap:focus .toggle:focus, 
.thumbwrap:hover .magnify:hover,
.thumbwrap:focus .magnify:focus, 
.photowrap:not(.selection) .thumbwrap:hover .removephoto:hover,
.photowrap:not(.selection) .thumbwrap:focus .removephoto:focus, 
.photowrap:not(.selection) .thumbwrap:hover .select:hover,
.photowrap:not(.selection) .thumbwrap:focus .select:focus {
	opacity: 1;
	color: #ffffff;
	cursor: pointer;
}

.photoinfo {
	position: absolute;
	display: table;
	background-color: rgba(0, 0, 0, 0.5);
	left: 0;
	bottom: -70px;
	height: 70px;
	width: 100%;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}

.photoinfo.portraitinfo {
	bottom: -150px;
	height: 150px;
}

.photoinfo div {
	width: 100%;
	display: table;
}

.photoinfo h3 {
	color: #ffffff;
	text-transform: none;
	display: table-cell;
	line-height: 120%;
	height: 70px;
	width: 100%;
	vertical-align: middle;
	padding: 0 10px;
}

.photoinfo.portraitinfo h3 {
	height: 150px;
}

.thumbwrap:hover .photoinfo {
	bottom: 0;
	display: block;
}


/* Calendar */
section#calendarwrap {margin: 0px;}

div.calendarcell {
	float: left;
	width: 14.25%;
}

div.calendarcell h2.albumdatenumber {
	padding: 7px;
	font-size: 12px;
	text-align: center;
	margin: 4px 2px;
}

.calnavwrap {
	text-align: center;
	font-size: 90%;
	padding: 6px 0;
}

.calnavwrap span, .calnavwrap a {
	vertical-align: baseline;
}

.monthwrap {
	float: left;
	width: 16.6667%;
}

.monthname {
	display: block;
	padding: 30px 10px;
	margin: 2px;
	text-align: center;
	font-size: 80%;
}

.calpanel {
	padding: 5px;
	margin: 2px 2px 4px 2px;
	position: relative;
	transition: 0.5s;
}

.calpanel h3 {
	font-size: 70%;
}

.calpanel div.calimg {
	background-color: #f2f2f2;
	height: 0; 
	width:100%;
	padding-bottom:100%;
	background-repeat: none;
	background-position: center;
	background-size: cover;
	margin-bottom: 5px;
}

.calpanel.calalb div.calimg {
	padding-bottom:67%;
}

.calpanel a {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}


.imgwrap {
	position: relative;
	margin: 0 auto 16px auto;
	background: #f2f2f2 url('img_root/loading.svg') center no-repeat;
} 

.imgwrap a {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

/* Filmstrip */
#filmstripwrap {
	height: 88px;
	overflow: hidden;
}

#filmstripthumbs {
	position: relative;
	overflow: hidden;
	margin: 0 88px;
	height: 80px;
	padding: 4px 4px;
}

#filmstripthumbs div {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	height: 80px;
	width: auto;
	white-space: nowrap;
}

#filmstripthumbs article {
	display: inline-block;
}

#filmstripthumbs article a {
	display: inline-block;
	opacity: 0.4;
}

#filmstripthumbs article a.active, #filmstripthumbs article a:hover, #filmstripthumbs article a:focus {opacity: 1;}

.prevnextnext {
	position: absolute;
	top: 0;
	height: 88px;
	width: 80px;
	line-height: 83px;
	text-align: center;
	font-size: 60%;
	margin: 0px;
	text-transform: uppercase;
	transition: 1s;
}
.prevnextnext:hover, .prevnextnext:focus {text-decoration: none;}
.prevnextnext.left {left: 0;}
.prevnextnext.right {right: 0;}
.prevnextnext.buttonoff {cursor: default;}


/* Tags */
#photo_tags {margin: 0 24px;}

.tagbutton,.taglabel {
	font-size: 16px;
	padding: 0px 8px;
	line-height: 24px;
	height: 24px;
	display: inline-block;
	position: relative;
	margin: 0 0 6px 16px;
	transition: 0.5s;
}

.tagbutton:hover, .tagbutton:focus {text-decoration: none;}
.taglabel:hover,.taglabel:focus {cursor: pointer;}

.tagbutton:before,.taglabel:before {
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height:0;
	border: transparent 12px solid;
	top:0;
	left:-24px;
	transition: all 0.5s;
}

.tagbutton:hover:before,.tagbutton:focus:before,.taglabel:hover:before,.taglabel:focus:before,.tagbutton:active:before {cursor: pointer;}
.tagbutton:after, .taglabel:after {
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height:0;
	border-radius: 2px;
	top:10px;
	left:-4px;
	transition: all 0.5s;
}

.tagwrap {padding: 10px;}

 /* Tag Cloud */
.cloudtag {
	display: inline-block;
	vertical-align: middle;
	padding: 2px 4px;
}

.cloudtag:hover, .cloudtag:focus {text-decoration: none;}


/* Location Map */
#locationmap, #albumlocationmap {
	display: block;
	width: 100%;
	height: 600px;
	margin: 0 auto 16px auto;
}


/* FULL EXIF INFO */
table.exiftable {
	width: 80%;
	margin: 0 auto;
}

table.exiftable tr {
}

table.exiftable tr th, table.exiftable tr td {
	font-size: 14px;
	padding: 4px 8px;
	width: 50%;
}

table.exiftable tr th {
	font-weight: 700;
	text-align: right;
}

table.exiftable tr td {
	text-align: left;
}



/* Photo Actions */
#photoactions {
	position: fixed;
	height: 100px;
	width: 100%;
	top: 100%;
	transition: 1s;
}

#photoactions.partvisible {top: calc(100% - 100px);}

#photoactions.fullvisible {
	top: 0;
	height: 100%;
	z-index: 120;
}

#quickactions {
	position: relative;
	padding: 12px 100px;
	width: calc(100% - 200px);
	height: 76px;
}

#quickactions div.inline {padding: 0 5px;}
#moreactions {padding: 24px 100px;}

.ajaxresult {
	display: none;
	padding: 10px;
}

#selectall, #selectnone,#viewmoreactions,#hidemoreactions {position: absolute;}
#selectall, #selectnone {left: 10px;}
#selectall {bottom: 52%;}
#selectnone {top: 52%;}
#viewmoreactions, #hidemoreactions {
	right: 10px;
	top: 50%;
	margin-top: -15px;
}

.working {
	display: block;
	height: 32px;
	width: 32px;
	margin: 0 auto;
	background: transparent url('img_root/loading.svg') center no-repeat;
}


/* Inline Editing */
.editableform {
	display: none;
	padding: 20px 80px;
	margin:	0 auto;
}

.inlineeditbutton {
	display: inline-block;
	padding: 6px 12px;
	font-size: 12px;
	border: none;
	box-sizing: border-box;
	line-height: normal;
	cursor: pointer;
}

.inlineeditbutton:hover, .inlineeditbutton:focus {text-decoration: none;}
.editable, .bannereditable {cursor: cell;}

.editicon {
	position: absolute;
	top: 4px;
	right: 0;
	width: 20px;
	height: 20px;
	vertical-align: top;
	display: block;
	cursor: pointer;
}


/* Backgrounds */
#fadeback, #formback {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
    text-align: center;
	z-index: 1000;
	display: none;
	z-index: 101;
}

#formback div {
	position: absolute;
	top: 50%;
    margin-top: -100px;
    width: 100%;
    padding: 30px 0;
    height: 100px;
    display: table;
}

#formback div.working {
	background-image: url('img_root/loading.svg');
	background-position:  center;
	background-repeat: no-repeat;
}

#fadecontent {
	position: relative;
	display: table-cell;
	height: 100px;
	vertical-align: middle;
	padding: 0;
	width: inherit;
	top: 0;
}

#fadecontent h2 {margin-bottom: 12px;}
#fadecontent p {margin-bottom: 0;}

#newsletterthanks, #contactthanks, #loginthanks {display: none;}

#cookieconfirmation {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
    text-align: center;
	z-index: 1000;
}

#cookieconfirmation article {
	width: 80%;
	max-width: 600px;
	margin: 0 auto;
	top: 35%;
	padding: 20px;
}


/* PANEL WRAPS */
.lastwrap {display: none;}
.switchtriggers.inactive:hover,.switchtriggers.active:focus {cursor: pointer;}


/* ADD ALBUM & ADD PHOTO WRAPS*/
.addalbumwrap,.addphotowrap {
	display: inline-block;
	margin: 4px 0;
	overflow: hidden;
}

.addalbumwrap {
	width: 216px;
	height: 316px;
	vertical-align: bottom;
}

.addphotowrap {
	height: 150px;
	width: 150px;
}

.addalbumwrap a, .addphotowrap a {
	display: table-cell;
	vertical-align: middle;
	text-align: center;
}

.addalbumwrap a {
	width: 216px;
	height: 316px;
}

.addphotowrap a {
	width: 150px;
	height: 150px;
}

@media screen and (max-width: 1200px){
	.sitecontent {width: auto;}

	/*nav#topnav {height: 30px;}*/
	nav#topnav a {
	}

	header.smaller nav#topnav a {
		padding: 0px 4px;
		font-size: 65%;
	}

}

@media screen and (max-width: 1124px){
	.imgwrap, .imgwrap img {
		width: 100% !important;
		height: auto !important;
	}
}

@media screen and (max-width: 1000px){
	nav#topnav a {
		padding: 0px 4px;
		font-size: 70%;
	}

	header.smaller nav#topnav a {
		padding: 0px 2px;
		font-size: 65%;
	}

	.sitecontent, .fullcontent {
		padding: 32px 16px;
	}

}


@media screen and (max-width: 800px){
	body.topmargin {margin-top: 0px;}
	.notmobile {display: none;	}
	br.notmobile {/*display: inline-block;*/}

	.mobileonly {display: block;}
	.narrowtext, .width960 {width: auto;}
	section#mainlogowrap {margin: 5px auto 8px auto;}
	header {position: relative;	border-bottom: none; margin-bottom: 12px;}
	header.smaller {position: relative; height: auto;}
	header.smaller section#mainlogowrap .sitelogo {float: none; height: 80px;}
	header.smaller section#mainlogowrap {
	    float: none;
	    height: 80px;
	    margin-top: 5px;
	    margin-bottom: 8px;
	    margin-left: 0px;
	}

	nav#topnav {display: none;}

	#sidenavigation {
		position: relative;
		display: block;
		transform: none;
		height: auto;
		z-index: auto;
		width: 100%;
	}

	#sidenavlogowrap {
		display: none;
	}

	#sidenavlogowrap .sitelogo path {
		transition: 1s;
	}

	nav#sidenav {
		width: auto;
		height: auto;
		padding: 0;
		position: relative;
		margin: 0px;
	}

	#mobnavhandle {
		position: relative;
		display: block;
		height: 30px;
		line-height: 30px;
		text-transform: uppercase;
		font-size: 80%;
		transition: 1s;
	}
	#mobnavhandle:hover, #mobnavhandle:focus {cursor: pointer;}

	#mobnavhandle:before {
		content: '';
		position: absolute;
		display: block;
		left: 12px;
		top: 50%;
		margin-top: -7px;
		width: 18px;
		height: 3px;
		border-top-style: double;
		border-top-width: 9px;
		border-bottom-style: solid;
		border-bottom-width: 3px;
		transition: 1s;
	}

	#sidenavopen, #sidenavclose {
		display: none;
	}

	#mobnavhandle.open {}

	nav#mainnav a {
		height: 30px;
		line-height: 30px;
		padding: 0;
		border-top-width: 1px;
		border-top-style: solid;
		border-top-color: #ffffff;
		transition: 1s
	}

	nav#mainnav a.collnav {}

	nav#mainnav a:hover, nav#mainnav a:focus {}

	nav#mainnav {display: none;}

	article#breadcrumbs {display: none;}

	article#footercalendar a {
		font-size: 90% !important;
	}

	#colourfooter {
	    padding: 30px;
	    text-align: center;
	}

	section#footerlogowrap {
		width: 100%;
		height: 76px;
		float: none;
		margin: 0 auto 16px auto;
	}

	footer div#smwrap {
		margin: 0;
    	width: auto;
    }

	section.footsitemapcol {
		float: none;
		width: auto;
		margin-bottom: 16px;
	}

	.footersocial {
	    float: none;
	    width: auto;
	}

	article#legalfooter {height: auto;}

	section#legalfootleft, section#footarg {
		float: none;
		width: auto;
		height: auto;
		margin: 0px auto;
		padding: 10px 0;
		text-align: center;
	}

	section#legalfootleft p {
	    display: block;
	    height: auto;
	    line-height: 1.2;
	}

	#thumbwrap {
		width: auto;
		height: auto;
	}

	#albumthumbs {
		width: auto;
		margin: 0 0 16px 0;
	}

	div.calendarcell h2.albumdatenumber {
		font-size: 10px;
	}

	.halfleft, .halfright {
		float: none;
		width: auto;
		margin: 0 0 16px 0;
	}

	#filmstripwrap {
		height: auto;
	}

	#filmstripthumbs {
	    position: relative;
	    overflow: hidden;
	    margin: 0 0 16px 0;
	    height: 80px;
	    padding: 4px 4px;
	}

	.prevnextnext, .prevnextprev {
		position: relative;
		width: calc(50% - 8px);
	}
}
@media screen and (max-width: 600px){
	br.clear {
		display: none;
	}

	div.calendarcell.empty {
		display: none;
	}

	div.calendarcell {
	    float: none;
	    width: auto;
	}
}


/* LIGHTBOX */
	#lb_fade {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	    text-align: center;
		z-index: 1000;
		background-color:rgba(0,0,0,0.8);
		display: none;
		/*opacity: 0;*/
	}

	#lb_fade.loading {
		background: rgba(0,0,0,0.8) url('img_root/loading.svg') center center no-repeat;	
	}

	#lb_panel {
		position: relative;
		display: table;	
		margin: 20px auto;
		min-width: 50%;
		min-height: 50%;
		opacity: 0;
		transition: 0.5s;
		/*max-width: 96%;*/
		/*max-height: 100vh;*/
	}

	#lb_panel div {
		position: relative;
		display: table-cell;
		vertical-align: middle;
		padding: 15px;
		background-color: #ffffff;
		width: auto;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;		
	}

	#lb_panel img {
		transition: 1s;
		max-height: 85vh;
		max-width: 85vw;
	}

	.lb_button {
		background-color: #eeeee7;
		width: 20px;
		height: 20px;
		line-height: 20px;
		padding: 5px;
		display: block;
		-webkit-border-radius: 20px;
		-moz-border-radius: 20px;
		border-radius: 20px;
	}

	.lb_button:hover, .lb_button:focus {
		cursor: pointer;
		background-color: #dad1b4;
	}

	#lb_close {position: absolute; top: -10px; right: -10px;}
	#lb_next {position: absolute; bottom: 10px; right: 20px;}
	#lb_previous {position: absolute; bottom: 10px; right: 60px;}
	#lb_expand {position: absolute; top: -10px; left: -10px;}
	#lb_shrink {position: absolute; top: -10px; left: -10px; display: none;}

	.togglewrap {position: absolute; bottom: 10px; left: 10px;}
	.togglewrap span {padding: 2px;}

	.togglewrap span.hidden {
		display: none;
	}


/* DROPZONE */
	.dropzone, .dropzone * {
	box-sizing: border-box; }

	.dropzone {
		min-height: 150px;
		border: 2px solid rgba(0, 0, 0, 0.3);
		background: white;
		padding: 20px 20px; 
	}
	.dropzone.dz-clickable {cursor: pointer; }
	.dropzone.dz-clickable * {cursor: default; }
	.dropzone.dz-clickable .dz-message, .dropzone.dz-clickable .dz-message * {cursor: pointer; }
	.dropzone.dz-started .dz-message {display: none; }
	.dropzone.dz-drag-hover {border-style: solid; }
	.dropzone.dz-drag-hover .dz-message {opacity: 0.5; }
	.dropzone .dz-message {
		text-align: center;
		margin: 2em 0;
	}
	.dropzone .dz-preview {
		position: relative;
		display: inline-block;
		vertical-align: top;
		margin: 16px;
		min-height: 100px;
	}
	.dropzone .dz-preview:hover {z-index: 1000;}
	.dropzone .dz-preview:hover .dz-details {opacity: 1;}
	.dropzone .dz-preview.dz-file-preview .dz-image {
		background: #999;
		background: linear-gradient(to bottom, #eee, #ddd); 
	}
	.dropzone .dz-preview.dz-file-preview .dz-details {opacity: 1;}
	.dropzone .dz-preview.dz-image-preview {background: white;}
	.dropzone .dz-preview.dz-image-preview .dz-details {
		-webkit-transition: opacity 0.2s linear;
		-moz-transition: opacity 0.2s linear;
		-ms-transition: opacity 0.2s linear;
		-o-transition: opacity 0.2s linear;
		transition: opacity 0.2s linear;
	}
	.dropzone .dz-preview .dz-remove {
		font-size: 14px;
		text-align: center;
		display: block;
		cursor: pointer;
		border: none;
	}
	.dropzone .dz-preview .dz-remove:hover {text-decoration: underline;}
	.dropzone .dz-preview:hover .dz-details {opacity: 1;}
	.dropzone .dz-preview .dz-details {
		z-index: 20;
		position: absolute;
		top: 0;
		left: 0;
		opacity: 0;
		font-size: 13px;
		min-width: 100%;
		max-width: 100%;
		padding: 2em 1em;
		text-align: center;
		color: rgba(0, 0, 0, 0.9);
		line-height: 150%;
	}
	.dropzone .dz-preview .dz-details .dz-size {
		margin-bottom: 1em;
		font-size: 16px;
	}
	.dropzone .dz-preview .dz-details .dz-filename {white-space: nowrap;}
	.dropzone .dz-preview .dz-details .dz-filename:hover span {
		border: 1px solid rgba(200, 200, 200, 0.8);
		background-color: rgba(255, 255, 255, 0.8);
	}
	.dropzone .dz-preview .dz-details .dz-filename:not(:hover) {
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.dropzone .dz-preview .dz-details .dz-filename:not(:hover) span {border: 1px solid transparent;}
	.dropzone .dz-preview .dz-details .dz-filename span, .dropzone .dz-preview .dz-details .dz-size span {
		background-color: rgba(255, 255, 255, 0.4);
		padding: 0 0.4em;
		border-radius: 3px;
	}
	.dropzone .dz-preview:hover .dz-image img {
		-webkit-transform: scale(1.05, 1.05);
		-moz-transform: scale(1.05, 1.05);
		-ms-transform: scale(1.05, 1.05);
		-o-transform: scale(1.05, 1.05);
		transform: scale(1.05, 1.05);
		-webkit-filter: blur(8px);
		filter: blur(8px);
	}
	.dropzone .dz-preview .dz-image {
		overflow: hidden;
		width: 120px;
		height: 120px;
		position: relative;
		display: block;
		z-index: 10;
	}
	.dropzone .dz-preview .dz-image img {display: block;}
	.dropzone .dz-preview.dz-success .dz-success-mark {
		-webkit-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
		-moz-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
		-ms-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
		-o-animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
		animation: passing-through 3s cubic-bezier(0.77, 0, 0.175, 1);
	}
	.dropzone .dz-preview.dz-error .dz-error-mark {
		opacity: 1;
		-webkit-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
		-moz-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
		-ms-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
		-o-animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
		animation: slide-in 3s cubic-bezier(0.77, 0, 0.175, 1);
	}
	.dropzone .dz-preview .dz-success-mark, .dropzone .dz-preview .dz-error-mark {
		pointer-events: none;
		opacity: 0;
		z-index: 500;
		position: absolute;
		display: block;
		top: 50%;
		left: 50%;
		margin-left: -27px;
		margin-top: -27px;
	}
	.dropzone .dz-preview .dz-success-mark svg, .dropzone .dz-preview .dz-error-mark svg {
		display: block;
		width: 54px;
		height: 54px;
	}
	.dropzone .dz-preview.dz-processing .dz-progress {
		opacity: 1;
		-webkit-transition: all 0.2s linear;
		-moz-transition: all 0.2s linear;
		-ms-transition: all 0.2s linear;
		-o-transition: all 0.2s linear;
		transition: all 0.2s linear;
	}
	.dropzone .dz-preview.dz-complete .dz-progress {
		opacity: 0;
		-webkit-transition: opacity 0.4s ease-in;
		-moz-transition: opacity 0.4s ease-in;
		-ms-transition: opacity 0.4s ease-in;
		-o-transition: opacity 0.4s ease-in;
		transition: opacity 0.4s ease-in;
	}
	.dropzone .dz-preview:not(.dz-processing) .dz-progress {
		-webkit-animation: pulse 6s ease infinite;
		-moz-animation: pulse 6s ease infinite;
		-ms-animation: pulse 6s ease infinite;
		-o-animation: pulse 6s ease infinite;
		animation: pulse 6s ease infinite;
	}
	.dropzone .dz-preview .dz-progress {
		opacity: 1;
		z-index: 1000;
		pointer-events: none;
		position: absolute;
		height: 16px;
		left: 50%;
		top: 50%;
		margin-top: -8px;
		width: 80px;
		margin-left: -40px;
		background: rgba(255, 255, 255, 0.9);
		-webkit-transform: scale(1);
		border-radius: 8px;
		overflow: hidden;
	}
	.dropzone .dz-preview .dz-progress .dz-upload {
		background: #333;
		background: linear-gradient(to bottom, #666, #444);
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		width: 0;
		-webkit-transition: width 300ms ease-in-out;
		-moz-transition: width 300ms ease-in-out;
		-ms-transition: width 300ms ease-in-out;
		-o-transition: width 300ms ease-in-out;
		transition: width 300ms ease-in-out;
	}
	.dropzone .dz-preview.dz-error .dz-error-message {display: block;}
	.dropzone .dz-preview.dz-error:hover .dz-error-message {
		opacity: 1;
		pointer-events: auto;
	}
	.dropzone .dz-preview .dz-error-message {
		pointer-events: none;
		z-index: 1000;
		position: absolute;
		display: block;
		display: none;
		opacity: 0;
		-webkit-transition: opacity 0.3s ease;
		-moz-transition: opacity 0.3s ease;
		-ms-transition: opacity 0.3s ease;
		-o-transition: opacity 0.3s ease;
		transition: opacity 0.3s ease;
		border-radius: 8px;
		font-size: 13px;
		top: 130px;
		left: -10px;
		width: 140px;
		background: #be2626;
		background: linear-gradient(to bottom, #be2626, #a92222);
		padding: 0.5em 1.2em;
		color: white;
	}
	.dropzone .dz-preview .dz-error-message:after {
		content: '';
		position: absolute;
		top: -6px;
		left: 64px;
		width: 0;
		height: 0;
		border-left: 6px solid transparent;
		border-right: 6px solid transparent;
		border-bottom: 6px solid #be2626;
	}

/* CMS */
	.templatebutton {
		display: inline-block;
		position: relative;
		width: 200px;
		height: 80px;
		margin: 0 5px 10px 5px;
		text-align: center;
		font-size: 0;
		border: transparent 2px solid;
	}

	.templatebutton:hover, .templatebutton:focus {
		cursor: pointer;
	}

	.templatebutton.selected {
		border: #000000 2px solid;
	}

	.templatebutton h3 {
		position: absolute;
		display: block;
		height: 50px;
		width: 200px;
		font-size: 16px;
		line-height: 80px;
		top: 0;
		left: 0;
	}

	.templatecolour {
		display: inline-block;
		font-size: 0;
		width: 40px;
		height: 80px;
		margin: 0;
	}

	.iconbutton {
		display: inline-block;
		width: 40px;
		margin: 3px;
		padding: 8px 0;
		text-align: center;
		font-size: 24px;
		color: #c2c2c2;
	}

	.iconbutton:hover, .iconbutton:focus {
		cursor: pointer;
	}

	.iconbutton.selected {
		background-color: #f2f2f2;
	}
