
/**
 * Theme Variables
 */
:root {
	/* Theme Colors */
	--color-primary: #f2ee56;
	--color-secondary: #0c0d0e;
	--color-white: #fff;
	--color-black: #000;
	--color-transparent: transparent;
	--color-current: currentColor;
	--color-gray: #111;
	--color-gray-light: #afafaf;
	--color-button-border: #b8b8b8;
	--font-face: "Moderat", sans-serif;
}

/**
 * General Styles
 */
*::-moz-selection {
	background: rgba(242, 238, 86, .7);
	color: #000;
	-webkit-text-stroke-width: 0;
}

*::selection {
	background: rgba(242, 238, 86, .7);
	color: #000;
	-webkit-text-stroke-width: 0;
}

::-webkit-scrollbar {
	height: .25rem;
	width: .5rem;
}

::-webkit-scrollbar-track {
	box-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, .05);
}

::-webkit-scrollbar-thumb {
	background-color: var(--color-primary);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1);
	transition-duration: 300ms;
}

::-webkit-scrollbar-thumb:hover {
	background-color: var(--color-secondary);
}

/**
 * Buttons
 */
.button {
	background-color: var(--color-white);
	border: 2px solid var(--color-button-border);
	padding: .75rem 1.25rem;
	text-decoration: none;
	color: var(--color-secondary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background-color 250ms, color 250ms, border-color 250ms;
}

.button.button-alt {
	background-color: var(--color-secondary);
	border: 2px solid var(--color-secondary);
	color: var(--color-white);
}

.button.button-underline {
	background-color: var(--color-transparent);
	border-color: var(--color-transparent);
	text-decoration: underline;
	text-underline-offset: .75rem;
	padding: 0;
	transition: text-decoration-color 320ms;
}

.button.button-bordered {
	border-color: var(--color-white);
	background-color: var(--color-transparent);
	color: var(--color-white);
}

.button.button-underline:hover {
	background-color: var(--color-transparent);
	border-color: var(--color-transparent);
	color: var(--color-black);
	text-decoration-color: var(--color-primary);
}

.button:hover {
	background-color: var(--color-secondary);
	color: var(--color-white);
	border-color: var(--color-secondary);
}

.button.button-alt:hover {
	background-color: var(--color-primary);
	color: var(--color-secondary);
}

.button.button-bordered:hover {
	background-color: var(--color-white);
	color: var(--color-secondary);
	border-color: var(--color-white);
}

@media screen and (min-width: 768px) {
	.button {
		padding: 1.125rem 2rem;
	}
}

/**
 * Master Header
 */
body.menu-active {
	overflow-y: hidden;
}

#masthead {
	padding-bottom: 1rem;
	padding-top: 2rem;
	position: relative;
	transition: background-color 250ms, padding 250ms;
	width: 100%;
	z-index: 100;
	margin-bottom: 1.5rem;
}

#masthead.scrolled {
	background-color: var(--color-white);
	padding-bottom: .5rem;
	padding-top: .5rem;
}

.masthead--inner {
	align-items: center;
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(12, minmax(0, 1fr));
}

.masthead--logo {
	max-width: 60px;
}

.masthead--branding {
	grid-column: span 6/span 6;
	position: relative;
	z-index: 50;
}

.masthead--trigger-wrap {
	display: flex;
	grid-column: span 6/span 6;
	justify-content: flex-end;
	position: relative;
	z-index: 50;
}

#masthead--trigger {
	background: none;
	border: none;
	padding: 0;
}

#masthead--trigger:focus, #masthead-trigger:active {
	outline: 0;
	border: 0;
	box-shadow: none;
}

.ham {
	cursor: pointer;
	transition: transform 400ms;
	user-select: none;
}

.line {
	fill: none;
	transition: stroke-dasharray 400ms, stroke-dashoffset 400ms;
	stroke: var(--color-secondary);
	stroke-width: 5.5;
	stroke-linecap: round;
}

.ham6 .top {
	stroke-dasharray: 40 172;
}

.ham6 .middle {
	stroke-dasharray: 40 111;
}

.ham6 .bottom {
	stroke-dasharray: 40 172;
}

.menu-opened .ham6 .top {
	stroke-dashoffset: -132px;
}

.menu-opened .ham6 .middle {
	stroke-dashoffset: -71px;
}

.menu-opened .ham6 .bottom {
	stroke-dashoffset: -132px;
}

.menu-updated-menu-container {
	background-color: var(--color-primary);
	bottom: -150vh;
	height: 100vh;
	left: 0;
	padding: 150px 1.5rem 3rem 1.5rem;
	position: fixed;
	transition: bottom 400ms;
	width: 100%;
}

