/**
	@Author:	Paul Strandoo
	@Date:		10 April 2021
	@Notes:		Ipswich Film Theatre Reboot 2021
	
	CONTENTS
	-------------
	- Global resets
	- Global typography & layout rules
	- Page styles
	- Post styles 
	- General bits 
	
	FONTS & COLORS
	-------------	
	Orange: ea8100;
	footer BG: #333331;
	crimson: #7d2a29;
	gold: #8e703d;
	Font-family: 'Germalt Regular'; 400,500,700
	Font-family: 'Inter', sans-serif; 400,500,700
	inner: 1180 / 1070px
	Neuvetica: 14 fonts, funky 'a'
	Extensa Grotesk: 5 weights ; meh.
	Solo: 3 weights: funky 'a', weird tails
*/

/*@charset "UTF-8";*/
:root {
	/* orange change:
		previous orange: #f98100 / rgba(249,129,0,100)
		news orange:     #f36d21 / rgba(243,109,33,100) 
	*/
	--orange: #f98100; /* nuke this; still in shop  f36d21 */
	--accent: #ec5670;
	--accent: #f98100; /* 2022 accent */
	--accent: rgb(252,193,0); /* 2024 accent */
	--black: #000;
	--white: #fff;
    --gray: gray;
    --gray-dark: #404040;
    --primary: #000;
    --success: #28a745;
    --info: #17a2b8;
    --warning: #ffc107;
    --inner-default: 1180px;
    --inner-narrow: 860px;
    --inner-wide: 1400px;
	}

*, *:before, *:after {
   -moz-box-sizing:    border-box;
   -webkit-box-sizing: border-box;
	box-sizing:        border-box;
	}

@-ms-viewport {
	width: device-width;
	}

html {
	height: 100%;
	font-size: 100%;
	}
body {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	line-height: 1.6;
	color: #222;
	font-weight: 500;
	font-weight: 400;
	/*height: 100%;*/
	/*display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;*/
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	}

p,
li,
td {
	font-family: 'Inter', sans-serif;
	font-size: 1.1rem;
	font-size: 1em;
	font-weight: 400;
	margin: 0 0 1em;
	word-spacing: 0.1em;
	}

li,td {
	margin: 0;
	}

em {
	font-style: italic;
	}
b,
strong {
	font-weight: 700;
	}

.cms-content bold,
.cms-content strong {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	}
.g-strong,
strong.g-strong {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	}

a {
	color: #000;
	text-decoration: underline;
	}
a:hover,
a:active {
	/*
	color: var(--accent);
	text-decoration: underline;
	background: black;
	box-shadow: 0 -2px 0 3px black;
	*/
	/*background: var(--accent);*/
	color: var(--accent);
	}

.hero-cta a[href^="tel"] {
	color: inherit;
	text-decoration: none;
	}
.top-strip a[href^="tel"] {
	color: inherit;
	text-decoration: none;
	}


h1,h2,h3,h4,h5,h6 {
	font-family: 'Germalt Bold', sans-serif;
	font-family: 'Inter', sans-serif;
	font-weight: normal;
	font-weight: 700;
	line-height: 1.3em;
	margin: 0 0 0.8em;
	}
h1, .h1 {
	/*font-weight: 700;*/
	font-size: 3.2rem;
	line-height: 1.1em;
	margin: 0 0 0.8em;
	}

h2, .h2 {
	font-size: 1.7rem;
	line-height: 1.1em;
	margin: 0 0 0.35em;
	}
h3, .h3 {
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	font-size: 1.4rem;
	font-size: 1.3rem;
	margin: 0 0 0.35em;
	}
h4 {
	font-size: 1.1rem;
	/*font-weight: 700;*/
	text-transform: uppercase;
	}
h5 {
	font-size: 1rem;
	margin: 0;
	/*font-weight: 700;*/
	}

h2 small,
.h2 small {
	font-size: 1.2rem;
	}
.h2onh3 {
	margin: 0;
	}
	
.display {
	font-family: 'Germalt Regular', sans-serf;
	font-family: 'Inter', sans-serif;
	color: #fff;
	font-size: 3.4rem;
	margin-bottom: 0; /* 2023 header */
	}

p + h2,
p + h3,
ul + h2,
ul + h3 {
	margin-top: 1.5em;
	}

img {
	display: block;
	}

.programme-title {
	margin-bottom: 0.2em;
	}
.programme-date {
	margin-bottom: 0.5em;
	}
.programme-times {
	margin: 0 0 25px;
	}
.programme-times .button {
	margin-right: 10px;
	}
.programme-links {
	margin-top: 1em;
	margin: 1em 0 0;
	}

.read-more {
	font-family: 'Inter', sans-serif;
	font-size: 1.1em;
	}
	
.reverse-link {
	color: #000;
	}
.reverse-link:hover {
	color: var(--orange);
	}
	
.f-right  {
	float: right;
	}
	
@media only screen and (min-width: 660px) {
	.display {
		font-size: 5rem;
		}
}
@media only screen and (min-width: 880px) {
	.display {
		font-size: 6rem;
		}
}
	
/* Misc Rules */
/*
.programme-row:last-child:after {
	content: "";
	height: 2px;
	width: calc(100% - 20px);
	margin: 20px 20px;
	background: var(--orange);
	}
*/
.seasons-page .programme-row:last-child:after {
	margin: 0;
	background: none;
	}

.row-divider:after {
	content: "";
	height: 2px;
	width: calc(100% - 20px);
	margin: 15px 20px;
	background: var(--black);
	}

.rule-above:before {
	content: "";
	height: 2px;
	width: calc(100% - 60px);
	margin: 20px 30px;
	background: var(--black);
	display: none;
	}

.film-trailer {
	margin: 2em 0;
	}
.film-info {
	margin-bottom: 0.2em;
	}
	
.film-meta {
	font-family: 'Inter', sans-serif;
	/*font-family: 'Germalt Bold', sans-serif;*/
	font-weight: 700;
	}
/*
.all-films-row:nth-of-type(odd) {
	background: #f1f1f1;
	}
*/

.captioned-notice {
	font-size: 1.1rem;
	margin-top: 1em;
	}

.all-films-row {
	margin-bottom: 0;
	}

@media only screen and (min-width: 660px) { 
	.all-films-img-col {
		 max-width:  295px;
		 }
}

.all-films-row:after,
.programme-row:after {
	content: "";
	height: 2px;
	width: calc(100% - 40px);
	margin: 20px;
	background: #000;
	}
	
.all-films-media {
	 /*max-width: 320px;*/
	 text-align: right;
	 margin: 0 0 0 auto;
	 }
	 
#film-quick {
	/*max-width: 500px;*/
	}


/* Dark and Light #utility */
.dark,
.dark p,
.dark li,
.dark h2,
.dark h3,
.dark h4 {
	color: #fff;
	}
.dark a {
	color: #fff;
	border-bottom: 1px solid #fff;
	}
.dark a:hover {
	color: #fff;
	}

.cinema-bold {
	color: #7d2a29;
	font-weight: 700;
	}
.restaurant-mode .cinema-bold {
	color: #8e703d;
	}

/* ----- [ Structure ] -----------------*/
header,
section,
footer {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
	}
section {
	margin: 50px auto;
	padding: 0;
	}
.inner {
	position: relative;
	max-width: var(--inner-default);
	margin: 0 auto;
	padding: 0 30px;
	}
.inner-narrow {
	max-width: var(--inner-narrow);
	}
.inner-wide {
	max-width: var(--inner-wide);
	}
.inner-max {
	max-width: 2020px;
	padding: 0 20px;
	}
.inner-full {
	max-width: 100%;
	padding: 0;
	}


/* ----- [ Strandoo Simple Grid System v3.1 ] --------------- */
.row {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	flex-direction: column;
	/*justify-content: stretch;*/
	list-style: none;
	margin-left: -15px;
	margin-right: -15px;
	/*overflow: hidden;*/
	position: relative;
	}

.row > .col {
	/*
	-webkit-box-flex: 1;
	-webkit-flex: 1;
	-ms-flex: 1;
	flex: 1;
	*/
	width: 100%;
	padding-left: 15px;
	padding-right: 15px;
	/*width: 100%;
	display: inherit;
	float: none;
	vertical-align: top;
	font-size: 18px;
	text-align: left;*/
	}

.row.no-padding,
.row.padding-0 {
	margin-left: 0;
	margin-right: 0;
	}
.row.padding-1 {
	margin-left: -1px;
	margin-right: -1px;
	}
.row.padding-5 {
	margin-left: -5px;
	margin-right: -5px;
	}
.row.padding-10 {
	margin-left: -10px;
	margin-right: -10px;
	}
.row.padding-15 {
	margin-left: -15px;
	margin-right: -15px;
	}
.row.padding-20 {
	margin-left: -20px;
	margin-right: -20px;
	}
.row.padding-30 {
	margin-left: -30px;
	margin-right: -30px;
	}

.no-padding > .col,
.padding-0 > .col {
	padding: 0;
	}
.padding-1 > .col {
	padding: 1px;
	}
.padding-5 > .col {
	padding: 5px;
	}
.padding-10 > .col {
	padding: 10px;
	}
.padding-15 > .col {
	padding: 15px;
	}
.padding-20 > .col {
	padding: 20px;
	}
.padding-30 > .col {
	padding: 20px 30px;
	}

.row.text-center > .col {
	text-align: center;
	}

.col > img,
.col a > img {
	max-width: 100%;
	}

.col-auto,
.col-full,
.col-1of2,
.col-1of3,
.col-2of3,
.col-1of4,
.col-3of4,
.col-1of5,
.col-2of5,
.col-3of5,
.col-4or5,
.col-1of6,
.col-100,
.col-50,
.col-33,
.col-66,
.col-25,
.col-75,
.col-40,
.col-60 {
	width: 100%;
    -webkit-box-flex: 0 !important;
    -webkit-flex: none !important;
    -ms-flex: none !important;
    flex: none !important;
    }


