@font-face {
	font-family: 'Cormorant Garamond';
	src: url('fonts/CormorantGaramond-Regular.ttf');
}

@keyframes wrong {
	0% { left: 0px; }
	14.29% { left: -0.25rem; }
	28.57% { left: 0.25rem; }
	42.86% { left: -0.25rem; }
	57.14% { left: 0.25rem; }
	71.43% { left: -0.25rem; }
	85.71% { left: 0.25rem; }
	100% { left: 0px; }
}

html, body {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	font-size: 20px;
}

* {
	box-sizing: border-box;
}

body {
	background-color: #eee;
	background-image: url('images/linen-paper-bw.jpg');
	background-size: 25em;
	overflow-x: hidden;
	font-family: 'Cormorant Garamond', serif;

	--contentInset: 0.8rem;
	--colourLink: #065B3E;
	--colourLinkHover: #107755;
	--colourLinkDots: #10775566;
	--colourFieldBg: #10775522;
	--colourFieldBgHover: #10775555;
	--colourPlaceholder: #1D3E35b5;
	--colourInputText: #1D3E35;
	--colourInputTextHover: #307563;

	--timerHeaderCollapse: 1s;
	--timerBarUnfurl: 1s;
	--timerOpacity: 0.5s;
	
	--logoRadius: 128px;
	--preAuthBarWidth: 200px;

	--raduDeepBlue: #132885;
}
body.pre-auth {
	overflow: hidden;
}
body>main,
body>footer,
body>#radu {
	opacity: 1;
	transition: opacity var(--timerOpacity);
}
body.pre-auth>main,
body.pre-auth>footer,
body.pre-auth>#radu {
	opacity: 0;
}

a {
	color: var(--colourLink);
	text-decoration-color: transparent;
	text-decoration-thickness: 2px;
	text-decoration-style: dotted;
	transition: color 0.5s, text-decoration-color 0.5s;
}
a:hover {
	color: var(--colourLinkHover);
	text-decoration-color: var(--colourLinkDots);
}


/*
PALETTE

Deep green - #1D3E35
Brown green - #304933
Brighter green - #065B3E

Pastel pink-ish - #E2CFC0
Cream - #F5EFB5
Light blue - #A0AFF0

*/

header {
	position: relative;
	width: 100%;
	height: 50vh;
	overflow: visible;
	background-color: #5C5C5C;
}
header.pre-auth {
	height: 100%;
}
header.trans {
	transition: height var(--timerHeaderCollapse);
}

#h-bg {
	position: absolute;
	inset: 0px;
	background-image: url('images/hengrave-bw.jpeg');
	background-size: cover;
	background-position: center center;
	filter: blur(0px);
	-webkit-filter: blur(0px);
}
header.pre-auth>#h-bg {
	filter: blur(0.5rem);
	-webkit-filter: blur(0.5rem);
	inset: -0.75rem;
}
header.trans>#h-bg {
	transition: filter var(--timerHeaderCollapse), -webkit-filter var(--timerHeaderCollapse);
}

#h-bar {
	width: 100%;
	font-size: 1.4em;
	background-color: white;
	position: absolute;
	left: 0;
	top: calc(50vh - 1.5em);
	height: 3em;
	overflow: hidden;
	z-index: 100;
}
#h-bar.pre-auth {
	left: 50%;
	width: 0px;
}
#h-bar.trans {
	transition: width var(--timerBarUnfurl), left var(--timerBarUnfurl);
}

#h-save {
	display: flex;
	column-gap: 2em; /*2x the gap either side of the logo*/
	opacity: 1;
	transition: opacity var(--timerOpacity);
}
#h-save>span {
	flex: 0 1 auto;
	width: 50%;
	padding: 1em var(--contentInset);
	line-height: 1em;
	font-style: italic;
	letter-spacing: 0.2em;
}
#h-save>span.l {
	text-align: right;
	padding-right: var(--logoRadius);
}
#h-save>span.r {
	text-align: left;
	padding-left: var(--logoRadius);
}
#h-save.pre-auth {
	opacity: 0;
}