.menu-opened .menu-updated-menu-container {
	bottom: 0;
}

#primary-menu {
	display: block;
	list-style-type: none;
	padding: 0;
	margin-block-start: 1em;
	margin-block-end: 1em;
}

#primary-menu a {
	color: var(--color-secondary);
	display: block;
	font-size: 2rem;
	padding: .75rem;
	text-decoration: underline;
	text-decoration-color: var(--color-transparent);
	text-underline-offset: .5rem;
	transition: text-decoration 250ms;
	white-space: nowrap;
	line-height: 1.15;
}

#primary-menu .menu-item-has-children {
	padding-bottom: .5rem;
}

#primary-menu .menu-item-has-children a {
	padding-bottom: .25rem;
}

#primary-menu a:hover, #primary-menu .current_page_item a {
	text-decoration-color: var(--color-primary);
}

#primary-menu .menu-button {
	display: inline-block;
	padding-left: .75rem;
	padding-top: 2.5rem;
}

#primary-menu .menu-button a {
	background-color: var(--color-secondary);
	color: var(--color-white);
	display: inline-block;
	font-size: 1rem;
	padding: .75rem 1rem;
	text-align: center;
	text-decoration: none;
	transition: background-color 250ms, color 250ms;
}

#primary-menu .menu-button a:hover {
	background-color: var(--color-white);
	color: var(--color-secondary);
}

#primary-menu .sub-menu {
	display: block;
	list-style-type: none;
	padding: 0;
}

#primary-menu .sub-menu .menu-item a {
	font-size: 1.25rem;
	margin-left: 1rem;
	padding-bottom: .25rem;
}

@media screen and (min-width: 500px) {
	#primary-menu {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (min-width: 768px) {
	body.menu-active {
		overflow-y: auto;
	}
	
	.masthead--branding {
		grid-column: span 2/span 2;
	}
	
	.menu-updated-menu-container {
		background-color: var(--color-transparent);
		grid-column: span 10/span 10;
		height: unset;
		max-width: unset;
		padding: 0;
		position: unset;
		width: unset;
		bottom: unset;
	}
	
	.masthead--trigger-wrap {
		display: none;
	}
	
	#primary-menu {
		align-items: center;
		display: flex;
		justify-content: flex-end;
	}
	
	#primary-menu a {
		font-size: .9rem;
	}
	
	#primary-menu .menu-item-has-children {
		padding-bottom: 0;
	}
	
	#primary-menu a, #primary-menu .menu-item-has-children a {
		padding: 1rem .75rem;
	}
	
	#primary-menu .menu-button {
		padding-left: .5rem;
		padding-top: 0;
	}
	
	#primary-menu .menu-button a {
		font-size: .9rem;
		padding: 1rem 1.5rem;
	}
	
	#primary-menu .menu-button a:hover {
		background-color: var(--color-primary);
	}
	
	#primary-menu .sub-menu {
		background-color: var(--color-white);
		left: 0;
		position: absolute;
		transform: scale(0);
		transform-origin: top center;
		transition: transform 250ms;
	}
	
	#primary-menu .menu-item-has-children {
		position: relative;
	}
	
	#primary-menu .menu-item-has-children:hover .sub-menu {
		transform: scale(1);
	}
	
	#primary-menu .sub-menu .menu-item a {
		display: block;
		font-size: 1rem;
		margin: 0;
		padding: .5rem 1rem;
	}
	
	#primary-menu .sub-menu .menu-item:first-child a {
		padding-top: 1rem;
	}
	
	#primary-menu .sub-menu .menu-item:last-child a {
		padding-bottom: 1rem;
	}
	
	#primary-menu .sub-menu .menu-item a:hover {
		text-decoration-color: var(--color-secondary);
	}
}

@media screen and (min-width: 1024px) {
	.masthead--branding {
		grid-column: span 1/span 1;
	}
	
	.masthead--logo {
		max-width: 75px;
	}
	
	.menu-updated-menu-container {
		grid-column: span 11/span 11;
	}
	
	#primary-menu a {
		font-size: 1rem;
		padding: .75rem 1rem;
	}
	
	#primary-menu .menu-button {
		padding-left: 1rem;
	}
	
	#primary-menu .menu-button a {
		padding: 1.15rem 2rem;
	}
}

/**
 * Footer
 */
#footer {
	background-color: var(--color-secondary);
	padding: 4rem 0;
}

#footer li > ol, #footer li > ul {
	margin-left: 0;
}

#footer a {
	text-decoration: none;
	transition: color 250ms;
}

.footer--logo {
	width: 75px;
	max-width: 100%;
	display: block;
	margin: 0 auto 2rem auto;
}

