/*
Theme Name: Recovery Sports Grill
Theme URI: http://underscores.me/
Author: Mannix Marketing, Inc.
Author URI: http://www.mannixmarketing.com
Description: Custom responsive theme for Recovery Sports Grill.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: recoverysportsgrill

This theme, like WordPress, is licensed under the GPL.

recoverysportsgrill is based on Underscores http://underscores.me/, (C) 2012-2015 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal http://necolas.github.com/normalize.css/
*/

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
/* normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
html{line-height:1.15;-webkit-text-size-adjust:100%}
body{margin:0}
hr{box-sizing:content-box;height:0}
code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}
a{background-color:transparent}
abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}
b,strong{font-weight:bolder}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative}
sub{bottom:-.25em}
sup{top:-.5em}
img{border-style:none}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}
button,select{text-transform:none}
[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}
[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}
[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:ButtonText dotted 1px}
fieldset{padding:.35em .75em .625em}
legend{color:inherit;display:table;max-width:100%;white-space:normal}
textarea{overflow:auto}
[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
[type=search]::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
details{display:block}
summary{display:list-item}
[hidden],template{display:none}
button,hr,input{overflow:visible}
progress,sub,sup{vertical-align:baseline}
[type=checkbox],[type=radio],legend{box-sizing:border-box;padding:0}
*:focus, *:focus-visible {outline-offset: 2px;}

/*--------------------------------------------------------------
# Colors
--------------------------------------------------------------*/
:root {
	--accent-color: #B40C2F;
	--red: #B40C2F;
	--black: #0B0B0B;
	accent-color: var(--accent-color);
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
html {font-size:16px; scroll-behavior: smooth;}
[id] { scroll-margin-top: 100px; }
body, button, input, select, textarea {
	color: #000;
	font-family: "Roboto", sans-serif;
	font-size: 24px;
	font-size: 1.5rem;
	line-height: 1.5;
}

h1, h2, h3, h4, h5, h6 {
  font-optical-sizing: auto;
  font-weight: 800;
	margin: 0 0 0.5em;
	line-height: 1.125;
}
h1 {
	font-family: "League Gothic", sans-serif;
  	font-weight: 400;
	text-transform: uppercase;
	font-size: 5.25rem;
}
h1 span {
	font-size: 3.5rem;
	font-family: "Rokkitt", serif;
	text-transform: none;
	display: block;
}
h2 {
	font-family: "Rokkitt", serif;
	font-size: 2.5rem;
}
h3 {
	font-family: "Rokkitt", serif;
	font-size: 1.8rem;
}

p {margin: 0 0 1.5em;}
dfn, cite, em, i {font-style: italic;}
blockquote {margin: 0 1.5em;}
address {margin: 0 0 1.5em;}
pre {background: #eee; font-family: "Courier 10 Pitch", Courier, monospace; font-size: 15px; font-size: 0.9375rem; line-height: 1.6; margin-bottom: 1.6em; max-width: 100%; overflow: auto; padding: 1.6em; }
code, kbd, tt, var {font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace; font-size: 15px; font-size: 0.9375rem;}
abbr, acronym {border-bottom: 1px dotted #666; cursor: help;}
mark, ins {background: #fff9c0; text-decoration: none;}
big {font-size: 125%;}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html{box-sizing:border-box}
*,:after,:before{box-sizing:inherit}
body{background:#fff}
hr{background-color:#ccc;border:0;height:1px;margin-bottom:1.5em}
ol,ul{margin:0 0 1.5em 0}
ul{list-style:disc}
ol{list-style:decimal}
li>ol,li>ul{margin-bottom:0;margin-left:1.5em}
dt{font-weight:700}
dd{margin:0 1.5em 1.5em}
img{height:auto;max-width:100%}
figure{margin:1em 0}
table{margin:0 0 1.5em;width:100%}

/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a, a:visited {
	color: var(--red);
	text-decoration: none;
	transition: all ease 0.2s;
}
a:hover, a:focus, a:active {
	color: #000;
	outline: transparent;
}
.page-section a:not(.button),
.entry-content a:not(.button),
.entry-content a:not(.button):visited {
	text-decoration: underline;
}
.page-section a:not(.button):hover,
.page-section a:not(.button):focus,
.entry-content a:not(.button):hover,
.entry-content a:not(.button):focus,
.entry-content a:not(.button):active {
}
.page-section a:not(.button):focus-visible,
.entry-content a:not(.button):focus-visible {
	outline: 1px dashed;
}
a[href*="tel:"] { white-space:nowrap; }
/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
.button, a.button, a.button:visited, button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	background-color: #FFF;
	border: 1px solid var(--red);
	border-radius: 100px;
	box-shadow: none;
	color: var(--red);
	display: inline-block;
	line-height: 1;
	padding: 15px 20px 15px 20px;
	transition: all ease 0.5s;
	text-transform: uppercase;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	position: relative;
	box-sizing: border-box;
}
.button:has(span) {
	padding: 15px 70px 15px 20px;
}
.gf_browser_ie.gform_wrapper .gform_footer input.button { padding: .6em 1em !important; }

.button.red-button, a.button.red-button, a.button.red-button:visited, button.red-button {
	background-color: var(--red);
	color: #FFF;
}
.white-bg .button.red-button {
	border-color: #000;
}
.button > span {
	border-left: 1px solid;
	position: absolute;
	right: 0;
	top: 0;
	padding: 15px 20px 15px 15px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.button.red-button > span {
	color: #FFF;
	border-color: #000;
}
p > .button:not(:first-of-type) {
	margin-left: 1rem;
}

.button:hover, a.button:hover, button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
.button:focus, a.button:focus,
button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
.button:active, a.button:active,
button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
	cursor: pointer;
	background: var(--red);
	color: #FFF;
	border-color: #FFF;
}
.button.red-button:hover, a.button.red-button:hover, a.button.red-button:visited:hover, button.red-button:hover,
.button.red-button:focus, a.button.red-button:focus, a.button.red-button:visited:focus, button.red-button:focus {
	background: #000;
	border-color: #000;
	color: #FFF;
}
.black-bg .button.red-button:hover, .black-bg a.button.red-button:hover, .black-bg a.button.red-button:visited:hover, .black-bg button.red-button:hover,
.black-bg .button.red-button:focus, .black-bg a.button.red-button:focus, .black-bg a.button.red-button:visited:focus, .black-bg button.red-button:focus,
.button.red-button:hover > span, .button.red-button:focus > span {
	border-color: #FFF;
}

.button:focus-visible, a.button:focus-visible,
button:focus-visible,
input[type="button"]:focus-visible,
input[type="reset"]:focus-visible,
input[type="submit"]:focus-visible {
	outline: 1px dashed;
	outline-offset: 3px;
}

.white-bg .button:focus-visible, .white-bg a.button:focus-visible, .white-bg button:focus-visible,
.paper-bg .button:focus-visible, .paper-bg a.button:focus-visible, .paper-bg button:focus-visible {
	outline-color: #000;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="search"],
textarea {
	border: 1px solid #757575;
	border-radius: 3px;
	color: #666;
	caret-color: var(--accent-color);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus {
	color: #111;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="search"] {
	padding: 3px;
}

textarea {
	padding-left: 3px;
	width: 100%;
	caret-color: var(--accent-color);
}

#tripleseat_embed_form label {
	font-size: 1.25rem;
}
#tripleseat_embed_form tr {
	padding-bottom: 15px;
}
#tripleseat_embed_form td input[type="text"],
#tripleseat_embed_form td select {
	width: 100%;
	padding: 5px;
	font-size: 1rem;
}
#tripleseat_embed_form .row_details_header h2 {
	margin-bottom: 0;
}
#tripleseat_embed_form input[type="text"].timeselect_input,
#tripleseat_embed_form input[type="text"].hasDatepicker {
	padding-left: 23px;
}

.timeselect {
	font-size: 1rem;
}

/*--------------------------------------------------------------
# Custom Styles
--------------------------------------------------------------*/
.container { max-width: 1400px; margin: 0 auto; box-sizing: border-box; position: relative; padding: 0 20px; }
#primary .container { max-width: 1100px; }
.nowrap { white-space: nowrap; }
#mannix { font-size: 1rem; padding: 1em 0; }
#mannix p { margin-bottom: 0.125em; }
.row { padding: 4em 0 2.5em; }
.sm-row { padding: 2em 0 0.5em; }
.top-padding { padding-top: 4em; }
.bottom-padding { padding-bottom: 2.5em; }
.margin-bottom {margin-bottom: 1.5em;}
.embed-container {height:0; margin-bottom:2em; max-width:100%; overflow:hidden; padding-bottom:56.25%; position:relative;}
.embed-container iframe, .embed-container object, .embed-container embed {position:absolute; top:0; height:100%; left:0; width:100%;}
.centered { text-align: center; }
.text-right { text-align: right; }
.flexed {display: flex; justify-content: space-between; flex-wrap: wrap;}
.flexed-centered {justify-content: center;}
.flexed-start {justify-content: flex-start;}
.flexed-end {justify-content: flex-end;}
.flexed-vertical-center {align-items: center;}
.flexed-reverse {flex-direction: row-reverse;}
.flex-73 { flex-basis: 73%; }
.flex-70 { flex-basis: 70%; }
.flex-65 { flex-basis: 65%; }
.flex-60 { flex-basis: 60%; }
.flex-50 { flex-basis: 50%; }
.flex-48 { flex-basis: 48%; }
.flex-45 { flex-basis: 45%; }
.flex-40 { flex-basis: 40%; }
.flex-35 { flex-basis: 35%; }
.flex-32 { flex-basis: 32%; }
.flex-30 { flex-basis: 30%; }
.flex-25 { flex-basis: 25%; }
.flex-23 { flex-basis: 23%; }
.flex-18 { flex-basis: 18%; }
.flexed-with-margin {margin-left:1%; margin-right:1%;}
.bg-image { height: 0; line-height: 0; background-size: cover; background-position: center; background-repeat:no-repeat; }
.four-by-three { padding-top: 75%; }
.square { padding-top: 100%; }
.portrait { padding-top: 133.33%; }
.full-height { height: 100%; }
.contain { background-size:contain; }
.remove-white-bg {mix-blend-mode:darken;}
.red-bg { background-color: var(--red); }
.black-bg { background-color: #000; }
.white-bg {	background-color: #fff; }
.white-text, .white-text a:not(.button) { color: #fff; }
.red-text { color: var(--red); }
.white-text a:not(.button):hover,
.white-text a:not(.button):focus { color:#BDBDBD; }
.red-bg a:not(.button):hover,
.red-bg a:not(.button):focus {
	color: #000;
}
.cement-bg {
	background-image: url('../jpg/background-cement.jpg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
body.webp-support .cement-bg {
	background-image: url('../webp/background-cement.jpg.webp');
}
.paper-bg {
	background-image: url('../png/paper.png');
	background-repeat: repeat;
}
body.webp-support .paper-bg {
	background-image: url('../webp/paper.png.webp');
}
.acf-map {
    width: 100%;
    height: 600px;
    margin: 0 0 1.5em;
}
.acf-map img {max-width: inherit !important;}
.p-60 {
	padding: 60px;
}
.p-60 > *:last-child {
	margin-bottom: 0;
}

div:has(>.top-rip),
div.row:has(>.top-rip) {
    position: relative;
    padding-top: calc(4em + 9.24%);
}
.top-rip {
	/*background-image: url('images/top-rip.svg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;*/
	aspect-ratio: 1440/133;
	position: absolute;
	top:-1px;
	left: 0;
	width: 100%;
}
.top-rip svg {
	object-fit: cover;
	object-position: center;
	inline-size: 100%;
	block-size: 100%;
}
.rip-red svg path {
	color: var(--red);
	fill: var(--red);
}
.rip-white svg path {
	color: #FFF;
	fill: #FFF;
}
.playbook-mark {
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	display: block;
}
.inverted {
	filter: invert(1);
}
.mark-1 {
	width: 235px;
	height: 200px;
	background-image: url('../png/playbook-marks-1.png');
}
.mark-2 {
	width: 100px;
	height: 100px;
	background-image: url('../png/playbook-marks-2.png');
}
.mark-3 {
	width: 300px;
	height: 250px;
	background-image: url('../png/playbook-marks-3.png');
}
.mark-4 {
	width: 210px;
	height: 175px;
	background-image: url('../png/playbook-marks-4.png');
}
#sticky-anchor {
	position: absolute;
	transition: all ease 0.3s;
	width: 100%;
	z-index: 0;
}
.site-header {
	transition: all ease 0.3s;
	padding: 25px 0;
	position: relative;
	z-index: 100;
}
.site-header.mobile-active,
.site-header.sticky {
	box-shadow: 2px 2px 3px rgba(0,0,0,0.5);
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 998;
	padding: 10px 0;
}
.site-logo, .footer-logo {
	line-height: 0;
}
.site-logo a, .footer-logo a {
	display: inline-block;
}
.site-logo a:focus-visible, .footer-logo a:focus-visible {
	outline: 1px dashed;
	outline-offset: 3px;
}
.footer-logo {
	margin-bottom: 0.5em;
}
.main-nav-wrapper {
	flex-basis: calc(100% - 180px);
}
.main-nav-wrapper .flexed div {
	flex-basis: auto;
}
.header-ctas {
	margin-left: 40px;
}
.header-ctas > span {
	display: inline-block;
	margin-right: 15px;
	&:last-of-type {
		margin-right: 0;
	}
}
a.member-portal {
	display: inline-block;
	vertical-align: middle;
	background: var(--red);
	color: #FFF;
	padding: 10px;
	border-radius: 50%;
	line-height: 0;
	text-align: center;
	font-size: 1.5rem;
}
.header-ctas > span a.button:has(span) {
	padding: 12px 70px 12px 20px;
}
.white-text a.member-portal:hover,
.white-text a.member-portal:focus {
	background: #FFF;
	color: var(--red);
}
.white-text a.member-portal:focus-visible {
	outline: 1px dashed #FFF;
}
.hero-image {
	position: relative;
	line-height: 0;
	background: #000;
	text-align: center;
}
.hero-image > img {
	width: 100%;
	height: auto;
}

#primary:has(.inline-header) {
	position: relative;
}
.inline-header {
	position: absolute;
	top: 0;
	right: 0;
	width: 70%;
	height: 100%;
	z-index: 1;
	opacity: 0.9;
}
.inline-header:before,
.inline-header:after {
	content: '';
	position: absolute;
	top: 0;
	height: 100%;
	z-index: 10;
}
.inline-header:before {
	width: 60%;
	left: 0;
	background: linear-gradient(to right, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, .80) 50%, rgba(0, 0, 0, 0) 100%);
}
.inline-header:after {
	width: 30%;
	right: 0;
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 1) 100%);
}
.inline-header img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.page-id-7 .inline-header img {
	object-position: bottom;
}
#primary:has(.inline-header) main {
	position: relative;
	max-width: 720px;
	margin-right: auto;
	z-index: 90;
}
#primary:has(.inline-header) .container {
	max-width: 1400px;
}

.page-cta {
	position: relative;
}
.page-cta:has(.page-cta-button) {
	padding-bottom: 50px;
}
.page-cta-image {
	border-radius: 8px;
	overflow: hidden;
	line-height: 0;
	margin-bottom: 24px;
}
.page-cta-text {
	text-align: center;
}
.page-cta-text h2 {
	font-size: 1.8rem;
}
.page-cta-text p {
	font-size: 1rem;
}
.page-cta-button {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
}
.page-cta-button p {
	margin-bottom: 0;
}
.footer {
	font-size: 1rem;
}

.divider {
	height: 500px;
	position: relative;
	overflow: hidden;
}
.divider-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-position: center;
	background-size: cover;
}
.divider-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 10px;
}
.text-section .container {
	max-width: 1100px;
}
.blocks-section .flexed {
	margin-bottom: 1.5em;
	border-radius: 8px;
	overflow: hidden;
}
.text-section h2,
.blocks-section .section-text h2 {
	font-size: 3rem;
}
.blocks-section .flexed.transparent-bg .section-photo {
	border-radius: 8px;
	overflow: hidden;
}
.blocks-section .flexed:not(.flexed-reverse).transparent-bg .section-text.p-60 {
	padding-right: 0;
}
.blocks-section .flexed.flexed-reverse.transparent-bg .section-text.p-60 {
	padding-left: 0;
}
.text-blocks-section .flexed > div > p {
	text-wrap: balance;
}
.text-blocks-section .flexed > div > *:last-child {
	margin-bottom: 0;
}
.text-section .flexed > div {
	flex-basis: 48%;
}
.section-photo {
	line-height: 0;
}
.section-photo img {
	object-fit: cover;
	block-size: 100%;
	inline-size: 100%;
	object-position: center;
}
.section-text > *:last-child {
	margin-bottom: 0;
}
.flexed-ctas-section .flexed-intro h2 {
	font-size: 5rem;
	line-height: 0.8;
	margin-bottom: 0.8rem;
	text-wrap: balance;
}
.flexed-ctas-section .flexed-intro p:first-of-type {
	font-size: 2.25rem;
	line-height: 1.27;
	font-family: "Rokkitt", serif;
}