@media only screen and (min-width: 660px) { 
	.row {
		flex-direction: row;
		}
	
	.col-auto {
		width: auto;
		}
	.col-full,
	.col-100 {
		width: 100% !important;
		}
	.col-1of2,
	.col-50 {
		width: 50% !important;
		}
	.col-1of3,
	.col-33 {
		width: 33.3333% !important;
		}
	.col-2of3,
	.col-66 {
		width: 66.6667% !important;
		}
	.col-1of4,
	.col-25 {
		width: 25% !important;
		}
	.col-3of4,
	.col-75 {
		width: 75% !important;
		}
	.col-1of5,
	.col-20 {
		width: 20% !important;
		}
	.col-4of5,
	.col-80 {
		width: 80% !important;
		}
		
	.col-1of6 {
		width: 16.666667% !important;
		}
	
	/* 60/40 */
	.col-40 {
		width: 40% !important;
		}
	.col-60 {
		width: 60% !important;
		}
		
	/* special */
	.col-1of3.grid-item {
		width: 50% !important;
		}
}

@media only screen and (min-width: 920px) { 
	.col-1of3.grid-item {
		width: 33.3333% !important;
		}
}

/* makes children flex containers (stretch inners) */
.flex-cols > .col {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    }


/* Vertical alignment per row */
.row-top {
	align-items: flex-start;
	}
.row-bottom {
	align-items: flex-end;
	}
.row-middle {
	align-items: center;
	}
	
/* Horizontal alignment per row */
.row-left {
	justify-content: flex-start;
	}
.row-right {
	justify-content: flex-end;
	}
.row-center {
	justify-content: center;
	}

.row-around {
	justify-content: space-around;
	}
.row-between {
	justify-content: space-between;
	}
.row-evenly {
	justify-content: space-around;
	}


.push-right {
	margin-right: auto;
	}
.push-left {
	margin-left: auto;
	}


/* Direction */
.row-reverse {
	flex-direction: row-reverse !important;
	}
.row-column {
	flex-direction: column;
	}
.row-column-reverse {
	flex-direction: column-reverse;
	}


/* 600px equivalent breakpoint */
@media only screen and (min-width: 660px) { 
	.row {
		/*
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		flex-wrap: wrap;
		*/
		flex-direction: row;
		}
		
	.row > .col { flex: 1}

	.row-2 > .col { width: 50%; }
	.row-3 > .col { width: 33.333%; }
	.row-4 > .col { width: 25%;}
	.row-5 > .col { width: 20%;}
	.row-6 > .col { width: 16.666%;}

	.row-2 .span-2 { width: 100%; }
	.row-3 .span-2 { width: 66.666%; }
	.row-4 .span-2 { width: 50%; }
	.row-4 .span-3 { width: 75%; }
	.row-5 .span-2 { width: 40%; }
	.row-5 .span-3 { width: 60%; }
	.row-5 .span-4 { width: 80%; }
}


/*
@media print, screen and (min-width: 640px) { 
	.row-story > .col { width: 50%; }
}
@media print, screen and (min-width: 1170px) { 
	.row-story > .col { width: 33.333%; }
}
@media print, screen and (min-width: 1570px) { 
	.row-story > .col { width: 25%; }
}
*/

/* ----- [ Page Wrapper / Overlay / Header ] -----------------*/
.page-wrapper {
	position: relative;
	flex: 1 0 auto;
	-webkit-transition: transform .3s ease;
	-moz-transition: transform .3s ease;
	-o-transition: transform .3s ease;
	transition: transform .3s ease;
	}

.page-wrapper.is-open {
	-webkit-transform: translateX(-360px);
	-moz-transform: translateX(-360px);
	-ms-transform: translateX(-360px);
	-o-transform: translateX(-360px);
	transform: translateX(-360px);
	}

.page-overlay {
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	visibility: hidden;
	background: #666;
	background: rgba(0,0,0,0.4);
	z-index: 100;
	opacity: 0;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
	}
.page-overlay.is-open {
	visibility: visible;
	opacity: 1;
	}

.page-header {
	position: absolute;
	/*position: relative;*/
	width: 100%;
	top: 0;
	left: 0;
	height: auto;
	margin: 0;
	padding: 0;
	z-index: 110;
	color: #fff;
	color: var(--black);
	background: var(--black); /* 2024 (April) header */
	background: transparent;  /* 2023/24 header */
	background: var(--while); /* 2024 (April) header */
	display: -webkit-flex;
	display: flex;
	flex-direction: row;
	justify-content: space-between; 
	align-items: center;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-transform: translateZ(0);
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-o-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transition: all 0.4s;
	-moz-transition: all 0.4s;
	-o-transition: all 0.4s;
	transition: all 0.4s;
	}
	
.page-header.tinted {
	background: rgba(0,0,0,0.7);  /* 2023 header */
	}

.page-header.nav-is-visible {
	-webkit-transform: translateX(-260px);
	-moz-transform: translateX(-260px);
	-ms-transform: translateX(-260px);
	-o-transform: translateX(-260px);
	transform: translateX(-260px);
	}

.page-header-inner {
	display: -webkit-flex;
	display: flex;
	flex-direction: row;
	justify-content: space-between; 
	align-items: flex-start;
	max-width: var(--inner-wide);
	width: 100%;
	margin: 0 auto;
	padding: 20px;
	}
	
.page-header a,
.page-header p {
	color: #fff;
	color: var(--black);
	}
	
.head-meta {
	width: 33.333%;
	display: -webkit-flex;
	display: flex;
	justify-content: flex-start; 
	align-items: center;
	text-align: left;
	}
.head-meta:last-child {
	text-align: right;
	justify-content: flex-end; 
	}

.button.programme-download {
	display: none;
	}

/* no hero */
.shopping-cart-page .page-header,
.checkout-page .page-header {
	border-bottom: 1px solid #d7d7d6;
	}

.logo-wrap {
	margin: 0;
	padding: 0 15px;
	padding: 0 15px 0 0;
	overflow: hidden;
	max-width: 115px;
	max-width: 180px; /* 2022 logo */
	width: 75vw;      /* 2023 logo */
	max-width: 310px; /* 2023 logo */
	max-width: 110px; /* 2024 logo */
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
	z-index: 1;
	}
	
.header-logo {
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
	}

.header-logo img {
	width: 100%;
	}

/* if alternate/2nd logo is different */
/*
.logo-main-rev,
.is-fixed .logo-main,
.is-dark .logo-main {
	display: block;
	}
.logo-main,
.is-fixed .logo-main-rev,
.is-dark .logo-main-rev {
	display: none;
	}
*/

/* 2024 April version */
.is-fixed .logo-main {
	display: block !important;
	}
.is-fixed .logo-main-rev,
.logo-main-rev {
	display: none !important;
	}


/* header stuff */
.page-header.is-hidden {
	height: auto;
	padding: 5px 0;
	}

.page-header {
	position: fixed;
	background: var(--white); /* 2024 (April) Header */
	}
.page-header.is-fixed {
	/*background: var(--black);*/ /* 2023 Header */
	background: var(--white); /* 2024 Header */
	}
.page-header.is-dark {
	/*background: var(--black); */ /* 2023 Header */
	}
.is-hidden .logo-wrap {
	/* max-width: 70px; 2022 logo */
	max-width: 125px;
	}
.is-hidden .page-header-inner {
	padding: 5px 20px;
	}


@media only screen and (min-width: 990px) { /* 800/1024 nav width */
	.page-header {
		position: absolute;
		display: -webkit-flex;
		display: flex;
		flex-direction: column;
		justify-content: flex-start; 
		align-items: stretch;
		}
	.page-header.is-hidden {
		-webkit-transform: translateY(-100%);
		-moz-transform: translateY(-100%);
		-ms-transform: translateY(-100%);
		-o-transform: translateY(-100%);
		transform: translateY(-100%);
		}

	.logo-wrap {
		position: relative;
		text-align: center;
		margin: 0;	 /* 2022 logo */
		margin: 15px 0; /* 2023 logo */
		padding: 0 15px;
		/*padding: 0 15px 0 0;*/
		overflow: hidden;
		min-width: 125px;
		/*max-width: 145px; // Orig logos
		max-width: 160px;*/
		max-width: 300px; /* 2022 logo */
		max-width: 330px; /* 2023 logo */
		max-width: 130px; /* 2024 logo */
		}
}

@media only screen and (min-width: 990px) { /* 800/1024 nav width */
	.page-header {
		position: fixed;
		}
	.page-header-inner {
		flex-direction: row;
		justify-content: space-between; 
		align-items: center;
		}
	.button.programme-download {
		display: block;
		}
	.logo-wrap.is-fixed {
		/*max-width: 120px;*/
		}
}


/* ----- [ Menu and Search Triggers ] ----------- */
.nav-toggle {
	display: block;
	background: transparent;
	width: 44px;
	height: 44px;
	/*margin-right: 10px;*/
	position: relative;
	cursor: pointer;
	z-index: 100;
	}
.nav-toggle a {
	display: none;
	}

.nav-icon {
	/* this span is the central line in the menu */
	display: inline-block;
	position: absolute;
	left: 50%;
	top: 50%;
	bottom: auto;
	right: auto;
	-webkit-transform: translateX(-50%) translateY(-50%);
	-moz-transform: translateX(-50%) translateY(-50%);
	-ms-transform: translateX(-50%) translateY(-50%);
	-o-transform: translateX(-50%) translateY(-50%);
	transform: translateX(-50%) translateY(-50%);
	width: 26px;
	height: 2px;
	background-color: var(--white);
	background-color: var(--black); /* 2024 Header */
	/* these are the upper and lower lines in the menu */
	}