#footer-menu {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	list-style-type: none;
	margin: 0;
	padding: 0;
}

#footer-menu .menu-item {
	display: block;
	padding: 0;
}

#footer-menu > .menu-item {
	padding-bottom: .25rem;
}

#footer-menu .menu-item a {
	color: var(--color-white);
	display: block;
	font-weight: 300;
	padding: 0 0 .45rem 0;
	text-align: center;
}

#footer-menu > .menu-item > a {
	font-weight: 700;
	font-size: .875rem;
	padding-bottom: .5rem;
	padding-top: 1rem;
	position: relative;
	text-transform: uppercase;
}

#footer-menu > .menu-item > a:hover, #footer-menu .current_page_item a {
	color: var(--color-primary);
}

#footer-menu > .menu-item > a:after {
	background-color: var(--color-white);
	content: "";
	height: 2px;
	left: 0;
	margin: 0 auto;
	position: absolute;
	right: 0;
	top: 0;
	width: 22px;
}

#footer-menu .sub-menu {
	list-style-type: none;
	padding: 0 0 .5rem 0;
}

#footer-menu .sub-menu a {
	color: var(--color-gray-light);
	font-size: .875rem;
}

#footer-menu .sub-menu a:hover {
	color: var(--color-white);
}

.footer--contact, .footer--address {
	font-size: 13px;
	font-weight: 300;
}

.footer--contact {
	padding-bottom: 1rem;
	position: relative;
}

.footer--contact:after {
	content: "";
	bottom: 0;
	left: 0;
	width: 22px;
	background-color: var(--color-white);
	height: 2px;
	position: absolute;
	display: block;
	margin: 0 auto;
	right: 0;
}

.footer--left {
	color: var(--color-gray-light);
	text-align: center;
	padding-bottom: 1rem;
	line-height: 1.5;
}

.footer--address {
	padding-top: .75rem;
}

.footer--sub {
	margin-top: 1rem;
	color: var(--color-gray-light);
	font-size: .75rem;
	font-weight: 300;
}

.footer--sub:before {
	content: "";
	display: block;
	width: 100%;
	background-color: rgba(255, 255, 255, .2);
	grid-column: span 2/span 2;
	height: 1px;
	margin-bottom: 2rem;
}

.footer--sub-right {
	text-align: center;
	color: var(--color-gray-light);
}

.footer--sub-left {
	padding-bottom: 1rem;
	text-align: center;
}

.footer--sub-menu {
	list-style-type: none;
	padding: 0;
}

.footer--sub-menu a {
	color: var(--color-gray-light);
	display: block;
	padding: .25rem;
}

.footer--sub-menu a:hover {
	color: var(--color-white);
}

@media screen and (min-width: 500px) {
	#footer-menu {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin: 1.5rem 0;
	}
}

@media screen and (min-width: 768px) {
	#footer-menu {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 2rem;
	}
	
	#footer-menu .menu-item a {
		padding-bottom: 1rem;
		text-align: left;
	}
	
	#footer-menu .menu-item a:after {
		right: unset;
	}
	
	.footer--left {
		text-align: left;
	}
	
	.footer--right {
		display: block;
	}
	
	.footer--logo {
		margin: 0 0 1.5rem 0;
	}
	
	.footer--contact:after {
		right: unset;
	}
	
	.footer--sub {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: .5rem;
		align-items: center;
		margin-top: 1rem;
	}
	
	.footer--sub:before {
		margin-bottom: 1.25rem;
	}
	
	.footer--sub-menu {
		text-align: right;
		display: flex;
		flex-wrap: nowrap;
		gap: 1rem;
	}
	
	.footer--sub-left {
		text-align: left;
		padding-bottom: 0;
	}
	
	.footer--sub-right {
		display: flex;
		justify-content: flex-end;
	}
}

@media screen and (min-width: 1024px) {
	#footer-menu {
		gap: 4rem;
		margin: 0;
	}
	
	.footer--logo {
		margin: 0 0 2rem 0;
	}
	
	.footer--inner {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}
	
	.footer--left {
		padding-bottom: 4.25rem;
	}
	
	.footer--sub {
		margin-top: 1.5rem;
	}
	
	.footer--contact {
		padding-bottom: 1.5rem;
	}
	
	.footer--address {
		padding-top: 1.25rem;
	}
}

/**
 * Utilities
 */
.summerloving {
	font-family: "SummerLoving", cursive;
}

/**
 * Loading/Loaded Classes
 */
#main {
	transition: opacity 500ms;
}

#main.is-loading {
	opacity: 0;
}

.lazy {
	opacity: 0;
	transition: opacity 1500ms 1000ms;
}

.lazy.loaded {
	opacity: 1;
}