.intro h2 {
	font-size: 2.875rem;
}
.slide-inner {
	padding: 0 20px;
}
.slide-buttons .slick-arrow {
	aspect-ratio: 1;
	border-color: #000;
	color: #000;
	background: transparent;
}
.slide-buttons .slick-next {
	margin-left: 20px;
}
.slide-buttons .slick-arrow:hover,
.slide-buttons .slick-arrow:focus {
	background-color: var(--red);
	border-color: var(--red);
	color: #FFF;
}
.slick-slide {
	transition: all ease 0.3s;
}
.slick-slide:not(.slick-center) {
	transform: scale(0.9);
}

.accordion-item {
    margin-bottom: 1.5em;
    border: 1px solid #777;
    border-radius: 8px;
    background: rgba(255,255,255,0.6);
    padding: 1.5em 25px;
}
.red-bg .accordion-item {
    background: rgba(0,0,0,0.2);
    border-color: #FFF;
}
details summary::-webkit-details-marker {
	display:none;
}
summary.accordion-title {
    position: relative;
    display: block;
    cursor: pointer;
}
summary.accordion-title h3 {
    font-size: 1.875rem;
    margin-bottom: 0;
    padding-right: 35px;
}
summary.accordion-title:after {
    content: '\2b';
    font-family: 'Font Awesome 6 Free';
    position: absolute;
    right: 0;
    top: 14px;
    line-height: 0;
    font-size: 1.8rem;
    color: var(--red);
    font-weight: 900;
    transition: all ease 0.3s;
}
.red-bg summary.accordion-title:after {
	color: #FFF;
}
summary.accordion-title:hover:after {
	transform: rotate(90deg);
}
details[open] summary.accordion-title:after {
  content: '\f068';
}
details[open] summary.accordion-title:hover:after {
	transform: none;
}
details.accordion .accordion-content {
    padding: 20px 10px 0.5em;
}