.is-fixed .nav-icon {
	background-color: var(--black); /* 2024 Header */
	}
	
.nav-icon::before, 
.nav-icon:after {
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	background-color: inherit;
	left: 0;
	}
.nav-icon::before {
	bottom: 8px;
	}
.nav-icon::after {
	top: 8px;
	}
.is-clicked .nav-icon {
	background-color: none;
	background-color: rgba(255,255,255,0);
	}
.is-clicked .nav-icon::before, 
.is-clicked .nav-icon::after {
	background-color: #fff;
	background-color: var(--black);
	}
.is-clicked .nav-icon::before {
	bottom: 0;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	}
.is-clicked .nav-icon::after {
	top: 0;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	-o-transform: rotate(-45deg);
	transform: rotate(-45deg);
	}

/* ----- [ Navigation ] ------------------- */
.menu-item {
	display: block;
	margin: 0;
	border-top: 1px solid var(--gray-dark);
	}
.menu-item a {
	font-family: 'Inter', sans-serif;
	display: block;
	font-size: 20px;
	font-weight: 400;
	font-weight: 500;
	padding: 10px 0;
	text-decoration: none;
	}
.menu-item a:hover,
.menu-item.nav-open > a {
	color: #000;
	color: var(--accent);
	/*color: var(--white);*/ /* 2024 header */
	background: none;
	text-decoration: none;
	}
.is-fixed .menu-item a:hover,
.is-fixed .menu-item.nav-open > a {
	color: var(--black); /* 2024 header */	
	}

.menu-item.mobile {
	display: block;
	border-top: none;
	}
.menu-item.mobile a {
	width: 100%;
	font-size: 1.1em;
	}
.menu-item.full {
	display: none;
	}

.dropnav {
	display: none;
	}

.dropnav .menu-item {
	padding-left: 2em;
	}
	
.has-children:after {
	content: "\f0da";
	font-family: fontawesome;
	margin-left: 0.4em;
	}
.has-children.submenu-open:after {
	content: "\f0d7";
	font-family: fontawesome;
	margin-left: 0.4em;
	}

@media only screen and (min-width: 990px) { /* 800px nav width: nav-toggle */
	.menu-item.mobile {
		display: none;
		}
	.menu-item.full {
		display: block;
		}

	.nav-toggle {
		display: none;
		}
	.menu-item {
		display: inline-block;
		position: relative;
		line-height: 1.2;
		margin: 0.3em 0 0.3em 2em;
		padding: 0;
		overflow: visible;
		border-bottom: none;
		border: none;
		min-height: 0;
		vertical-align: middle;
		text-align: center;
		}
	.menu-item a {
		position: relative;
		color: #fff; /* 2023 */
		color: #000; /* 2024 (April) */
		font-size: 1.1rem;
		padding: 2px 0;
		white-space: nowrap;
		border-bottom: none;
		}
	.menu-item:hover a,
	.menu-item a.on {
		color: var(--accent);
		color: var(--white); /* 2024 header */
		color: var(--black); /* 2024 (April) header */
		/*border-bottom: 2px solid var(--accent);
		border-bottom: transparent;*//* 2024 header */
		}
	
	/* 2024 header */
	.is-fixed .menu-item a {
		color: #000;
		}
		
	/* Drop Menus */	
	.dropnav,
	.dropnav-2 {		
		display: block;
		position: absolute;
		min-width: 140px;
		width: auto;
		top: 120%;
		margin-left: -15px;
		margin-left: 0;  /* 2023 header */
		/* left: -50%; */
		text-align: left;
		background: var(--black);
		background: var(--white); /* 2024 header */
		z-index: 9999;
		visibility: hidden;
		opacity: 0;
		padding: 10px 15px;
		box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.15);
		white-space: nowrap;
		-webkit-transform: none;
		-moz-transform: none;
		-ms-transform: translateX(0px);
		-o-transform: none;
		transform: none;
		-webkit-transition: all .3s ease;
		-moz-transition: all .3s ease;
		-o-transition: all .3s ease;
		transition: all .3s ease;
		}
	.dropnav > ul {
		margin: 70px 0 0;
		margin: 30px 0 0; /* 2023 header */
		}
	.dropnav > ul ul {
		margin: 0;
		}
		
	.menu-item:hover > .dropnav {
		top: 100%;
		top: calc(100% + 2px);
		visibility: visible;
		opacity: 1;
		}
		
	.menu-item .has-children:after {
		content: "\f0d7";
		font-family: fontawesome;
		line-height: 0;
		margin-left: 0.4em;
		/*display: none;*/
		}

	.dropnav .has-children:after {
		content: "\f0da";
		font-family: fontawesome;
		margin-left: 0.4em;
		/*display: none;*/
		}
	
	.dropnav-2 {
		top: 0;
		left: calc(100%  + 18px);
		margin-left: 0;
		margin-top: -10px;
		}
	.menu-item .menu-item:hover .dropnav-2 {
		top: -16px;
		visibility: visible;
		opacity: 1;
		}

	.dropnav .menu-item {
		display: block;
		font-size: 1em;
		text-align: left;
		text-transform: capitalize;
		font-weight: 600;
		letter-spacing: 0;
		margin: 16px 0;
		padding-left: 0;
		}
	.dropnav .menu-item a {
		display: inline;
		color: #fff;
		color: var(--black); /* 2024 header */
		padding: 2px 0;
		margin: 0;
		border-bottom: 2px solid transparent;
		}
	.dropnav a:hover,
	.dropnav a.on {
		color: var(--accent);
		color: var(--black);
		text-decoration: none;
		border-bottom: 2px solid var(--accent);
		border-bottom: 2px solid transparent; /* 2024 Header */
		}
	.dropnav .menu-item ul {
		display: inherit;
		}
}

/* ----- [ Side Shopping Cart ] --------------- */
.cart-toggle {
	margin: 6px 0 0 8px;
	}
.i-bag-icon {
	width: 26px;
	display: block;
	}

.side-shopping-cart {
	position: fixed;
	padding: 25px 20px 0;
	padding: 40px 30px 0;
	top: 0;
	bottom: 0;
	left: 100%;
	right: 0;
	width: 360px;
	width: 40vw;
	min-width: 680px;
	min-width: 0;
	width: 100%;
	background: #fff;
	z-index: 800;
	-webkit-transform: translateX(101%);
	-moz-transform: translateX(101%);
	-ms-transform: translateX(101%);
	-o-transform: translateX(101%);
	transform: translateX(101%);
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
	/*visibility: hidden;*/
	overflow-y: auto;
	}
.side-shopping-cart.is-open {
	-webkit-transform: translateX(0);
	-moz-transform: translateX(0);
	-ms-transform: translateX(0);
	-o-transform: translateX(0);
	transform: translateX(0);
	visibility: visible;
	left: auto;
	/*transform: translateX(-40vw);*/
	}

@media only screen and (min-width: 600px) {
	.side-shopping-cart {
		width: 40vw;
		min-width: 600px;
		}
}

@media only screen and (min-width: 800px) {
	.side-shopping-cart {
		width: 40vw;
		min-width: 680px;
		}
}


/* ----- [ Page Content ] --------------- */
/* ----- [ Home Page ] ------------------ */
.top {
	padding-top: 120px;
	padding-bottom: 20px;
	}
.hero {
	padding: 0;
	margin: 50px auto;
	min-height: 400px;
	/*height: calc(90vh - 30px); /* 2023 header */
	max-height: 85vh;
	height: 100%;
	height: 100vh;
	margin-top: 98px; /* 2022 logo */
	margin-top: 0; /* 2023 header */
	background: #eee;
	overflow: hidden;
	}
.hero .inner {
	/*height: 90vh;*/
	padding: 0;
	margin-top: 100px;  /* 2023 header */
	margin-top: 0;
	height: 100%;
	max-height: 85vh;
	display: flex;
	justify-content: flex-start;
	align-items: flex-end;
	padding-bottom: 70px;
	padding-bottom: 0;
	}

.home-hero {
	padding: 0;
	margin: 0 auto;
	background-size: cover;
	background-position: 50% 50%;
	background-repeat: no-repeat;
	height: calc(90vh - 30px); /* 2023 header */
	}

.hero-text {
	color: #fff;
	padding: 60px 25px;
	}
.hero-text.dark-text .hero-headline,
.hero-text.dark-text .hero-dates {
	color: #000 !important;
	}
.hero-headline {
	color: #fff !important;
	font-size: 2.4rem;
	margin: 0 0 0.2em;
	}
.hero-headline small {
	font-size: 1.2rem;
	line-height: 1;
	}
.hero-dates {
	color: #fff !important;
	}

/* Temporary Hero */
.restaurant-home .hero {
	background-color: #222;
	background-size: 80%;
	}

@media only screen and (min-width: 660px) { /* 1024 */
	.top {
		padding-top: 170px;
		}
	.hero {
		min-height: 500px;
		height: calc(90vh - 30px); /* 2023 header */
		/*margin-top: 138px;*/ /* 2022 logo */

		}
		
	/* Temporary Hero */
	.restaurant-home .hero {
		background-color: #222;
		background-size: 60%;
		}
}

@media only screen and (min-width: 800px) { /* 1024 */
	.hero {
		max-height: 800px;
		height: calc(90vh - 154px);
		height: calc(90vh - 30px); /* 2023 header */
		margin-top: 98px; /* 2022 logo  112px*/
		margin-top: 0; /* 2023 header */
		margin-top: 106px; /* 2024 (April) header */
		padding-top: 0;
		margin-bottom: 80px;
		}
	.home-hero {
		max-height: 800px;
		height: calc(90vh - 156px);
		height: calc(90vh - 30px); /* 2023 header */
		}
	.hero .inner {
		padding-bottom: 70px;
	}
}