#h-logo {
	position: absolute;
	top: calc(50vh - var(--logoRadius));
	left: calc(50% - var(--logoRadius));
	width: calc(var(--logoRadius) * 2);
	height: calc(var(--logoRadius) * 2);
	border-radius: 50%;
	background-color: #fff;
	backdrop-filter: blur(0px);
	-webkit-backdrop-filter: blur(0px);
	background-image: url('images/ep-logo-alpha.png');
	background-position: center center;
	background-size: cover;
	z-index: 200;
}
#h-logo.pre-auth {
	top: calc(50vh - calc(var(--logoRadius) * 2));
	left: calc(50% - var(--logoRadius));
	background-color: #fffc;
	backdrop-filter: blur(0.25rem);
	-webkit-backdrop-filter: blur(0.25rem);
}
#h-logo.trans {
	transition: top var(--timerHeaderCollapse), left var(--timerHeaderCollapse), background-color var(--timerHeaderCollapse), backdrop-filter var(--timerHeaderCollapse), -webkit-backdrop-filter var(--timerHeaderCollapse);
}


#h-auth {
	left: calc(50% - var(--preAuthBarWidth));
	width: calc(var(--preAuthBarWidth) * 2);
	height: 5em;
	top: 55vh;
	position: absolute;
	font-size: 1.4em;
	opacity: 1;
	transition: opacity var(--timerOpacity);
}
#h-auth.done {
	opacity: 0;
}

#h-login {
	width: calc(var(--preAuthBarWidth) * 2);
	height: 5em;
	padding: 1em;
	background-color: #fffc;
	backdrop-filter: blur(0.25rem);
	-webkit-backdrop-filter: blur(0.25rem);
	position: relative;
}
#h-login.wrong {
	animation-name: wrong;
  animation-duration: 500ms;
  animation-fill-mode: forwards;
}

#h-pwd {
	width: 100%;
	border: none;
	background-color: var(--colourFieldBg);
	height: 1.5em;
	font-size: 1em;
	padding: 0.25em;
	text-align: center;
	font-family: 'Cormorant Garamond', serif;
	outline: none;
	border: 0px solid transparent;
	transition: border var(--timerOpacity);
}
#h-pwd:focus {
	border: 0.1em solid var(--colourFieldBgHover);
}
#h-enter {
	width: 100%;
	padding: 0px;
	margin: 0.5em 0 0 0;
	height: 1em;
	font-size: 1em;
	border: none;
	background-color: transparent;
	text-align: center;
	font-family: 'Cormorant Garamond', serif;
	color: var(--colourInputText);
	font-weight: bold;
	cursor: pointer;
	outline: none;
	transition: color 0.5s;
}
#h-enter:hover {
	color: var(--colourInputTextHover);
}




.pg-width {
	width: 1024px;
	margin: 0px auto;
}



#radu {
	width: 100%;
	height: var(--logoRadius);
}

#radu.admin {
	background-color: #A0AFF044;
	background-image: url('images/floral-background-blue.png');
	background-size: auto 100%;
	background-repeat: repeat-x;
	backdrop-filter: blur(0.25rem);
	-webkit-backdrop-filter: blur(0.25rem);
	padding-top: var(--logoRadius);
	padding-bottom: calc(var(--contentInset) * 5);
	height: auto;
	box-shadow: 0px -3em 3em -5em inset #8799e7;
}
#radu.admin>div {
	display: flex;
	column-gap: var(--contentInset);
	padding: calc(var(--contentInset) / 2) 0;
	align-items: center;
}
#radu.admin>div>div {
	flex: 1;
}

#radu.admin .centre {
	text-align: center;
	padding-top: calc(var(--contentInset) * 2);
}

#radu.admin h2,
#radu.admin h3,
#radu-totals>span.amt {
	color: var(--raduDeepBlue);
}

#radu-totals {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-template-rows: auto auto;
	gap: calc(var(--contentInset) / 2);
}
#radu-totals>span.amt {
	font-size: 2em;
	text-align: center;
	font-variant: slashed-zero;
	transition: opacity 1s;
	opacity: 1;
}
#radu-totals>span.amt.refreshing {
	opacity: 0;
}
#radu-totals>span.fig {
	font-size: 0.8em;
	text-align: center;
	font-variant: small-caps;
	opacity: 0.8;
}

#radu-csv {
	margin: 1em;
	padding: 0.5em 1em;
	background-color: #bfc9f5;
	border: none;
	color: var(--raduDeepBlue);
	font-family: 'Cormorant Garamond', serif;
	font-weight: bold;
	transition: background-color 0.5s, color 0.5s;
	font-size: 1.2em;
	cursor: pointer;
}
#radu-csv:hover {
	background-color: #8799e7;
	text-decoration: none;
}