.cta-icon {
	aspect-ratio: 1;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #000;
	max-width: 100px;
	font-size: 2.5rem;
	margin: 0 auto 15px;
}
.cta-text p strong {
	font-size: 1.5rem;
	font-family: Rokkitt, serif;
}
.cta-text > *:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
# Page styles
--------------------------------------------------------------*/
#benefits ul,
#simple-steps ul {
	list-style: none;
	padding-left: 0;
	max-width: 900px;
	margin: 0 auto 1.5em;
}
#benefits li,
#simple-steps li {
	margin-bottom: 0.8em;
	padding-left: 1.75em;
	position: relative;
}
#benefits li:before,
#simple-steps li:before {
	content: '\f058';
	font-family: 'Font Awesome 6 Free';
	position: absolute;
	left: 0;
	top: 0;
	font-weight: 900;
	color: var(--red);
}
#benefits li:before {
	color: #000;
}
#benefits .section-text h2 {
	font-size: 4rem;
	margin-bottom: 0.25rem;
}
#benefits .flexed.flexed-vertical-center {
	align-items: stretch;
}

#check-in .intro p {
	max-width: 460px;
	margin: 0 auto 1.5em;
	font-size: 1rem;
}
#check-in {
	position: relative;
}
#check-in .playbook-mark {
	position: absolute;
}
#check-in .mark-1 {
	top: 9em;
	left: 4%;
}
#check-in .mark-2 {
	top: 9em;
	right: 6%;
	width: 200px;
	height: 200px;
	transform: rotate(-90deg);
}
#check-in .mark-4 {
	bottom: 2%;
	left: 2%;
}