.hero-overlay {				
	/* z-index: 1; */
	position: absolute;
	bottom: 0;
	top: 0;
	left: 0;
	right: 0;
	background: transparent;
	}
.hero-overlay {
	display: flex;
	justify-content: center;
	align-items: center;
	}


.slick-slider,
.slick-list,
.slick-slide,
.slick-track {
	/*height: 100%;*/
	}

	
/* ----- [ Slick Dots ] ----------- */
.slick-dots {
    position: absolute;
    bottom: -40px;
    bottom: 20px;
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    text-align: center;
    display: none !important; /* 2023 header */
	}

.grid-slider .slick-dots {
	bottom: -30px;
	}

.slick-dots li {
    position: relative;
    display: inline-block;
    margin: 0 8px;
    padding: 0;
    cursor: pointer;
	}
.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 12px;
    height: 12px;
    padding: 0;
    cursor: pointer;
    color: #fff;
    /*border: 3px solid #222;*/
    outline: none;
    background: none;
    background: #fff;
    opacity: 0.8;
    border: none;
    border-radius: 50%;
	}
.slick-dots li button:hover,
.slick-dots li.slick-active button {
	background: var(--accent);
    opacity: 1;
	}

/* ----- [ News Pages ] --------------- */
.news-post {
	margin-bottom: 60px;
	}
.post-date {
	font-family: 'Germalt Bold', sans-serif;
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 1rem;
	text-transform: uppercase;
	}
.post-thumb {
	margin: 0 0 30px;
	}
.post-thumbnail {
	width: 100%;
	}
/*	
h1+p.post-date {
	margin-top: -2em;
	margin-bottom: 2em;
	}
*/
figure {
	margin: 0;
	margin-bottom: 1.5em;
	padding: 0;
	width: 100%;
	}
figcaption {
	font-size: 0.85em;
	line-height: 1.3em;
	margin: 0.4em 0;
	}
figure img {
	width: 100%;
	}

.sibling-nav {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-top: 40px;
	}
	
.archive-list {
	margin-bottom: 20px;
	}
.archive-list .on {
	color: var(--accent);
	}

/* ----- [ Feature Boxes ] --------------- */
.service-head {
	color: #fff !important;
	text-align: center;
	padding: 10px 20px;
	background: rgba(142,112,61,0.9);
	overflow: hidden;
	}
.service-head h3 {
	color: #fff;
	font-size: 1rem;
	margin: 0;
	text-transform: uppercase;
	}
.service-head small {
	display: block;
	line-height: 1.4em;
	margin-top: 3px;
	}
.service-thumb {
	width: 100%;
	-webkit-transition: .4s all ease;
	-o-transition: .4s all ease;
	transition: .4s all ease;
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
	}
.service-link {
	display: block;
	overflow: hidden;
	border: none;
	-webkit-transition: .4s all ease;
	-o-transition: .4s all ease;
	transition: .4s all ease;
	}
.service-link:hover {
	text-decoration: none;
	}

.service-link:hover .service-thumb {
	-webkit-transform: scale(1.05);
	-ms-transform: scale(1.05);
	transform: scale(1.05);
	}

@media screen and (min-width: 600px) {
	.service-head {
		position: absolute;
		left: 10px;
		right: 10px;
		bottom: 10px;
		padding: 10px 20px;
		background: rgba(142,112,61,0.9);
		overflow: hidden;
		}
	.restaurant-ads .service-head {
		min-height: 80px;
		}
}

/* ----- [ Media Cards ] --------------- */
.media-card {
	position: relative;
	width: 100%;
	margin: 0;
	display: flex;
	/*overflow: hidden;*/
	flex-direction:  column;
	height: 100%;
	transition: all 0.3s ease-in-out;
	}

.media {
	position: relative;
	overflow: hidden;
	}
.media img,
.news-image-link img {
	width: 100%;
	transition: all 0.3s ease-in-out;
	}
.media-card:hover .media img,
.news-image-link:hover img {
	/*transform: scale(1.1, 1.1);*/
	background: rgba(53, 82, 123, 0.9);
	background: rgba(0,0,0,0.5);
	}

.news-image-link {
	display: block;
	overflow: hidden;
	}

.ratio-container {
	position: relative;
	}
