:root {
	--rust_old:#a33800;
	--rust:#FF6F00;
	--char:#1c1b1b;
}

body,html {
	margin:0;
	height:100%;
	width:100%;
	scroll-padding-top:200px;
}
body {
	background-color:#fafaf9;
	padding:0;
	margin-top:90px;
	font:16px Arial,sans-serif;


}
* {
	box-sizing: border-box;
	transition: font-size .25s;
	xoutline:1px solid red;
}
a, img {
	outline:none;
}

header {
	background-color:rgb(242 240 234 / 0.8);
	position:fixed;
	z-index:5;
	top:0;
	left:0;
	width:100%;
	backdrop-filter: blur(10px);
	padding:23px 20px;
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
	border-bottom:1px solid white;
}

header div.head_title_flex a {
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
	white-space: nowrap;
	text-decoration:none;
	transition:opacity .25s;
}

header div.head_title_flex a:hover {
	opacity:.5;
}

header div.head_title_flex a>span:first-child,
header div.head_title_flex a>span:last-child {
	font:400 italic 1.5em Georgia,Cambria,"Times New Roman",Times;
	color: #1C1917;
	text-transform: uppercase;
}

header div.head_title_flex a>span:nth-child(2) {
	font:1rem Arial, sans-serif;
	color:#D6D3D1;
	display:inline-block;
	padding:0 .45em;
}

header>nav {
	flex:1 1 50%;
	text-align:right;
	font:700 1em Epilogue, sans-serif;
	text-transform: uppercase;
	display:flex;
	justify-content:flex-end;
	align-items:center;
	align-content:flex-start;
	gap:30px;
	padding-right:30px;
	white-space: nowrap;
}

header>nav a {
	color:#78716C;
	text-decoration: none;
	transition: color .25s;
}

header>nav a:hover {
	color:var(--rust);
}

header a.butt {
	white-space: nowrap;
	text-decoration: none;
	display:inline-block;
	background-color:var(--rust);
	color:white;
	text-transform:none;
	font-weight:400;
	font-size:1.125em;
	padding:14px 30px 12px 30px;
	border-radius:10px;
	transition:opacity .25s;
	transition: background-color .25s;

	box-shadow:0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)
}

header a.butt:hover {
	background-color:#c95011;
}

main {
	display:flex;
	justify-content:space-between;
	align-items:stretch;
	flex-flow:row wrap;
	border-bottom:1px solid #CCC;
}

main>section {
	position: relative;
	flex:0 0 66.66%;
	padding:0 4em 4em 4em; 
}

main>aside {
	flex:0 0 33%;
	background-color:#f9f7f2;
	position:relative;
	z-index:1;
	border-left:1px dashed rgb(214 211 209);
	padding:30px 30px;
}

.decorative_junk_1 {
	border-radius: 9999px;
	width: 500px;
	height:500px;
	z-index: -10;
	right: 25%;
	bottom:5rem;
	position:fixed;
	background:radial-gradient(
		circle,
		rgba(144, 238, 144, 0.15) 0%,
		rgba(255, 255, 255, 0) 70%
		)

}

div.content_wrap {
	max-width:48rem;
}

main>section h1 {
	font:600 4.5em "Newsreader";
	color:var(--char);
	margin:.65em 0 0 0;
	letter-spacing:-.03em;
	line-height:1.125em;
}
main>section h1 span {
	color:var(--rust);
	font-style:italic;
}

main>section p.subhead {
	font:500 2em "Newsreader";
	line-height:1.25em;
	color:var(--rust);
	margin:.75em 0 0 0;
}

p.content_body {
	font:400 1.125em Epilogue, sans-serif;
	color: rgb(70 71 65);
	line-height:1.625;
	max-width:675px;
}

div.gallery_grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-auto-rows: minmax(100px, auto);
	gap:24px;
	margin-top:80px;
	width:100%;

	max-width:1150px;
}

div.gallery_grid>div {
	background-color:#f2f0ea;
	border-radius:10px;
	padding:24px
}