.page-id-52 h1 {
	font-size: 4.75rem;
    text-align: center;
    text-wrap: balance;
}

.page-id-54 .inline-header img {
	object-position: left center;
}

.page-id-48 #sign-up {
	background-image: url('../jpg/hof-background.jpg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.error404 .entry-content ul {
	columns: 2;
	column-gap: 80px;
	max-width: 460px;
	margin: 0 auto;
}
/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
.footer-newsletter p {
	font-size: 1rem;
}
.footer-nav-wrapper p:has(strong),
.footer-newsletter p:has(strong) {
	font-size: 1.5625rem;
	margin-bottom: 20px;
	font-family: 'League Gothic', sans-serif;
}
.footer-nav-wrapper p:has(strong) strong,
.footer-newsletter p:has(strong) strong {
	font-weight: normal;
}
.social-icon {
	display: inline-block;
	vertical-align: middle;
	margin-right: 15px;
	font-size: 2rem;
}
.social-icon:last-of-type {
	margin-right: 0;
}
.white-text .social-icon a:hover,
.white-text .social-icon a:focus {
	color: var(--red);
}
.blog #primary .container,
.archive #primary .container {
	max-width: 1600px;
}
.grid {margin-top: 3em;}
.grid-sizer,
.grid-item { width: 47%; }
.gutter-sizer { width: 3%; }
.grid-item {margin-bottom: 3%;}
.post-header,
.post-grid-header { margin-bottom: 15px; }
.post-header img,
.post-grid-header img {width: 100%;}
.grid-item h2 {
	font-size: 1.8rem;
	margin-bottom: 0;
	text-decoration: underline;
}
.grid-item .entry-header {
	padding: 5px 15px;
}
.grid-item .entry-content {
	padding: 0 15px;
}
.grid-item .entry-footer {
	padding: 15px;
}