.ratio-container:after {
    content: '';
    display: block;
    height: 0;
    width: 100%;
    /* 16:9 = 56.25% = calc(9 / 16 * 100%) */ /*68.75*/
    padding-bottom: 68.75%;
}
.ratio-container > * {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.inner-link {
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10px;
	color: var(--accent);
	text-align: center;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	-webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
	-o-transition: all .2s ease;
	transition: all .2s ease;
	}
	
.media:hover .inner-link {
	background: rgba(53, 82, 123, 0.9);
	background: rgba(0,0,0,0.5);
	}

.inner-link .button,
.inner-link h3 {
	opacity: 0;
	-webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
	-o-transition: all .2s ease;
	transition: all .2s ease;
	margin-top: 10px;
	}
.inner-link h3:after {
	content: "";
	height: 2px;
	width: 70px;
	background: var(--accent);
	display: block;
	margin: 5px auto;
	}
.media:hover .inner-link .button,
.media:hover .inner-link h3 {
	opacity: 1;
	}
	
.card-body {
	color: #fff;
	padding: 10px;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	flex:  1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: rgba(0,0,0,0.2);
	-webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
    transition: all .2s ease;
	}

.card-title {
	font-size: 2rem;
	line-height: 1.1;
	margin: 0 0 0.2em;
	}
.card-title:after {
	content: "";
	height: 2px;
	width: 100px;
	background: #fff;
	display: block;
	margin: 20px auto 25px;
	}
.card-title small {
	font-size: 0.6em;
	}

.card-text {
	font-family: 'Inter', sans-serif;
	font-size: 1.2rem;
	line-height: 1.3;
	margin: 0 0 0.2em;
	font-weight: 500;
	}
.card-text .button {
	margin-bottom: 3px;
	}
	
.card-body:hover {
	color: var(--accent);
	/*color:  #fff;*/
	/*background: rgba(0,0,0,0.3);
	background: rgba(53, 82, 123, 0.9);*/
	background: rgba(0,0,0,0.6);
	}
.card-body:hover .card-title:after {
	background: var(--accent);
	}


@media screen and (min-width: 660px) {
	.card-title {
		font-size: 2rem;
		}
	.card-title:after {
		width: 80px;
		margin: 10px auto 15px;
		}
	.big-grid .grid-item:nth-child(9) {
		display: none;
		}
}
@media screen and (min-width: 920px) {
	.big-grid .grid-item:nth-child(9) {
		display: block;
		}
}
@media screen and (min-width: 1200px) {
	.card-title {
		font-size: 2.4rem;
		}
	.card-title:after {
		width: 100px;
		margin: 20px auto 25px;
		}
}

/* repurposed for At Home Grid */
.card-body2 {
	padding:10px 0;
	background: none;
	}
.card-title2 {
	margin: 0 0 0.2em;
	}
.media-card:hover .ratio-container a {
	background: rgba(0,0,0,0.3);
	}

.sticky-nav {
	position: -webkit-sticky;
	position: sticky;
	top: 230px;
	}
	
.sticky-nav .h1 {
	margin: 30px 0 10px;
	padding: 0 0 10px;
	border-bottom: 1px solid #ccc;
	}
.sticky-nav .h1:first-of-type {
	margin: 0;
	}
  
/* ----- [ feminista festival script hack ] -----------------*/	
.css-1qwg17u.e1hm5r1k14 {
	border: 1px solid #eee !important;
	margin-bottom: 20px !important;
	}
.e1hm5r1k1 {
	overflow: hidden;
	margin: 0 !important;
	}
.e1hm5r1k1 img {
	display: block;
	margin: -31% 0 0 0 !important;
	vertical-align: top !important;
	}
/* cart button */
.css-1fmsmy8.e1t3x36r1 {
	margin-top: 15px !important;
	}

/* ----- [ Content ] -----------------*/
.cms-content::first-of-type,
.cms-content.hidden::first-of-type {
	display: block;
	}

.cms-content ul,
.cms-content ol {
	margin: 0 0 1em;
	}
.cms-content li {
	list-style-type: square;
	list-style-position: outside;
	margin: 0 0 0.5em 1.2em;
	}
.cms-content ol li {
	list-style-type: decimal;
	list-style-position: outside;
	margin: 0 0 0.5em 1.2em;
	}

.cms-content p > img {
	max-width: 100%;
	/*margin: 40px auto;*/
	margin-bottom: 1em;
	}

.cms-content h4 {
	margin-top: 1.5em;
	}
.cms-content h3 + h4 {
	margin-top: 0.5em;
	}

.cms-content table {
	float: none;
	width: 100%;
	margin: 0 0 2em;
	border: 1px solid #ccc;
	}
.cms-content td,
.cms-content th {
	padding: 5px;
	line-height: 1.3em;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	}
.cms-content th,
.cms-content th p {
	font-weight: bold;
	background: #eee;
	}

.TextformatterVideoEmbed {
	margin-bottom: 1em;
	}

/* on the About Us page */
.inline-icon {
	overflow: hidden;
	}
.inline-icon a {
	display: inline-block;
	/*border-right: 1px solid #ccc;*/
	margin-right: 10px;
	}
.inline-icon img {
	margin: 0!important;
	opacity: 0.7;
	}
.inline-icon img:hover {
	opacity: 1;
	}
	
.sidebar h2,
.sidebar h3 {
	color: var(--black);
	margin-bottom: 1em;
	}


/* Helvetica Demo */
.helvetica-stack,
.extras-page h1,
.extras-page .col-1of2 p,
.extras-page .col-1of2 li,
.extras-page .col-1of2 h2,
.extras-page .col-1of2 h3,
.extras-page .col-1of2 h4,
.extras-page .col-1of2 .button {
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}
.extras-page h1,
.extras-page .col-1of2 h2,
.extras-page .col-1of2 h3,
.extras-page .col-1of2 h4 {
	font-weight: bold;
	}
.extras-page h1 {
	font-weight: 700;
	}
.extras-page .col-1of2 .button {
	font-weight: bold;
	padding: 15px 25px;
	}


/* ----- [ All Films Page ] --------------- */
.search-bar {
	font-family: 'Inter', sans-serif;
	margin: 0 0 40px;
	}

.search-bar-row   {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	}	
	
.form-input {
    width: 100%;
    margin: 0 auto;
	position: relative;
	white-space: nowrap;
	display: block;
	margin-bottom: 10px;
    }
	
.search-bar-label {
	margin: 0 0.5em 0 0;
	font-size: 1.2rem;
	display: block;
    }
.search-bar select {
	font-family: 'Inter', sans-serif;
	display: inline-block;
	width:  100%;
	overflow: hidden;
	height: 47px;
	font-size: 100%;
	margin:  0;
	padding: 12px 8px 5px;
	padding: 10px 8px 10px;
	background-color: #fff;
	border: 2px solid #000;
	border-radius: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	cursor: pointer;
	}
	
.search-bar select:after {
	content: "\f0d7";
	font-family: fontawesome;
	margin-left: -2em;
	margin-right: 2em;
	width:  0;
	pointer-events: none;
	}

.form-input:last-child:after {
	display: none;
	}
	
.search-bar .button {
	border: 2px solid #000;
	margin: 0;
	display: block;
	width: 100%;
	}

/* For IE <= 11 */
select::-ms-expand {
    display: none; 
    }
select:hover,
select:focus {
    /* background-color: var(--accent); */
    }

@media only screen and (min-width: 768px) {
	.search-bar-row {
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: space-between;
		align-items: flex-end;
		}
	.search-bar-label  {
		display: block;
		}
	.search-bar select {
		width: calc(100% - 15px);
		}
	.form-input {
		width: auto;
		margin: 0;
		flex: auto;
		}
}
	
/* ----- [ Programme Page ] --------------- */
.booking-dates {
	margin-top: 20px;
	}
.booking-button {
	margin: 0 10px 10px 0;
	}
.button.is-captioned {
	padding: 15px 30px 15px 20px;
	}
.is-captioned span {
	display: inline-block;
	margin-right: -1em;
	}

/* ----- [ Forms ] --------------- */
input, textarea, select {
	font-family: 'Inter', sans-serif;
	font-weight: 400;
	font-size: 16px;
	/*line-height: 1.75em;*/
	color: #333;
	/*-webkit-text-stroke: 0.1px;*/
	/*-webkit-appearance: none;*/
	}

/* normalise iOS */
input[type="checkbox"], input[type="radio"] {
    margin-left: 0
	}
input[type="checkbox"] {
    -webkit-appearance: checkbox
	}
input[type="radio"] {
    -webkit-appearance: radio
	}
	
.InputfieldSubmit {
	overflow: hidden;
	}
.InputfieldSubmit button {
	float: right;
	}
	
input:focus,
textarea:focus {
	background: #fff;
	}
	
input:focus {
	background: #fff;
	}

.padloper-cart-add-product {
	margin: 0 0 20px;
	}

.pad-qty {
	text-align: center;
	}

.qty-input {
	width: 50px;
	font-size: 1em;
	font-weight: 700;
	text-align: center;
	padding: 5px 0;
	height: 38px;
	vertical-align: middle;
	margin: 0 10px 0 0;
	border: 1px solid var(--black);
	}
	
.add-to-cart {
	vertical-align: middle;
	}

h3 + .side-cart {
	margin-top: -2em;
	}
.side-shopping-cart,
.side-shopping-cart2 {
	margin-top: -5px;
	padding: 15px 0;
	border-bottom: 1px solid var(--orange);
	}
.side-shopping-cart p,
.side-shopping-cart2 p {
	margin: 0;
	}

.pad-cart-row {
	border-bottom: 1px solid var(--orange);
	}
.pad-cart-row small {
	font-size: 14px;
	}


/* ----- [ Side Cart ] -------------- */
.pad-cart {
	border-bottom: 1px solid var(--orange);
	width: 100%;
	}
.pad-cart td,
.pad-cart th {
	font-size: 1.2rem;
	line-height: 1.2em;
	padding: 12px 0;
	vertical-align: middle;
	font-weight: 600;
	}
.pad-cart th {
	font-size: 0.9em;
	padding: 10px 0 12px;
	}
.pad-cart th:first-of-type {
	text-align: left;
	}

.pad-cart td {
	border-bottom: 1px solid var(--orange);
	}

.cart-image-large {
	max-width: 120px;
	margin: 0 20px 0 0;
	}

.pad-cart-product-title {
	color: #222;
	}
.pad-cart-product-title span {
	color: #666;
	font-size: 0.9em;
	}
.pad-cart-price,
.pad-cart-qty {
	width: 90px;
	position: relative;
	text-align: right;
	}

/* ----- [ Shopping Cart ] -----------------*/
.cart-wrapper {
	padding-bottom: 50px;
	margin-bottom: 30px;
	}
.side-cart-head {
	font-size: 1.6em;
	}
.close-cart {
	position: absolute;
	top: 25px;
	right: 20px;
	cursor: pointer;
	font-size: 20px;
	}

.remove-check {
	cursor: pointer;
	}
.remove-text {
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
	display: inline-block;
	font-size: 13px;
	font-weight: 400;
	line-height: 16px;
	color: #d83e49 !important;
	text-transform: lowercase;
	position: absolute;
	bottom: 16px;
	right: 0;
	border-bottom: 1px solid #d83e49;
	text-decoration: none;
	}

.cart-sale-notice {
	font-size: 13px;
	color: red;
	}

.pad-cart-row:hover .remove-text {
	opacity: 1;
	visibility: visible;
	text-decoration: none;
	}

.col.checkout-cart {
	overflow: hidden;
	}

.empty-cart {
	/*border: 2px solid #000;*/
	padding: 10px 0;
	}

.cart-totals {
	margin-top: 4px;
	}

.pad-edit-checkout,
.pad-editcart {
	margin-bottom: 15px;
	}
.checkout-cart .checkout-button {
	display: none;
	}

.checkout-instructions {
	margin-top: 20px;
	}

.customer {
	margin: 0 0 20px;
	overflow: hidden;
	}

.customer-info,
.invoice-meta {
	width: 100%;
	border-top: 1px solid #ccc;
	}
.customer-info td,
.invoice-meta td {
	vertical-align: top;
	padding: 5px 0;
	border-bottom: 1px solid #ccc;
	}
.customer-info td.no-rule {
	border-bottom: none;
	}

.customer-info.with-shipping {
	width: 50%;
	float: left;
	}

.shopping-cart {
	overflow: hidden;
	}

/* disable on Checkout */
.checkout .cart-link,
.shopping-cart .cart-link {
	pointer-events: none;
	cursor: default;
	opacity: 0.8;
	}

/* ----- [ Checkout Stuff ] -----------------*/
.form-group,
.Inputfield {
	margin: 0 0 10px;
	clear: both;
	}
.form-group label,
.Inputfield label {
	font-weight: 400;
	font-size: 1em;
	line-height: 1.6em;
	margin: 0 0 10px;
	}
	
.Inputfield .toggle-icon {
	display: none;
	}
.form-control,
.InputfieldContent input {
	display: block;
	width: 100%;
	padding: .5rem .75rem;
	line-height: 1.25;
	background-color: #fff;
	background-image: none;
	background-clip: padding-box;
	/*-webkit-appearance: none;*/
	transition: border-color ease-in-out .15s,
		box-shadow ease-in-out .15s;
	border: none;
	border: 1px solid #000;
	border: 1px solid rgba(0, 0, 0, 0.2);
	/*height: 55px;*/
	/*background: none !important;
	color: #000 !important;*/
	font-size: 18px;
	}

.InputfieldContent input:focus,
.InputfieldContent input:active {
	border: 1px solid #000;
	outline: none;
	box-shadow: none;
	}
	
.form-control:focus,
.form-control:active,
#mc_embed_signup input.email:focus,
#mc_embed_signup input.email:active {
	border: 1px solid #fff;
	color: #222;
	outline: #fff;
	box-shadow: none;
	background: #fff;
	}


.Inputfield_pad_firstname,
.Inputfield_email,
.Inputfield_pad_city,
.Inputfield_pad_postcode {
	float: left;
	width: 50%;
	}

.Inputfield_pad_lastname,
.Inputfield_pad_phone,
.Inputfield_pad_state,
.Inputfield_display_country {
	float: right;
	width: 49%;
	clear: none;
	}
.Inputfield_pad_countrycode,
.Inputfield_pad_paymentmodule,
.Inputfield_pad_shippingmodule {
	display: none;
	}

.Inputfield_pad_shippingmodule li {
	display: inline !important;
	}

.InputfieldRadiosStacked input {
	display: inline-block;
	width: auto;
	margin: 0 10px 0 0;
	}
	
.InputfieldError {
	text-align: right;
	margin: -1.6em 0 0 0;
	font-size: 0.9em;
	color: #f00;
	}
.InputfieldError .fa-flash {
	display: none;
	}
.InputfieldError + input {
	border-color: #f00;
	}

.stripe-card-input {
	font-family: 'Lato', sans-serif;
	font-size: 18px;
	line-height: 1.25;
	border: 1px solid #ccc;
	margin: 10px 0;
	padding: .5rem .75rem;
	}

#stripe-intents-form label {
	color: #222 !important;
	font-weight: 600;
	}