#radu-r-span {
	display: block;
	font-size: 0.9em;
	text-align: right;
	margin-top: 0.25em;
}
#radu-refresh {
	display: inline-block;
	color: var(--raduDeepBlue);
	padding: 0.25em 0;
	position: relative;
	cursor: pointer;
	text-decoration: underline;
	text-decoration-color: transparent;
	text-decoration-thickness: 2px;
	text-decoration-style: dotted;
	transition: color 0.5s, text-decoration-color 0.5s;
}
#radu-refresh:hover {
	color: #1234c8;
	text-decoration-color: #1234c8;
}
#radu-refresh.error {
	animation-name: wrong;
  animation-duration: 500ms;
  animation-fill-mode: forwards;
}



main {
	display: flex;
	column-gap: calc(var(--contentInset) * 1.5);
	padding-top: calc(var(--contentInset) * 2);
	margin-top: 2em;
}

#col-sticky {
	flex: 0 0 auto;
	width: 200px;
	overflow-x: unset;
}

#col-main {
	flex: 0 1 auto;
}

#col-images {
	flex: 0 0 auto;
	width: 300px;
	padding-bottom: 4em;
}

#m-sticky {
	position: sticky;
	top: var(--contentInset);
	bottom: 8em;
}

#m-menu {
	background-color: #eee;
	background-image: url('images/floral-background.png');
	background-size: cover;
	padding: var(--contentInset);
	font-size: 1.2em;
	box-shadow: 0px 0px 0.2em 0em #065B3E22;
}
#m-menu>a {
	display: block;
	padding: 0.5em 0;
	font-weight: bolder;
}
#m-menu-venue-mob {
	display: none !important;
}

#m-venue {
	padding: calc(var(--contentInset) + 2em) var(--contentInset) calc(var(--contentInset) + 5.35em);
}
#m-venue,
#m-venue-mob {
	line-height: 1.5em;
	font-size: 0.9em;
}
#m-venue>span,
#m-venue-mob span {
	display: block;
}
#m-venue-mob {
	display: none;
}
#m-venue-mob>section {
	display: flex;
	flex-direction: column;
	align-items: center;
}

#col-main section {
	padding: var(--contentInset);
	margin: 4em 0;
}

#m-welcome {
	margin-top: 0px !important;
	padding-top: 0px !important;
}

h1 {
	font-size: 2.4em;
	margin: 0px 0px 0.5em !important;
}
h2, h3 {
	color: #065B3E;
}

.m-times {
	display: grid;
	grid-template: auto / 4em 1fr;
	gap: 0.5em;
	padding-left: 0.5em;
}

.m-flower-div {
	width: 50%;
	margin-left: 25%;
}

h3.m-collapse {
	margin-bottom: 0px;
	position: relative;
	cursor: pointer;
}
h3.m-collapse:after {
	content: 'Read more';
	position: absolute;
	right: 0px;
	font-size: 0.8em;
	opacity: 0.6;
	font-weight: normal;
}
h3.m-collapse.shown:after {
	content: 'Less';
}





#r-container {
	width: 100%;
	background-color: #f3f3f3;
	padding: var(--contentInset);
	background-image: url('images/floral-background.png');
	background-size: 100% auto;
	background-repeat: repeat-y;
	transition: background-color 3s;
	box-shadow: 0px 0px 0.2em 0em #065B3E22;
}
#r-container.r-has-errors {
	background-color: darkred;
	transition: background-color 0.5s;
}

.r-wrapper {
	display: grid;
  grid-template-rows: 0fr;
	opacity: 0;
  transition: grid-template-rows 500ms, opacity 500ms;
}
.r-wrapper.shown {
  grid-template-rows: 1fr;
	opacity: 1;
}
.r-wrapper>.r-slider {
	overflow: hidden;
}

.r-row {
	padding: var(--contentInset) 0;
}

label.r-head {
	font-weight: bold;
	color: #1D3E35;
	transition: color 500ms;
}

#r-form legend {
	font-size: 0.8em;
}

.r-input-inset {
	padding: 0.5em var(--contentInset);
	display: flex;
	column-gap: 0.25em;
}
.r-input-inset>* {
	flex: 1;
}
.r-input-inset.mob-row>*{
	text-align: center;
}
.r-input-inset.mob-row>div *{
	cursor: pointer;
}

#r-form .r-error>label.r-head {
	color: darkred;
}
#r-form .r-error>div>div>input[type='radio']:before,
#r-form .r-error>div>input[type='text'],
#r-form .r-error>div>input[type='email']
{
	border: 0.1em solid darkred !important;
}