.entry-meta, .entry-footer { font-size: 90%; font-style: italic; }
.cat-links, .tags-links, .comments-link { display: block; width: 100%; }
.posts-navigation { padding-top: 10px; font-size: 90%; }
.entry-footer a,
.posts-navigation a {text-decoration: underline;text-decoration-style: dotted; text-decoration-thickness:1px;}
.entry-footer a:hover, .entry-footer a:focus,
.posts-navigation a:hover, .posts-navigation a:focus {text-decoration-style: solid;}

/*--------------------------------------------------------------
# Navigation
## Menus
--------------------------------------------------------------*/
.main-navigation, .header-navigation, .footer-navigation {
	width: 100%;
}

.main-navigation ul, .header-navigation ul, .footer-navigation ul {
	list-style: none;
	margin: 0;
	padding-left: 0;
}
.footer-navigation ul {
	columns: 3;
}
.main-navigation li, .header-navigation li, .footer-navigation li {
	display: inline-block;
	position: relative;
}
.footer-navigation li {
 	width: 100%;
}
.main-navigation li, .header-navigation li {
	margin-right: 20px;
}
.main-navigation li:last-of-type, .header-navigation li:last-of-type {
	margin-right: 0;
}

#primary-menu a, .header-navigation a, .footer-navigation a {
	display: inline-block;
	text-decoration: none;
}
#primary-menu a {
	font-family: "League Gothic", sans-serif;
	font-weight: 400;
	text-transform: uppercase;
	font-size: 1.3125rem;
	padding: 20px 0;
	text-decoration: underline;
	text-decoration-thickness: 3px;
	text-decoration-color: transparent;
	text-underline-offset: 15px;
	transition: all ease 0.5s;
}
.header-navigation a {
	font-size: 0.875rem;
}
.header-navigation a:hover,
.header-navigation a:focus {
	text-decoration: underline;
}
.header-navigation a:focus-visible {
	outline: 1px dashed #FFF;
	outline-offset: 2px;
}
.footer-navigation a {
	font-size: 1rem;
}