/* ----- [ Wizard; from Savoy ] -----------------*/
.wizard-steps {
	width: 100%;
	max-width: 1140px;
	min-width: 755px;
	margin: 0 auto;
	/*margin-top: 40px;*/
	/*overflow: hidden;*/
	}
.wizard-steps > ul{
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	list-style: outside none none;
	flex-flow: row wrap;
	justify-content: center;
	text-transform: uppercase;
	padding:5px 0;
	clear: both;
	margin-bottom: 30px;
	}

.wizard-steps li{
	position: relative;
	display: inline-block;
	font-size: 1em;
	line-height: 2.5;
	white-space: nowrap;
	text-align: center;
	flex: 1 1 0%;
	margin: 0px 2px;
	padding: 0 5px;
	color: #fff;
	position: relative;
	overflow: hidden;
	text-overflow: ellipsis;
	z-index: 1;
	background: #f8dbba;
	border-color: #f8dbba;
	}
.wizard-steps li a {
	color: #fff;
	text-decoration: none;
	}
.wizard-steps li:hover a {
	color: var(--orange);
	border-color: var(--orange);
	text-decoration: none;
	}
.wizard-steps li.CurrentWizardStep,
.wizard-steps li.CurrentWizardStep a {
	color: #fff;
	background: var(--orange);
	border-color: var(--orange);
	}
.wizard-steps li.UnrequiredWizardStep {display: none;}
.wizard-steps li.CurrentWizardStep > span.Number:before {color: #fff;}
.wizard-steps li > span.Order {display: none;}
.wizard-steps li > span.Number {
	display: inline-block;
	color: #fff;
	margin: 0px 0.4em 0px 0px;
	vertical-align: middle;
	font-size: 1.3rem;
	line-height: 1;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	z-index: 10;
	}

@media (max-width: 767px) {
	.wizard-steps {
		display: none;
		}
	.wizard-steps > ul {
		padding: 10px 0;
		margin: 0;
		margin-bottom:20px;
		}
	.wizard-steps li {
		float: left;
		padding: 0 10px;
		margin: 0;
		}
	.wizard-steps li {
		display: none;
		}
	.wizard-steps li.CurrentWizardStep {
		display: block;
		width: 100%;
		}
}


/* ----- [ Buttons ] -------- */
button,
.button,
a.button {
	font-family: 'Germalt Bold', sans-serif;
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	display: inline-block;
	font-size: 1.3rem;
	line-height: 1;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
	width: auto;
	color: #000;
	background: transparent;
	border: 1px solid var(--black);
	padding: 15px 25px;
	outline: none;
	cursor: pointer;
	box-shadow: none;
	-webkit-appearance: none;
	-webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -o-transition: all .2s ease;
    transition: all .2s ease;
    -moz-border-radius: 0;
    -khtml-border-radius: 0;
    -webkit-border-radius: 0;
    border-radius: 0;
    resize: none;
	}

button:hover,
.button:hover,
a.button:hover,
.button.on {
	background: var(--black);
	color: var(--accent);
	text-decoration: none;
	-webkit-appearance: none;
	}

.button-outline,
a.button-outline {
	color: #333;
	background: none;
	padding: 10px 20px;
	border: 1px solid #ccc;
	}

.button-reversed,
a.button-reversed {
    color: var(--accent);
    background: var(--black);
    border: 1px solid var(--accent);
    /*color: var(--black);
    background: transparent;
    border: 1px solid var(--black);*/
	}
.button-reversed:hover,
a.button-reversed:hover {
	color: var(--black);
	border-color: var(--black);
	background: transparent;
	}

.page-header .button,
.page-header a.button {
	border: none;
	margin-top: -4px;
	}

.button-full-width {
	width: 100%;
	margin: 0 0 10px;
	}
	
.button-small,
a.button-small {
	font-size: 1.1rem;
	padding: 12px 20px 13px;
	}
.button-large,
a.button-large {
	/*font-size: 0.95rem;*/
	}

.button-right,
a.button-right {
	float: right;
	}

.filter-button-group {
	justify-content: space-between;
	margin-left: 0;
	margin-right: 0;
	}

.filter-button-group .button {
	font-size: 0.9rem;
	margin: 0 0 10px;
	flex: 1;
	}

@media screen and (min-width: 600px) {
	.filter-button-group {
		justify-content: space-between;
		margin-left: -5px;
		margin-right: -5px;
		}
	.filter-button-group .button {
		margin: 0 5px 10px;
		}
}

.button-full {
	width: 100%;
	display: block;
	}

button:hover {
	background: #1Db954;
	}


/* ----- [ Calendar Filter Buttons ] --------------- */
.day-buttons {
	margin: 0 0 50px;
	display: none;
	}
.day-buttons button,
.day-buttons a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
	font-weight: 400;
	color: #000;
	padding: 15px 20px;
	background: #fff;
	border: none;
	border: 1px solid #000;
	border-right: none;
	width: 100%;
	}
.day-buttons div:last-of-type button,
.day-buttons div:last-of-type a {
	border: 1px solid #000;
	}

.day-buttons button:hover,
.day-buttons button.is-active,
.day-buttons a:hover,
.day-buttons a.is-active {
	color: var(--accent);
	background: var(--black);
	width: 100%;
	}

.day-list {
    position: relative;
    cursor: pointer;
    outline: none;
    overflow: visible;
    margin-bottom: 20px;
	}

.day-list:after {
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    right: 15px;
    top: 25%;
    margin-top: -3px;
    border-width: 6px 6px 0 6px;
    border-style: solid;
    border-color: #fff transparent;
    display: none;
	}

.day-list .dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    transition: all 0.3s ease-in;
    list-style: none;
    /* Hiding */
    opacity: 0;
    pointer-events: none;
	}

.day-list .dropdown li a {
    display: block;
    padding: 10px;
    text-decoration: none;
    color: #8aa8bd;
    border-bottom: 1px solid #e6e8ea;
    box-shadow: inset 0 1px 0 rgba(255,255,255,1);
	}

.day-list .dropdown li i {
    float: right;
    color: inherit;
	}

.day-list.dropdown li:first-of-type a {
    border-radius: 7px 7px 0 0;
	}

.day-list .dropdown li:last-of-type a {
    border-radius: 0 0 7px 7px;
    border: none;
	}

.day-list.active .dropdown {
    opacity: 1;
    pointer-events: auto;
    z-index: 10;
}

/* Hover state */
.day-list .dropdown li:hover a {
    background: #f3f8f8;
	}


@media only screen and (min-width: 600px) {
	.day-buttons {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		}
	.day-list {
		display: none;
		}
}



/* ----- [ Menu Buttons ] --------------- */
.menu-buttons {
	margin: 0 0 50px;
	flex-wrap: wrap;
	align-items: stretch;
	border-right: 1px solid #8e703d;
	border-top: 1px solid #8e703d;
	border-bottom: 1px solid #8e703d;
	}
.menu-buttons a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: #8e703d;
	line-height: 1.3em;
	padding: 7px 20px;
	padding: 7px 10px!important;
	background: #fff;
	border: none;
	vertical-align: middle;
	border-left: 1px solid #8e703d;
	width: 100%;
	white-space: normal;
	-webkit-appearance: none;
	-webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
	-o-transition: all .2s ease;
	transition: all .2s ease;
	}
.menu-buttons span {
	display: block;
	}

.menu-buttons a:hover,
.menu-buttons a.is-active,
.menu-buttons a.on {
	color: #fff;
	background: #8e703d;
	border: none;
	border-left: 1px solid #8e703d;
	width: 100%;
	}

@media only screen and (min-width: 600px) {
	.menu-buttons {
		border-top: none;
		border-bottom: none;
		}
}
/* button-see above */


/* ----- [ Podcast page ] -----------------*/	
.podcast-list > li {
	list-style-type: none;
	margin: 0 0 5px;
	}

.podcast-list .button {
	width: 100%;
	cursor: pointer;
	text-align: left;
	text-overflow: ellipsis;
	/* Required for text-overflow to do anything */
	white-space: nowrap;
	overflow: hidden;
	}
	
.cms-content iframe {
	margin-bottom: 1em;
	}


/* ----- [ Contact Page ] --------------- */
.footnote {
	font-size: 16px;
	}

/* ----- [ Restaurant Pages ] --------------- */
.flex-hero {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-end;
	flex: 1 1 auto;
	padding: 0;
	text-align: center;
	}
.hero-cta {
	padding: 30px 40px;
	padding: 20px;
	text-align: center;
	width: 300px;
	background: #7d2a29;
	background: rgba(125, 42, 41, 0.7);
	z-index: 10;
	}
.hero-cta h2 {
	color: #fff;
	font-size: 1.7rem;
	line-height: 0.9em;
	margin: 0 auto 5px;
	}
.hero-cta small {
	font-size: 0.9rem;
	text-transform: uppercase;
	}
.hero-cta.restaurant {
	text-align: center;
	background: #8e703d;
	background: rgba(142, 112, 61, 0.8);
	/*box-shadow: 300px 0 #740e0c;*/
	}

/* ----- [ PW Pager Nav: Search Results ] --------  */
.MarkupPagerNav {
	text-align: right;
	padding: 0 15px;
	}
.MarkupPagerNav li {
	display: inline-block;
	font-size: 15px;
	line-height: 1em;
	margin: 0 0 10px;
	}
.MarkupPagerNav a {
	display: block;
	border: 1px solid #e2e2e2;
	padding: 6px 8px;
	/*font-weight: bold;*/
	}

.MarkupPagerNav a:hover {
	border: 2px solid #e2e2e2;
	padding: 5px 7px;
	}

.MarkupPagerNavOn a {
	font-weight: bold;
	border: 1px solid #e2e2e2;
	background: #e2e2e2;
	color: #222;
	}

.quickedit2 {
	position: absolute;
	top: 0;
	left: -25px;
	}