div.gallery_card {
	/* image wrap */
	border-radius:15px;
}

div.card_img_wrap {
	/*height:287px;*/
	padding-bottom:56.7%;
	position:relative;
	overflow:hidden;
	border-radius:10px;
}

div.card_img_wrap>div {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;

	background-size:cover;
	background-position:center center;
	transition: transform .25s;
}

div.card_img_wrap>div:hover {
	transform:scale(1.075);
}

.card_img_wrap span {
	/* floaty */
	position:absolute;
	bottom:5px;
	right:5px;
	background-color:#D0FF95;
	color:#406900;
	font:400 .95em Epilogue;
	padding:8px 10px 5px 10px;
	text-transform: uppercase;
	border-radius:100px;
	box-shadow: 2px 2px 7px 0 rgba(0,0,0,.25);
}

div.gallery_card h3 {
	margin:1em 0 0 0;
	font:500 2em "Newsreader";
	color:var(--char);
	letter-spacing:normal;
	line-height:1.25em;
}

div.gallery_card p {
	margin:1.25em 0 0 0;
	font:400 1em "Epilogue";
	line-height:1.5em;
	color:#464741;
}


footer {
	background-color:#fafaf9;
	padding:65px 50px;
}

.foot_inner_flex {
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
}

.foot_title_flex {
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
}

.foot_title_flex>span:first-child,
.foot_title_flex>span:last-child {
	font:italic 1.125em  Georgia,Cambria,"Times New Roman",Times;
	color: #1C1917;
	text-transform: uppercase;
}

.foot_title_flex>span:nth-child(2) {
	font:1em Arial, sans-serif;
	color:#D6D3D1;
	padding:0 .45em;
}

.foot_center {
	margin:0;
	padding:0 2em;
	color:#a8a29e;
	font:.9em Georgia,Cambria,"Times New Roman",Times;
	text-transform: uppercase;
	text-align: center;
}

.foot_right_flex {
	font:.9em Georgia,Cambria,"Times New Roman",Times;
	color:#a8a29e;
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
	gap:2em;
}
.foot_right_flex a {
	color:#a8a29e;
	text-decoration: none;
	text-transform: uppercase;
	transition: color .25s;
}
.foot_right_flex a:hover {
	color:var(--rust);
}

.aside_head_flex {
	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
	border-bottom:1px solid #ccc;
}


.aside_head_flex h2,
.aside_head_flex span {
	line-height: 1;
	letter-spacing: 0.05em;
	letter-spacing:1.4px;
	font:700 .875em Epilogue;
	text-transform: uppercase;
	color:var(--char);
}
.aside_head_flex span {
	color:var(--rust);
}

.stuff {
	font:600 4em "Newsreader";
	color:rgba(0,0,0,.15);
	margin:.65em 0 0 0;
	letter-spacing:-.03em;
	line-height:1.125em;
	text-align:center;
}

form.raf_form {
	margin:0; padding:0;
}

fieldset {
	margin: 20px 0 0 0;
	padding: 0;
	border: 0;
	outline:0;

	background-color:white;
	padding:20px 7px;
	border:1px solid #ccc;
	border-left:none;
	border-right:none;

}

fieldset h3 {
	margin:0;
	font:400 1em Epilogue;
	color:#A8A29E;
	text-transform:uppercase;
	padding:10px 0;
}

fieldset input[type="text"],
fieldset input[type="email"] {
	width:100%;
	padding:8px 6px;
	outline:none;
	border:none;
	border-bottom:1px solid #CCC;
	margin-top:14px;
	font:.875em Epilogue;
}

.checkoff_flex {
	display:flex;
	justify-content:flex-start;
	align-items:center;
	flex-flow:row nowrap;
	margin-top:15px;
}

.checkoff_flex span {
	color: #78716C;
	font-size:.875em;
	padding-left:.5em;
}