#primary-menu button {
	background-color: transparent;
	color: #FFF;
	font-size: 1rem;
	border-radius: 0;
	border: 0;
	display: inline-block;
	padding: 5px;
	vertical-align: 2px;
}

ul#primary-menu ul {
	background: var(--black);
	color: #FFF;
	box-shadow: 0 2px 5px rgba(255, 255, 255, 0.3);
	display: none;
	float: left;
	left: -999em;
	position: absolute;
	z-index: 99999;
}

ul#primary-menu ul ul {
	display: none;
	left: -999em;
	top: 0;
}

ul#primary-menu ul a {
	text-decoration: none;
	width: 250px;
	padding: 10px;
}

ul#primary-menu ul li {
	margin-right: 0;
}

#primary-menu li:hover > a,
#primary-menu li.focus > a,
#primary-menu li > a:focus,
#primary-menu .current_page_item > a,
#primary-menu .current-menu-item > a,
#primary-menu .current_page_ancestor > a,
#primary-menu .current-menu-ancestor > a {
	color: #FFF;
	text-decoration-color: var(--red);
	text-underline-offset: 5px;
}
#primary-menu li > a:focus-visible {
	outline: 1px dashed #FFF;
	outline-offset: 2px;
}

ul#primary-menu ul li:hover > a,
ul#primary-menu ul li.focus > a,
ul#primary-menu ul li > a:focus,
ul#primary-menu ul .current_page_item > a,
ul#primary-menu ul .current-menu-item > a,
ul#primary-menu ul .current_page_ancestor > a,
ul#primary-menu ul .current-menu-ancestor > a {
	background-color: var(--red);
	color: #FFF;
}

ul#primary-menu li:hover > ul,
ul#primary-menu li.focus > ul {
	display: block;
	left: auto;
}

ul#primary-menu ul li:hover > ul,
ul#primary-menu ul li.focus > ul {
	display: block;
	left: 100%;
}

/*--------------------------------------------------------------
## Mobile Navigation
--------------------------------------------------------------*/
.mobile-navigation {
    background-color: #111;
    height: 100%;
    overflow-x: hidden;
    padding-top: 180px;
    position: fixed;
    right: 0;
    top: 0;
    transition: 0.5s;
    visibility: hidden;
    width: 0;
    z-index: 800;
    overscroll-behavior: contain;
}
.mobile-nav-wrapper {
	display: none;
	margin-left: 30px;
}
.mobile-sticky-cta {
	display: none;
}
.white-text .mobile-sticky-cta a:not(.button) {
	background: #FFF;
	text-align: center;
	padding: 8px 10px;
	display: block;
	color: var(--red);
	transition: all ease 0.5s;
	text-transform: uppercase;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	& > span {
		margin-left: 15px;
	}
	&:hover {
		background: var(--red);
		color: #FFF;
		cursor: pointer;
	}
}
.site-header:has(.mobile-sticky-cta),.site-header:has(.mobile-sticky-cta).mobile-active, .site-header:has(.mobile-sticky-cta).sticky {
	padding-bottom: 0;
}