/* ----- [ Footer ] --------------- */
.page-footer {
	color: #fff;
	color: var(--black);
	background: var(--black);
	background: var(--accent);
	padding: 50px 15px 15px;
	padding: 50px 0 15px; /* fix? */
	text-align: left;
	flex-shrink: 0;
	}

.page-footer .inner {
	max-width: var(--inner-wide);
	margin: 0 auto;
	}

.footer-links {
	flex-grow: 0;
	margin-bottom: 20px;
	}

.page-footer p,
.page-footer li {
	font-family: 'Inter', sans-serif;
	color: #fff;
	color: var(--black);
	font-size: 1rem;
	font-weight: 500;
	margin: 0;
	}
.page-footer li {
	margin: 0;
	}

.page-footer h5 {
	margin-bottom: 1.8em;
	}
	
.page-footer h5:not(:first-child)  {
	margin-top: 2.2em;
	}

.page-footer a {
	color: #fff;
	color: var(--black);
	}
.page-footer a:hover {
	color: var(--accent);
	color: #000;
	/*font-weight: bold;*/
	background: none;
	}
	
.page-footer img {
	/*filter: invert(1);*/
	/*mix-blend-mode: difference;*/
	}
	
.partner-logos img {
	max-width: 190px;
	max-height: 50px;
	margin-bottom: 26px;
	}

.footer-row .col {
	margin-bottom: 40px;
	}

p.site-copyright {
	/*float: left;*/
	text-align: center;
	text-align: left;
	margin: 1em 0 0;
	}
.site-copyright span {
	white-space: nowrap;
	}


/* Newsletter */
.ml-field-email {
	margin: 10px 0;
	}

	
.ml-field-email input,
#mc_embed_signup input.email {
	font-family: 'Inter', sans-serif;
	font-size: 1rem;
	padding: 6px;
	color: var(--black);
	background: transparent;
	border: 1px solid var(--black);
	width: 100%;
	}
#mc_embed_signup input::placeholder {
	color: #222 !important;
	}

#mc_embed_signup input.email:focus,
#mc_embed_signup input.email:active {
	border: 1px solid var(--black);
	color: var(--black);
	outline: var(--black);
	box-shadow: none;
	}
#mc_embed_signup input.email:focus::placeholder,
#mc_embed_signup input.email:active::placeholder {
	color: #ccc !important;
	}

.ml-error input {
	color: #222;
	background-color: transparent;
	}
.ml-form-embedSubmit .loading {
	display: inline-block;
	}
.ml-form-embedSubmitLoad {
	height: auto;
	width: auto;
	}

#mc_embed_signup input.email {
	margin: 10px 0;
	}
#mc_embed_signup {
	background: none !important;
	}
#mc-embedded-subscribe-form,
#mc_embed_signup form {
	text-align: left !important;
	padding: 0 !important;
	}
#mc_embed_signup label {
	display: none;
	}



@media only screen and (min-width: 600px) { /* 1024 */
	.page-footer p,
	.page-footer li {
		}
	.footer-row .col {
		margin-bottom: 20px;
		}
}

/* ----- [ Social Media Icons ] --------------- */
.social-icons-wrapper {
	white-space: nowrap;
	margin: 4px 0 0 10px;
	display: none;
	}
.social-icons-wrapper .social-icon {
    color: #fff;
    display: inline-block;
    height: 20px;
	width: 36px;
    vertical-align: middle;
	}

.social-icons-wrapper .social-icon a,
.social-icons-wrapper .social-icon a:visited {
    color: #fff;
    /*line-height: 22px;*/
	}