.checkoff_flex input[type=checkbox]:checked {
	background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
	background-color: var(--rust);

}
.checkoff_flex input[type=checkbox] {
	box-sizing: border-box;
	width: 2px;
	min-width:20px;
	height: 20px;
	margin: 6px;
	padding: 0;
	border: 2px solid #CCC;
	border-radius:5px;
	appearance: none;
	
	outline: none;
	transition: outline 0.1s;
}
.centered {
	text-align:center;
	margin-top:20px;
}

fieldset input[type=button],
.jv_modal button {
	border:none;
	outline:none;
	white-space: nowrap;
	text-decoration: none;
	display:inline-block;
	background-color:var(--rust);
	color:white;
	text-transform:none;
	font-weight:400;
	font-size:1em;
	padding:7px 20px 6px 20px;
	border-radius:10px;
	transition:opacity .25s;
	transition: background-color .25s;
	box-shadow:0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	margin:0 auto;
	cursor:pointer;

	width:90%;
	max-width:200px;
}

fieldset input[type=button]:hover,
.jv_modal button:hover {
	background-color:#c95011;
}


/***************** OVERLAY *********************/




.signup_form_overlay {
	display:none;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:99999;
	background-color: rgba(0,0,0,.75);
}


.jv_wait {
	display:none;
	position:absolute;
	top:50%;
	left:50%;
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.lds-ripple {
	color: white;
}

.lds-ripple,
.lds-ripple div {
	box-sizing: border-box;
}
.lds-ripple {
	display: inline-block;
	position: relative;
	width: 80px;
	height: 80px;
}
.lds-ripple div {
	position: absolute;
	border: 4px solid currentColor;
	opacity: 1;
	border-radius: 50%;
	animation: lds-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
}
.lds-ripple div:nth-child(2) {
	animation-delay: -0.5s;
}
@keyframes lds-ripple {
	0% {
		top: 36px;
		left: 36px;
		width: 8px;
		height: 8px;
		opacity: 0;
	}
	4.9% {
		top: 36px;
		left: 36px;
		width: 8px;
		height: 8px;
		opacity: 0;
	}
	5% {
		top: 36px;
		left: 36px;
		width: 8px;
		height: 8px;
		opacity: 1;
	}
	100% {
		top: 0;
		left: 0;
		width: 80px;
		height: 80px;
		opacity: 0;
	}
}


.jv_modal {
	display:none;
	position:absolute;
	top:50%;
	left:50%;
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width:90%;
	max-width:400px;
	background-color:white;
	border-radius:5px;
	padding:0;
	margin:0;
	overflow:hidden;
}

p.jv_modal_header {
	background-color:var(--rust);
	color:white;
	font-size:1.5em;
	font-weight:bold;
	padding:5px 20px;
	margin:0;
}

p.jv_modal_message {
	margin:1em 0 0 0;
	padding:5px 20px 0 20px;
	font-size:1.125em;
}

.jv_modal button {
	display:block;
	max-width:200px;
	margin:20px auto;
	text-align:center;
}


/***************** END OVERLAY ****************/

/***************** GEN PAGE STUFF *************/

h1.gen_header {
	font:600 2em "Newsreader";
	color:var(--char);
	margin:4em 0 0 0;
	letter-spacing:-.03em;
	line-height:1.125em;
	text-align:center;
	border-bottom:1px solid #ccc;
}
h1.gen_header span {
	font-size:.75em;
	display:block;
}

.gen_marge {
	margin-top:120px;
}

.gen_pad {
	padding:0 20px;
}

p.rule_subhead {
	font-size:1.125em;
	text-align:center;
	max-width:850px;
	margin:2em auto;
}

.rules dl {
	max-width:850px;
	margin:0 auto;
}

.rules dt {
	font-size:1.125em;
	font-weight:600;
	margin:1em 0 0 0;
	border-bottom:1px solid #999;
}

.rules dd {
	margin:1em 0 0 0;
	padding:0;
	font-size:1em;
	line-height:1.5em;
}

.rules dd ul {
	font-size:1em;
	line-height:1.5em;
	margin-bottom:1em;
}

.rules dd ul li {
	margin-top:1em;
}




.small_width {
	max-width:850px;
	margin:0 auto;
}


.accordion_wrap {
	/*background-color:#f9f7f2;*/
	background-color:#f4f2ed;
	padding:20px;
	border-radius:10px;
}

.accordion_wrap h3 {
	font:600 1.25em Epilogue, sans-serif;
	/*
	background-color:white;
	
	padding:10px 10px;
	border-top:1px solid #CCC;
	margin:0;
	cursor:pointer;

	display:flex;
	justify-content:space-between;
	align-items:center;
	flex-flow:row nowrap;
	*/
}

/*
.accordion_wrap ul {
	font:400 1.125em Epilogue, sans-serif;
	color: rgb(70 71 65);
	line-height:1.625;
	background-color:white;
	margin-top:0;

	border-bottom:1px solid #CCC;
	padding-bottom:1em;
	display:none;
}
*/
.accordion_wrap ul li {
	padding-top:1em;
}

.material-symbols-outlined {
	
	font-variation-settings:
	'FILL' 0,
	'wght' 400,
	'GRAD' 0,
	'opsz' 24
}

.accordion_pointer {
	outline:1px solid #CCC;
	transition: transform .25s;
	transform:rotate(-90deg);
}

.accordion_pointer_up {
	transform:rotate(90deg) !important;
}

/***************** END GEN PAGE STUFF *************/


@media all and (max-width:1275px) {
	.foot_inner_flex {
		flex-wrap: wrap;
	}
	.foot_center {
		order:3;
		flex:0 0 100%;
		margin-top:2em;
	}
}

@media all and (max-width:1100px) {
	div.gallery_card h3 {
		font-size:1.5em;
	}
}


@media all and (max-width:1000px) {
	main>section h1 {
		font-size:3em;
	}

}
@media all and (max-width:975px) {
	div.gallery_grid {
		/* early pop to 1 column */
		grid-template-columns: repeat(1, 1fr);
		gap:10px;
	}
}

@media all and (max-width:900px) {
	/* nav break */
	header {
		flex-wrap: wrap;
		padding:5px 20px;
	}
	header div.head_title_flex {
		order:1;
	}
	header>nav {
		flex:0 0 100%;
		order:3;
		justify-content:flex-start;
		gap:16px;
	}

	header a.butt {
		order:2;
	}
}

@media all and (max-width:780px) {
	/* form break */
	div.gallery_grid {
		/* back to 2 cols for a moment */
		grid-template-columns: repeat(2, 1fr);
		gap:10px;
	}
	body {
		margin-top: 120px;
	}
	main {
		display:block;
	}
	.decorative_junk_1 {
		border-radius: 9999px;
		width: 250px;
		height:250px;
		z-index: -10;
		right: -10%;
		bottom:5rem;
		position:fixed;
		background:radial-gradient(
			circle,
			rgba(144, 238, 144, 0.15) 0%,
			rgba(255, 255, 255, 0) 70%
			);
	}

	.foot_inner_flex {
		flex-direction: column;
	}
	.foot_right_flex {
		margin-top:1em;
	}

	footer {
		background-color:#fafaf9;
		padding:35px 25px;
	}
}
@media all and (max-width:650px) {
	main>section {
		padding:0 30px 40px 30px; 
	}
}

@media all and (max-width:600px) {
	div.gallery_grid {
		grid-template-columns: repeat(1, 1fr);
		gap:10px;
	}
}

@media all and (max-width:550px) {
	header a.butt {
		padding:7px 15px 6px 15px;
		font-size:1em;
	}

	main>section h1 {
		font-size:2.5em;
	}

	main>section p.subhead {
		font-size:1.5em;
	}
}

@media all and (max-width:490px) {
	/* final nav snap */
	body {
		margin-top:160px;
	}
	header {
		flex-direction:column;
		padding:10px 15px;
	}

	header div.head_title_flex {
		order:1;
	}
	header>nav {
		flex:0 0 100%;
		order:2;
		justify-content:flex-start;
		gap:16px;
		padding:10px 0;
	}

	header a.butt {
		order:3;
		padding:7px 15px 6px 15px;
		font-size:1.25em;
	}
}