#r-form input[type='text'],
#r-form input[type='email'],
#r-form input[type='tel'],
#r-form textarea {
	padding: 0.25em;
	font-size: 1em;
	font-family: 'Cormorant Garamond', serif;
	color: var(--colourInputText);
	outline: none;
	display: block;
	width: 100px;
}
#r-form input[type='text']:focus,
#r-form input[type='email']:focus,
#r-form input[type='tel']:focus,
#r-form textarea:focus {
	border: 0.1em solid var(--colourFieldBgHover);
}

#r-form textarea {
	height: 6em;
	resize: none;
}

#r-form input[type='radio'] {
	font-size: 1em;
	cursor: pointer;
	width: 0.8em;
	height: 0.8em;
	position: relative;
	visibility: hidden;
	margin: 0 0.6em;
}
#r-form input[type='radio']:before {
	content: ' ';
	display: block;
	position: absolute;
	inset: 0px;
	visibility: visible;
	border: 0.1em solid var(--colourFieldBgHover) !important;
}
#r-form input[type='radio']:checked:after {
	content: ' ';
	display: block;
	position: absolute;
	inset: -0.2em;
	visibility: visible;
	background-image: url('images/checkbox.png');
	background-size: contain;
}
#r-form input[type='text'],
#r-form input[type='email'],
#r-form input[type='tel'],
#r-form textarea,
#r-form input[type='radio']:before,
#r-submit,
#r-another {
	background: var(--colourFieldBg);
	backdrop-filter: blur(0.25rem);
	-webkit-backdrop-filter: blur(0.25rem);
	border: 0.1em solid transparent;
	transition: border 500ms;
}
#r-form input::placeholder {
	color: var(--colourPlaceholder);
	opacity: 0.5;
}

#r-submit,
#r-another {
	height: 2em;
	font-size: 1.25em !important;
	font-family: 'Cormorant Garamond', serif;
	color: var(--colourInputText);
	cursor: pointer;
	outline: none;
	transition: color 0.5s, background-color 0.5s, border 0.5s !important;
	padding: 0.4em 0 0.6em;
	text-align: center;
	position: relative;
	font-weight: bold;
}
#r-submit:hover,
#r-another:hover {
	color: var(--colourInputTextHover);
	background-color: var(--colourFieldBgHover);
}
#r-submit.r-has-errors {
	animation-name: wrong;
  animation-duration: 500ms;
  animation-fill-mode: forwards;
}

#r-required {
	text-align: center;
	min-height: 1em;
	font-weight: normal;
	color: black;
	transition: color 0.5s, font-weight 0.5s;
}
#r-required.r-has-errors {
	font-weight: bold;
	color: darkred;
}




.i-wrapper {
	opacity: 0;
  transition: opacity 250ms;
}
.i-wrapper.shown {
	opacity: 1;
}
.i-image {
	opacity: 0;
  transition: opacity 1000ms, height 250ms;
	width: 300px;
	height: 0;
	background-size: 100% auto;
	background-position: top center;
	background-repeat: no-repeat;
}
.i-wrapper.shown>.i-image {
	height: 455px;
}
.i-image.shown {
	opacity: 1;
}
.i-image.i0 { background-image: url('images/photos/side-photo-0.jpg'); }
.i-image.i1 { background-image: url('images/photos/side-photo-1.jpg'); }
.i-image.i2 { background-image: url('images/photos/side-photo-2.jpg'); }
.i-image.i3 { background-image: url('images/photos/side-photo-3.jpg'); }
.i-image.i4 { background-image: url('images/photos/side-photo-4.jpg'); }
.i-image.i5 { background-image: url('images/photos/side-photo-5.jpg'); }
.i-image.i6 { background-image: url('images/photos/side-photo-6.jpg'); }
.i-image.i7 { background-image: url('images/photos/side-photo-7.jpg'); }
.i-image.i8 { background-image: url('images/photos/side-photo-8.jpg'); }
.i-image.i9 { background-image: url('images/photos/side-photo-9.jpg'); }
.i-image.i10 { background-image: url('images/photos/side-photo-10.jpg'); }
.i-image.i11 { background-image: url('images/photos/side-photo-11.jpg'); }
.i-image.i12 { background-image: url('images/photos/side-photo-12.jpg'); }
.i-image.i13 { background-image: url('images/photos/side-photo-13.jpg'); }
.i-image.i14 { background-image: url('images/photos/side-photo-14.jpg'); }
.i-image.i15 { background-image: url('images/photos/side-photo-15.jpg'); }
.i-image.i16 { background-image: url('images/photos/side-photo-16.jpg'); }
.i-image.i17 { background-image: url('images/photos/side-photo-17.jpg'); }
.i-image.i18 { background-image: url('images/photos/side-photo-18.jpg'); }