.social-icons-wrapper .social-icon-facebook:hover { color: #3b5998 }
.social-icons-wrapper .social-icon-instagram:hover { color: #f00 } /*231f20*/
.social-icons-wrapper .social-icon-linkedin:hover { color: #0077b5 }
.social-icons-wrapper .social-icon-twitter:hover { color: #1da1f2 }
.social-icons-wrapper .social-icon-vimeo:hover { color: #1ab7ea }
.social-icons-wrapper .social-icon-youtube:hover { color: red }
.social-icons-wrapper .social-icon-pinterest:hover { color: #bd081c }

.social-icons-wrapper .social-icon span {
	visibility: hidden;
	}

.social-icons-wrapper .social-icon svg {
    fill: currentColor;
   	max-width: 100%;
    max-height: 100%;
	}

.social-networks a:hover {
	opacity: 1;
	}

@media only screen and (min-width: 660px) {
	.social-icons-wrapper {
		display: block;
		}
}

.top-link {
    position: fixed;
    bottom: 60px;
    right: 16px;
    opacity: 0;
    -webkit-transition: opacity .4s ease;
    -moz-transition: opacity .4s ease;
    -o-transition: opacity .4s ease;
    transition: opacity .4s ease;
    z-index: 100;
    display: none;
	}
.top-link a {
    color: #e1e1e1;
    font-size: 2.5em;
    line-height: 1;
    display: block;
    height: 50px;
	width: 50px;
    outline: medium none;
    position: relative;
    /*text-indent: -9999px;*/
    z-index: 0;
    text-align: center;
    }
.top-link.show {
	opacity: 1;
	}


/* ----- [ Utility ] ------------------ */
.centered,
.centered p,
.centered h2,
.centered h3,
.text-centered,
.text-center {
	text-align: center;
	}
.text-left,
.text-left p,
.text-left h2,
.text-left h3 {
	text-align: left;
	}
.text-right,
.text-right p,
.text-right h2,
.text-right h3 {
	text-align: right;
	}
	
.text-small {
	font-size: 1em;
	}

.jumbotron {
	font-size: 1.2rem;
	text-align: center;
	padding: 20px;
	border: 2px solid var(--black);
	background: none;
	}

/* home page fetching unpublished parent malarky */
.jumbowrap {
	display: none;
	}
.jumbowrap:first-child {
	display: block;
	}

.all-caps {
	text-transform: uppercase !important;
	}

img.full {
	width: 100%;
	}
img.half {
	width: 50%;
	float: left;
	}
img.right {
	float: right;
	}
img.right {
	float: right;
	}

.hidden {
	display: none;
	}

/* for debugging; remove after production */
.debug {
	display: none;
	}

.flatpickr-day.today {
	border-color: var(--accent);
	}
.flatpickr-day.today:hover,
.flatpickr-day.today:focus,
.flatpickr-day:hover,
.flatpickr-day:focus {
	color:  #fff;
	background: var(--accent);
	border-color: var(--accent);
	}
.flatpickr-day.selected {
	background: var(--accent);
	border-color: var(--accent);
	}

/* ----- [ mobile/desktop ] --------------- */
.mobile {
	display: block;
	}
.desktop {
	display: none;
	}
@media only screen and (min-width: 660px) {
	.mobile {
		display: none;
		}
	.desktop {
		display: block;
		}
	/* for certain 2/3 pages */
	.pad-right {
		padding-right: 30px;
		}
}

/* ----- [ PW styles ] ---------------- */
#editpage {
	position: fixed;
	bottom: 0;
	left: 0; 
	padding: 5px 6px; 
	background: #db1174; 
	color: #fff; 
	display: block;
	font-weight: bold; 
	z-index: 1000;
	}
#editpage:hover {
	background: #ffffcc;
	color: #000; 
	}

.align_left {
	float: left;
	margin: 0 1em 0.25em 0;
	}
.align_right {
	float: right;
	margin: 0 0 0.25em 1em;
	}
.align_center {
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin: 0 0 1em;
	}

.WireFatalError {
	background: #a30000; 
	color: #fff; 
	padding: 1em; 
	position: relative;
	z-index: 9999;
	}

.time-machine {
	position: fixed;
	top: 5px;
	right: -310px;
	z-index: 200;
	padding: 10px;
	background: #7d2a29;
	border-radius: 10px 0 0 10px;
	display: none;
	}
.time-machine.is-open {
	right: 0;
	}
.time-machine form {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	}
.time-machine input {
	height: 35px;
	margin: 0;
	vertical-align: middle;
	}
.pull-out {
	color: #fff;
	font-size: 1.3em;
	margin-right: 10px;
	cursor: pointer;
	}

/* ----- [ PRINT STYLES ] ------------------ */
@media print {
	html, body {
		font-size: 10pt;
	}
	.page-header {
		position: absolute;
		}
	.page-footer {
		display: none;
		}

}

.main-navigation {
	/*flex: 0 1 50%;*/
	display: none;
	padding: 0 10%;
	}
	
.main-navigation.is-open {
	display: block;
	}

.main-nav-wrapper {
	position: absolute;
	width: 100%;
	top: 100%;
	top: 0;
	left: 0;
	height: 0;
	-webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
	-o-transition: all .2s ease;
	transition: all .2s ease;
	}
	
.main-nav-wrapper.is-open {
	min-height: 100vh;
	color: var(--black);
	background: #fff;
	overflow-y: scroll;
	padding-top: 140px;
	padding-bottom: 150px;
	}

@media only screen and (min-width: 660px) { 
	.top-strip {
		display: block;
		}
}
@media only screen and (min-width: 820px) { 
	.strip-text {
		margin: 0;
		padding-top: 4px;
		text-align: left;
		font-size: 0.9rem;
		font-weight: 700;
		/*text-transform: uppercase;*/
		}
	.strip-meta {
		}
}

@media only screen and (min-width: 990px) { /* 800 *//* nav width nav-toggle 2022 */
	.main-nav-wrapper {
		position: relative;  /* for dropnav */
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		flex-wrap: nowrap;
		justify-content: flex-end;
		align-items: center;
		width: 100%;
		top: 0;
		height: auto;
		padding: 0;
		}
		
	.is-fixed .main-nav-wrapper {
		/*padding: 4px 0 0;*/
		}
	
	.main-navigation {
		/*flex: 0 1 50%;*/
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-end;
		align-items: center;
		padding: 0;
		-webkit-transition: all .2s ease;
		-moz-transition: all .2s ease;
		-o-transition: all .2s ease;
		transition: all .2s ease;
		}

	.nav-toggle {
		display: none;
		}
}
		

/* ----- [ Isotope Grid ] ----------- */
.big-grid {
	margin-bottom: 100px;
	}
.grid-sizer,
.grid-item { 
	/*width: calc(33.333% - 20px);*/
	width: 50%;
	margin: 0 0 20px;
	margin: 0;
	}
.grid-item--width2 {
	width: 100%;
	}

.gutter-sizer {
	width: 2%;
	}

.grid-item img {
	width: auto;
	max-width: 100%;
	}

.related-work:last-of-type {
	display: none;
	}
@media only screen and (min-width: 900px) {
	.grid-sizer,
	.grid-item { 
		/*width: calc(33.333% - 20px);*/
		width: 25%;
		}
	.grid-item--width2 {
		width: 50%;
		}
}
@media only screen and (min-width: 1600px) {
	.grid-sizer,
	.grid-item { 
		/*width: calc(33.333% - 20px);*/
		width: 20%;
		}
	.grid-item--width2 {
		width: 40%;
		}
	.related-work:last-of-type {
		display: block;
		}
}

/* ----- [ Donations Page ] ----------- */
.wrapper h1 {
	font-family: 'Raleway', sans-serif;
	font-size: 40px;
	font-weight: 300;
	margin: 20px 0;
	}

.wrapper p {
	font-family: 'Raleway', sans-serif;
	font-size: 16px;
	line-height: 1.5em;
	margin-bottom: 30px;
	text-align: left;
	}

.donation-form {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: stretch;
	}

.donation-form fieldset legend {
	font-size: 18px;
	margin-left: -13px;
	padding: 0 15px;
	display: none;
	}

.donation-form label,
.donation-form2 label {
	display: block;
	font-size: 13px;
	padding-left: 2px;
	vertical-align: top;
	/*display: none;*/
	}
.donation-form2 label {
	font-size: 16px;
	}

.donation-form .text,
.donation-form2 .text {
	border: 2px solid #e8e8e8;
	box-sizing: border-box;
	font-size: 17px;
	margin-bottom: 8px;
	outline: none;
	padding: 4px;
	resize: none;
	width: 100%;
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-ms-transition: all .2s linear;
	-o-transition: all .2s linear;
	transition: all .2s linear;
	}

.donation-form select.text {
	margin-top: 4px;
	height: 30px;
	}

.donation-form .form-city,
.donation-form .form-state,
.donation-form .form-zip {
	display: inline-block;
	}

.donation-form .form-last-name {
	margin-left: 10px;
	}

.donation-form .form-city {
	width: 60%;
	}

.donation-form .form-state {
	margin: 0 10px;
	width: 60px;
	}

.donation-form .form-zip {
	width: 38%;
	float: right;
	}

.donation-form .form-amount {
	margin-bottom: 20px;
	overflow: hidden;
	}

.donation-form .form-amount label,
.amount.text {
	color: var(--black);
	background-color: #fff;
	border:   2px solid var(--black);
	cursor: pointer;
	display: block;
	float: left;
	font-size: 32px;
	font-weight: 400;
	line-height: 2;
	text-align: center;
	width: calc(50% - 10px) !important;
	padding: 10px 4px 0;
	margin: 0 10px 10px 0;
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-ms-transition: all .2s linear;
	-o-transition: all .2s linear;
	transition: all .2s linear;
	}
	
.donation-form .form-amount label:last-of-type {
	font-size: 28px;
	line-height: 2.3;
	}
	
.donation-form .form-amount label.amount.text:before,
.donation-form .text:before {
	content:"£";
	}
	
.donation-form .form-amount label:hover {
	color: #000;
	background-color: var(--accent);
	}
.form-amount input[type=radio] {
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	}

.donation-form .form-amount label.active,
.donation-form .form-amount label.focus {
	color: #fff;
	background-color: var(--accent);
	font-weight: 600;
}

.donation-form .text:focus {
	border: 2px solid #d0d0d0;
}


.donation-form .form-amount .amount {
	margin: 0;
	width: 90px;
}

.donation-form .form-amount input {
	}

.donation-form .form-cvc,
.donation-form .form-expiry {
	display: inline-block;
	vertical-align: top;
	width: 75px;
}

.donation-form .form-expiry {
	margin-left: 10px;
	width: 225px;
}

.donation-form .form-expiry select {
	width: 120px;
}

.donation-form .form-expiry select:last-child {
	margin-left: 10px;
	width: 90px;
}

.donation-form .form-submit {
	margin: 15px 0;
	text-align: center;
}

.messages {
	margin: 0;
	background-color: #efe1e1;
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-ms-transition: all .2s linear;
	-o-transition: all .2s linear;
	transition: all .2s linear;
	opacity: 0;
}

.messages.active {
	opacity: 1;
}

.messages p {
	color: #570707;
	padding: 10px 20px;
	font-weight: 600;
}


.homelinks {
	position: fixed;
	top: 0;
	right: 0;
	padding: 10px;
	z-index: 9999;
	background: #fff;
	opacity: 0;
	}
.homelinks:hover {
	opacity: 1;
	}

@media only screen and (min-width: 800px) {
	.donation-form .form-amount label,
	.amount.text {
		width: calc(25% - 10px) !important;
		}
}

/* ----- [ Forms 1: MTO Options ] --------------- */
/* The container */
.option-list {
	overflow: hidden;
	}
.option-list-item {
	position: relative;
	}
.horizontal-list {
	float: left;
	width: 50%;
	}

.option-label {
	display: block;
	position: relative;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	}

/* Hide the browser's default radio button/checkbox */
.option-label input {
	position: absolute;
	opacity: 0;
	cursor: pointer;
	}


/* Create a custom radio button */
.checkmark,
.radiobutton,
.imagebutton {
	position: absolute;
	top: 3px;
	left: 0;
	height: 20px;
	width: 20px;
	/*background-color: #eee;*/
	border: 1px solid #ccc;
	}
.radiobutton {
	border-radius: 50%;
	}
.imagebutton {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	top: 0;
	margin: 5px 10px 5px 0;
	height: 80px;
	width: 80px;
	}

.check-label,
.radio-label {
	padding: 0 0 5px 30px;
	}

/* On mouse-over, add a grey background color */
.option-label:hover input ~ .checkmark,
.option-label:hover input ~ .radiobutton {
	background-color: #ccc;
	}

/* When the radio button is checked, add a blue background */
.option-label input:checked ~ .checkmark,
.option-label input:checked ~ .radiobutton {
	background-color: #2196F3;
	}
.option-label input:checked ~ .imagebutton {
	border: 1px solid #222;
	}

/* Create the indicator (the dot/circle - hidden when not checked) */
.checkmark:after,
.radiobutton:after {
	content: '';
	position: absolute;
	display: none;
	}

/* Show the indicator (dot/circle) when checked */
.option-label input:checked ~ .checkmark:after,
.option-label input:checked ~ .radiobutton:after {
	display: block;
	}

/* Style the indicator (dot/circle) */
.option-label .radiobutton:after {
	top: 5px;
	left: 5px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: white;
	}
/* Style the indicator (checkmark) */
.option-label .checkmark:after {
	left: 6px;
	top: 0px;
	width: 8px;
	height: 15px;
	border: solid white;
	border-width: 0 3px 3px 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	}

.image-radio {
	position: relative;
	display: block;
	cursor: pointer;
	margin-bottom: 0;
	outline: 0;
	}
.image-radio input[type="radio"] {
	display: none;
	}

.image-radio img {
	/*outline: 1px solid #fff;
	outline-offset: -1px;
	padding: 5px;*/
	width: 100%;
	-webkit-transition: all .4s ease;
	-moz-transition: all .4s ease;
	-o-transition: all .4s ease;
	transition: all .4s ease;
	overflow: hidden;
	}

.image-radio:hover img,
.image-radio:active img {
	/*outline: 1px solid #666;*/
	/*opacity: 0.3;*/
	}

.image-radio-checked img,
.image-radio-checked img:hover {
	/*border-color: #4783B0;*/
	/*outline: 1px solid #000;*/
	}

.image-radio .button {
	margin-top: 10px;
	}
.image-radio:hover .button {
	background: #c6c6c6;
	color: #fff;
	}
.image-radio-checked .button {
	background: #c6c6c6;
	color: #fff;
	}

.option-select {
	position: absolute;
	top: 15px;
	left: 15px;
	color: #fff;
	font-size: 1.1rem;
	line-height: 1em;
	-webkit-transition: all .2s ease;
	-moz-transition: all .2s ease;
	-o-transition: all .2s ease;
	transition: all .2s ease;
	opacity: 0;
	}
.option-select .icon {
	display: inline;
	font-size: 1.6rem;
	margin: 0 6px 0 0;
	}

.image-radio:hover .option-select,
.image-radio:active .option-select,
.image-radio-checked .option-select,
.image-radio:hover .option-grid-info,
.image-radio:active .option-grid-info,
.image-radio-checked .option-grid-info {
	opacity: 1;
	}
.image-radio:hover .option-grid-info,
.image-radio:active .option-grid-info,
.image-radio-checked .option-grid-info {
	opacity: 1;
	bottom: 0;
	}

.image-radio:active .option-select .text:after,
.image-radio-checked .option-select .text:after {
	content: "Selected";
	display: inline;
	}

.swatch-list {
	position: relative;
	}
.swatch-item {
	display: inline-block;
	width: 44px;
	height: 44px;
	margin: 0 5px 0 0;
	}

.big-swatch {
	position: absolute;
	top: 0;
	left:0;
	}
.swatch-title {
	text-align: right;
	}
		
/* end */