#togglenav {
	background: transparent;
	border-radius: 0;
	color: #FFF;
	border: 0;
	font-size: 3.125rem;
	font-weight: 900;
	padding: 0;
}
#togglenav > span {
	display: block;
	font-size: 0.8125rem;
}
.mobile-ctas {
	max-width: 260px;
	margin: 0 auto 3rem;
}
.mobile-navigation ul {
	list-style-type: none;
	padding: 0;
	max-width: 420px;
	margin: 0 auto;
}
.mobile-navigation ul ul {
	display: none;
	margin: 0;
}
.mobile-navigation ul ul li a {
	padding-left: 2.5em;
	text-transform: none;
}
.mobile-navigation li a {
	border-top: 1px solid rgba(255,255,255,0.25);
	color: #FFF;
	display: block;
	padding: 10px 20px;
	font-family: "Rokkitt", serif;
	text-transform: uppercase;
}
.mobile-navigation li.current-menu-item > a,
.mobile-navigation li > a:hover, .mobile-navigation li > a:focus {
	background: var(--red);
	color: #FFF;
}
.mobile-navigation li { position: relative; }
.mobile-navigation ul li.menu-item-has-children > a { margin-right: 30px; }
.mobile-navigation li > button { position: absolute; right: 0; top: 0; border-radius: 0; padding: 19.75px 10px; z-index: 700; border:0; border-top: 1px solid rgba(255,255,255,0.25); background: #111; color: #FFF; }
.mobile-navigation ul li.focus > ul {display: block;}

/*--------------------------------------------------------------
## Comment Navigation
--------------------------------------------------------------*/
.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {margin: 0 0 1.5em; overflow: hidden;}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {float: left; width: 50%;}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {float: right; text-align: right; width: 50%;}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
.screen-reader-text {clip: rect(1px, 1px, 1px, 1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; }
.screen-reader-text:focus {border-radius: 3px; box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6); clip: auto !important; display: block; font-size: 14px; font-size: 0.875rem; font-weight: bold; height: auto; left: 5px; line-height: normal; padding: 15px 23px 14px; text-decoration: none; top: 5px; width: auto; z-index: 100000;}
#content[tabindex="-1"]:focus {outline: transparent;}
a.skip-link {color: #000; background-color: #FFF;}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-delay: -1ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    background-attachment: initial !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    transition-delay: 0.01ms !important;
  }
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {display: inline; float: left; margin-right: 1.5em;}
.alignright {display: inline; float: right; margin-left: 1.5em;}
.aligncenter {clear: both; display: block; margin-left: auto; margin-right: auto;}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before, .clear:after, .entry-content:before, .entry-content:after, .comment-content:before, .comment-content:after, .site-header:before, .site-header:after, .site-content:before, .site-content:after, .site-footer:before, .site-footer:after {content: ""; display: table; table-layout: fixed;}
.clear:after, .entry-content:after, .comment-content:after, .site-header:after, .site-content:after, .site-footer:after {clear: both;}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {margin: 0 0 1.5em;}
.widget select {max-width: 100%;}

/*--------------------------------------------------------------
# Content
## Posts and pages
--------------------------------------------------------------*/
.sticky {display: block;}
.byline, .updated:not(.published) {display: none;}
.single .byline, .group-blog .byline {display: inline;}
.page-content, .entry-content, .entry-summary {margin: 1.5em 0 0;}
.page-links {clear: both; margin: 0 0 1.5em;}
.blog .format-aside .entry-title, .archive .format-aside .entry-title {display: none;}
.comment-content a {word-wrap: break-word; }
.bypostauthor {display: block; }
embed, iframe, object {max-width: 100%;}
.wp-caption {margin-bottom: 1.5em; max-width: 100%; }
.wp-caption img[class*="wp-image-"] {display: block; margin-left: auto; margin-right: auto; }
.wp-caption .wp-caption-text {margin: 0.8075em 0; }
.wp-caption-text {text-align: center; }

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {margin-bottom: 1.5em;}
.gallery-item {display: inline-block; text-align: center; vertical-align: top; width: 100%;}
.gallery-columns-2 .gallery-item {max-width: 49%;}
.gallery-columns-3 .gallery-item {max-width: 32.33%; }
.gallery-columns-4 .gallery-item {max-width: 24%; }
.gallery-columns-5 .gallery-item {max-width: 19%; }
.gallery-columns-6 .gallery-item {max-width: 15.66%; }
.gallery-columns-7 .gallery-item {max-width: 13.28%; }
.gallery-columns-8 .gallery-item {max-width: 11.5%; }
.gallery-columns-9 .gallery-item {max-width: 10.11%; }
.gallery-caption {display: block; }

/*--------------------------------------------------------------
# Media Queries
--------------------------------------------------------------*/
@media screen and (max-width: 1920px){
	#check-in .mark-3 {
		height: 200px;
		width: 200px;
	}
	#check-in .mark-4 {
		height: 150px;
		width: 150px;
	}
}
@media screen and (max-width: 1680px){
	#check-in .mark-3 {
		height: 100px;
		width: 100px;
	}
	#check-in .mark-4 {
		height: 75px;
		width: 75px;
	}
}
@media screen and (max-width: 1500px){
	#check-in .mark-1 {
		top: 6.5em;
		left: 2%;
	}
	#check-in .mark-2 {
		top: 6em;
		right: 2%;
	}
}
@media screen and (max-width: 1400px){
	.footer-nav-wrapper.flex-48 {
	    flex-basis: 485px;
	}
}
@media screen and (max-width: 1300px){
	.p-60 {
	    padding: 40px;
	}
	.blocks-section .flexed:not(.flexed-reverse).transparent-bg .section-text.p-60 {
		padding-left: 0;
	}
	.blocks-section .flexed.flexed-reverse.transparent-bg .section-text.p-60 {
		padding-right: 0;
	}
}
@media screen and (max-width: 1200px){
	.main-navigation li {
		margin-right: 15px;
	}
	.header-ctas {
	    margin-left: 30px;
	}
	.header-ctas > span {
		margin-right: 10px;
	}
	.header-ctas > span a.button:has(span) {
		font-size: 0.9rem;
	}
	.footer-nav-wrapper.flex-48 {
	    flex-basis: 320px;
	}
	.footer-navigation ul {
	    columns: 2;
	}
}
@media screen and (max-width: 1125px){
	.site-header .container {
		padding: 0 10px 0 0;
	}
	.site-logo img {
		width: 150px;
		height: 100px;
	}
	#check-in .mark-1,
	#check-in .mark-2 {
		width: 150px;
		height: 100px;
		top: 3.5em;
	}
}
@media screen and (max-width: 1080px){
	.main-navigation li {
		margin-right: 10px;
	}
	.header-ctas {
	    margin-left: 20px;
	}
	.header-ctas a.button > span {
		padding: 12px 15px 12px 10px;
	}
	.header-ctas > span a.button:has(span) {
	    padding: 12px 60px 12px 20px;
	}
	#primary-menu a {
		font-size: 1.25rem;
	}
}
@media screen and (max-width: 1023px){
	.site-header {
		padding: 10px 0;
	}
	.mobile-nav-wrapper {
		display: block;
	}
	.header-navigation,
	.menu-primary-container {
		display: none;
	}
	.ctas-section .flexed {
		display: block;
	}
	.ctas-section .page-cta {
		max-width: 600px;
		margin: 0 auto 3rem;
	}
	#primary.row:has(.inline-header){
		padding-top: 0;
	}
	.inline-header {
		position: relative;
		right: auto;
		width: 100%;
		height: 350px;
		opacity: 1;
		margin-bottom: 3em;
	}
	.inline-header:before,
	.inline-header:after {
		display: none;
	}
	.inline-header img {
		object-position: center;
	}
	.page-id-50 .inline-header img {
		object-position: center bottom;
	}
	#primary:has(.inline-header) main {
		max-width: 100%;
		margin: 0 auto;
	}
	#benefits .section-text h2 {
		font-size: 3rem;
	}
}
@media screen and (max-width: 960px){
	#mannix .flexed,
	.blocks-section .flexed {
		display: block;
	}
	.footer-nav-wrapper {
		display: none;
	}
	.footer-newsletter.flex-30 {
		flex-basis: 60%;
	}
	.site-footer.top-padding {
	    padding-top: 1em;
	}
	#mannix {
		text-align: center;
	}
	.social-media-wrapper {
		margin-top: 20px;
	}
}
@media screen and (max-width: 860px){
	.text-blocks-section .flexed,
	.flexed-ctas-section .container > .flexed {
		display: block;
	}
}
@media screen and (max-width: 768px){
	.slick-slide:not(.slick-center) {
	    transform: none;
	}
	.site-footer .flexed {
		display: block;
	}
	.footer-newsletter {
		text-align: center;
	}
	.footer-newsletter p:last-child {
		text-align: center !important;
	}
	.entry-content .alignleft,
	.entry-content .alignright {
		display: block;
		float: none;
		margin: 0 auto;
	}
	.page-id-48 #primary.row {
		padding-bottom: 0;
	}
}
@media screen and (max-width: 600px){
	.page-id-52 h1,
	h1 {
		font-size: 4.25rem;
	}
	h1 span {
    	font-size: 2.75rem;
    }
    h2 {
    	font-size: 2rem;
    }
    .intro h2,
    .text-section h2,
	#benefits .section-text h2,
    .blocks-section .section-text h2 {
	    font-size: 2.5rem;
	}
	.flexed-ctas-section .flexed-intro h2 {
    	font-size: 4rem;
    }
    .flexed-ctas-section .flexed-intro p {
    	font-size: 1.5rem;
    }
	.mobile-nav-wrapper {
	    margin-left: 20px;
	}
	.header-ctas {
		margin-left: 0;
	}
	main .playbook-mark.mark-2,
	.header-ctas > span:first-of-type {
		display: none;
	}
	.entry-content p:has(a.button:nth-of-type(2)) > a.button {
		display: table;
		margin: 0 0 1em;
		min-width: 250px;
	}
	.entry-content p:has(a.button:nth-of-type(2)) > a.button:last-child {
		margin-bottom: 0;
	}
	.accordion-item {
		padding: 1.5em 15px;
	}
	#check-in .mark-4 {
		display: none;
	}
	#check-in .mark-1 {
		top: 2em;
		left:0px;
		height: 75px;
		width: 75px;
	}
	#check-in .mark-2 {
		top: 1.125em;
		right: -10px;
		height: 75px;
		width: 95px;
	}
}
@media screen and (max-width: 500px){
	.header-ctas {
		display: none;
	}
	.mobile-sticky-cta,
	.flexed-ctas-section .flexed-ctas > .flexed {
		display: block;
	}
	.inline-header {
		height: 250px;
	}
	.error404 .entry-content ul {
		columns: 1;
	}
}
@media screen and (max-width: 420px){
	body, button, input, select, textarea {
		font-size: 20px;
		font-size: 1.25rem;
	}
	.page-id-52 h1,
	h1 {
		font-size: 3.5rem;
	}
	h1 span {
    	font-size: 2.125rem;
    }
    h2 {
    	font-size: 1.75rem;
    }
    .mobile-navigation li > button {
    	padding: 14.5px 10px;
    }
    .intro h2,
    .text-section h2,
    .blocks-section .section-text h2 {
	    font-size: 2rem;
	}
	summary.accordion-title:after,
	summary.accordion-title h3 {
	    font-size: 1.5rem;
	}
	.p-60 {
        padding: 40px 20px;
    }
	.entry-content p:has(a.button:nth-of-type(2)) > a.button {
		display: block;
		min-width: auto;
	}
}
@media screen and (max-width: 360px){
	.page-id-52 h1,
	h1 {
		font-size: 3rem;
	}
	h1 span {
    	font-size: 2rem;
    }
}