footer {
	width: 100%;
	padding: 2em 0 4em;
	background-color: white;
}

.f-cols {
	display: flex;
	column-gap: calc(var(--contentInset) * 2);
	align-items: center;
}
.f-cols>div {
	flex: 1;
	text-align: right;
}
.f-cols>div>* {
	display: block;
	margin: 1em 0 1em auto;
}
.f-cols>div>img {
	margin: 0 auto 0 0;
}
.f-cols>div>button {
	font-size: 0.9em;
	background: transparent;
	border: none;
	color: var(--colourLink);
	transition: color 0.5s, text-decoration-color 0.5s;
	font-family: 'Cormorant Garamond', serif;
	padding: 0 !important;
	cursor: pointer;
}
.f-cols>div>button:hover {
	color: var(--colourLinkHover);
}





@media (max-width:1050px) {
	body {
		--logoRadius: 96px;
	}
	#h-bar {
		font-size: 1.2em;
	}
	#h-save {
		column-gap: 1em;
	}
	.pg-width {
		width: 800px;
	}
	main {
	column-gap: calc(var(--contentInset) * 1);
	}

	#col-sticky {
		width: 180px;
	}
	#m-menu {
		font-size: 1em;
	}

	#col-images,
	.i-image {
		width: 250px;
	}
	.i-wrapper.shown>.i-image {
		height: 380px;
	}
}



@media only screen and (hover: none) and (pointer: coarse), (max-width: 850px) {
	html, body {
		font-size: 2.4vmax;
	}

	body {
		--logoRadius: 16vw;
		--preAuthBarWidth: 40vw;
		--contentInset: 0.8em;
	}

	header {
		height: 35vh;
	}
	#h-auth {
		top: 45vh;
	}
	#h-bar {
		top: calc(35vh - 2em);
		height: 4em;
		border-top-left-radius: 2em;
		border-bottom-left-radius: 2em;
	}
	#h-bar.pre-auth {
		left: var(--logoRadius);
	}
	#h-logo {
		top: calc(35vh - var(--logoRadius));
		left: -2vw;
	}
	#h-logo.pre-auth {
		top: calc(43vh - calc(var(--logoRadius) * 2));
		left: calc(50% - var(--logoRadius));
	}
	#h-save {
		flex-direction: column;
		padding: 0.5em 0 0.5em 0;
	}
	#h-save>span {
		width: 100%;
		padding: 0.25em 0 0.25em calc(var(--logoRadius) * 1.8) !important;
		text-align: left !important;
	}

	.pg-width {
		width: 100%;
		padding-left: var(--contentInset) !important;
		padding-right: var(--contentInset) !important;
	}

	#radu {
		height: calc(var(--logoRadius) + 1em);
	}
	#radu.admin {
		padding-bottom: var(--contentInset);
		margin-bottom: calc(var(--contentInset) * 3.25);
	}
	#radu-csv {
		display: block;
		margin: 1em auto;
	}

	#radu.admin>div,
	.f-cols,
	main {
		row-gap: var(--contentInset);
		flex-direction: column;
		font-size: 1.2em;
		align-items: stretch;
	}

	main {
		padding-top: 0px;
	}

	#col-sticky,
	#col-main {
		width: 100%;
		max-width: 100%;
	}

	#m-sticky {
		position: static;
		bottom: 8em;
	}

	#m-menu {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		background-position: center;
	}
	#m-menu>a {
		padding: 0.5em;
	}
	#m-menu-venue-mob {
		display: block !important;
	}

	#m-venue {
		display: none;
	}
	#m-venue-mob {
		display: block;
	}

	h3.m-collapse {
		text-align: left;
		margin-top: 0px;
		padding: 0.5em;
	}
	h3.m-collapse:after {
		right: 0.5em;
	}
	
	h2, h3 {
		text-align: center;
	}

	.r-input-inset {
		font-size: 1.25em;
		padding: 0.5em 0;
	}
	.r-input-inset:not(.mob-row) {
		flex-direction: column;
		row-gap: 0.25em;
		align-items: stretch;
	}
	.r-input-inset:not(.mob-row)>* {
		width: 100% !important;
	}

	#col-images {
		display: none;
	}

	.f-cols>div {
		flex: 1;
		text-align: center;
	}
	.f-cols>div>* {
		display: block;
		margin: 1em auto;
	}
	.f-cols>div>img {
		margin: 0 auto;
	}
}