@media (prefers-reduced-motion: no-preference) {
	:root {
		interpolate-size: allow-keywords;
	}

	html {
		scroll-behavior: smooth;
	}
}

@media (prefers-reduced-motion: reduce) {
	* {
		transition: none !important;
		animation: none !important;
		transition-duration: 0s !important;
	}
}

.sr-only:not(:focus):not(:active),
.screen-reader-text:not(:focus):not(:active) {
	clip: rect(0 0 0 0); 
	clip-path: inset(50%);
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap; 
	width: 1px;
}

img,
picture,
video,
canvas,
svg {
	max-width: 100%;
	display: block;
	height: auto;
}

a {
	transition: color 0.2s;
	color: var(--color-accent);
	text-decoration: none;
	outline-offset: 2px;
}

:target {
	scroll-margin-block: 75px;
}

[hidden] {
	display: none !important;
}

.post-content figure,
blockquote,
p {
	margin: 0 0 1.5em;

	&:last-child {
		margin: 0;
	}
}

b,
strong {
	font-weight: bold;
}

ul, ol {
	list-style: none;
	padding: 0;
	margin: 0;
}

input::placeholder {
	opacity: 1;
	color: inherit;
}

/***** GLOBAL *****/
#wpadminbar {
	position: fixed;
}

h1, .h1 {
	font-family: var(--font-heading);
	font-size: 4rem;
	line-height: 1.15em;
	margin: 0 0 0.3em;
	font-weight: normal;
	color: var(--text-accent);
	text-transform: none;
}

h2, .h2 {
	color: var(--text-accent);
	font-family: var(--font-secondary);
	font-size: 3rem;
	line-height: 1em;
	margin: 0 0 0.3em;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

h3, .h3 {
	font-family: var(--font-heading);
	font-size: 2.5rem;
	line-height: 1em;
	margin: 0 0 0.3em;
	font-weight: normal;
	color: var(--text-accent);
	letter-spacing: 0.05em;
	text-transform: none;
}

h4, .h4 {
	font-family: var(--font-secondary);
	text-transform: uppercase;
	font-size: 2.5rem;
	color: inherit;
	line-height: 1em;
	margin: 0 0 0.7em;
	letter-spacing: 0.05em;
	font-weight: normal;
}

h5, .h5 {
	font-family: var(--font-secondary);
	font-size: 2.4rem;
	line-height: 1em;
	margin: 0 0 0.3em;
	font-weight: normal;
	color: inherit;
	text-transform: uppercase;
}

h6, .h6 {
	font-family: var(--font-secondary);
	font-size: 2rem;
	line-height: 1em;
	margin: 0 0 0.3em;
	font-weight: normal;
	color: inherit;
	text-transform: uppercase;
}

.heading {
	text-wrap: balance;
}

.underline {
	text-decoration: underline;
	
	&:has(> a) {
		color: var(--color-accent);
	}
}

.stylized-text {
	font-family: var(--font-secondary);
	font-size: 1.35em;
	text-transform: uppercase;
}

.larger-text {
	font-family: var(--font-secondary);
	font-size: 1.4em;
}

.red-text {
	color: var(--color-accent);
}

.decoration-full {
	display: flex;
	justify-content: center;
	min-width: 30rem;
	min-height: 5.2rem;
	color: var(--text-accent);
	border-width: 2px 0;
	border-style: solid;
	border-color: var(--color-gold);

	span {
		align-self: center;
		padding: 0.5rem 1rem;
		min-width: 12rem;
		text-align: center;
	}

	&::before,
	&::after {
		display: block;
		border-right: 2px solid var(--color-gold);
		content: '';
		min-height: 10px;
		width: 6rem;
		background: url("../img/icon-graphic-header.svg") no-repeat center right / auto 2.2rem;
	}

	&::after {
		transform: scaleX(-1);
	}
}

.decoration-dots {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	justify-content: space-evenly;

	&::before,
	&::after {
		content: '';
		width: 3.5rem;
		flex: 0 0 3.5rem;
		height: 1rem;
		background: url("../img/icon-dot-red.svg") space center / 1rem auto;
	}
}

body h1:last-child,
body h2:last-child,
body h3:last-child,
body h4:last-child {
	margin-bottom: 0;
}

.page-section__header {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.richtext-content a:not(.button) {
	color: var(--color-accent);
	text-decoration: underline;
}

.richtext-content ol,
.richtext-content ul {
	margin: 0 0 1.5em;
	list-style-type: disc;
	padding: 0 0 0 1.5em;

	&:last-child {
		margin: 0;
	}
}

.richtext-content ol {
	list-style-type: decimal;
}

.richtext-content table {
	margin: 1.5em 0;
}

.aligncenter {
	display: block;
	margin: 0 auto;
}

hr.separator {
	margin: 0;
	border: 0;
	height: 1.6rem;
}

.page-column__row--description hr,
hr.separator--dots {
	margin: -0.5rem auto;
	width: 3.5rem;
	height: 1rem;
	background: url("../img/icon-dot-gold.svg") space center / 1rem auto;
	
	&:last-child {
		margin-bottom: 0.5rem;
	}
}

.page-column__row--description hr:not(.separator--dots) {
	margin: -1rem auto 1.2rem;
	border: 0;
	height: 1.6rem;
}

hr.separator--lines-dots {
	border-width: 2px 0;
	border-color: var(--color-gold);
	border-style: solid;
	background: url("../img/icon-dot-red.svg") space center / 8px auto;
}

@media (max-width: 768px) {
	.richtext-content {
		word-wrap: break-word;
	}

	h1, .h1 {
		font-size: 3.2rem;
		line-height: 1.2em;
	}

	h2, .h2 {
		font-size: 2.5rem;
		line-height: 1.2em;
	}
	
	h3, .h3 {
		font-size: 2.2rem;
		line-height: 1.2em;
	}

	h4, .h4 {
		font-size: 1.8rem;
		line-height: 1.4em;
	}

	h5, .h5 {
		font-size: 2.2rem;
	}
}

.ratio-container {
	--ratio: 4/3;
	aspect-ratio: var(--ratio);
	position: relative;
	overflow: hidden;
}

.ratio-container--placeholder {
	background: #f7f5f5;

	img {
		width: 50px;
		height: auto;
		position: absolute;
		opacity: 0.6;
		top: 50%;
		left: 50%;
		translate: -50% -50%;
	}
}

.ratio-container > * {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/***** END GLOBAL *****/

/**** SLIDER ****/
.slider {
	--slides-per-page: 3;
	--gap: 1rem;
	display: flex;
	overflow-x: auto;
	overflow-y: hidden;
	scrollbar-width: none;
	gap: var(--gap);
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scroll-snap-stop: always;
}

.slider--full {
	.slider__slide {
		scroll-margin-left: var(--side-offset);

		&:first-child {
			margin-left: var(--side-offset);
		}

		&:last-child {
			margin-right: var(--side-offset);
			scroll-margin-right: var(--side-offset);
		}
	}
}

.slider {
	display: flex;
	--slides-per-page: 3;
	--gap: 0px;
	overflow-x: auto;
}

.slider__slide {
	--gap_per_item: var(--gap) * ( var(--slides-per-page) - 1 ) / var(--slides-per-page);
	flex: 0 0 calc(100% / var(--slides-per-page) - var(--gap_per_item));
}

.slider__control {
	opacity: 0;
	position: absolute;
}
/**** END SLIDER ****/

/***** FORMS *****/
input
button,
textarea,
select,
button {
	font: inherit;
	accent-color: var(--color-accent);
	outline-offset: 2px;
	font-size: 1.6rem;
}

button {
	color: inherit;
	border: 0;
	background: transparent;
	padding: 0;
	cursor: pointer;
}

.select-wrapper {
	color: #000;
	display: block;
}

.select-wrapper:has(select[inert]) {
	color: var(--color-gray-medium);
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
input[type="password"],
input[type="number"],
button,
textarea,
select {
	width: 100%;
	color: #000;
	border-radius: 0.4rem;
	display: block;
	background: transparent;
	border: 1px solid currentColor;
	height: 4.8rem;
	padding: 0 2.5rem;
	font-family: inherit;
	outline-offset: 2px;
}

input[type="checkbox"] {
	margin: 0 0.4rem 0 0;
	width: 1.6rem;
	height: 1.6rem;
}

select {
	appearance: none;
	color: inherit;
}

input[type="submit"],
.button {
	width: auto;
	min-height: 4rem;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	padding: 0.5rem 1.25em;
	min-width: 14.5rem;
	text-transform: uppercase;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	gap: 1.2rem;
	border-radius: 0.3rem;
	background: var(--color-accent);
	color: #fff;
	font-style: normal;
	text-decoration: none;
	outline-offset: 2px;
	transition: background 0.2s;
	border: 0;
	line-height: 1.4em;
}

.button::before,
.button::after {
	content: '';
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--color-dark);
}

.button--outline {
	border: 1px solid var(--color-accent);
	color: var(--color-accent);
	background: transparent;
}

.button--outline-accent {
	border: 1px solid var(--color-gold);
	color: var(--color-gold);
}

.button--outline-accent::before,
.button--outline-accent::after {
	background: var(--color-gold);
}

.button--smaller {
	height: 3.2rem;
	min-height: 3.2rem;
}

.form-line {
	display: flex;
	flex-wrap: wrap;
}

.form-line > *:not(.button),
.form-line .select-wrapper select {
	flex: 1;
	border-right: 0;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}

.form-line > .button {
	width: auto;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
}

@media (max-width: 768px) {
	input[type="submit"],
	.button:not(.button--big) {
		min-width: 11rem;
	}

	input[type="text"],
	input[type="email"],
	input[type="tel"],
	input[type="date"],
	input[type="password"],
	input[type="number"],
	button,
	textarea,
	select {
		padding: 0 2rem;
	}

	.select-wrapper::after {
		right: 1em;
	}
}

fieldset {
	border: 0;
	padding: 2.5rem;
	margin: 0 0 3rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}


fieldset p.form-row {
	margin: 0;
}

legend {
	float: left;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 1.5rem;
	line-height: 1.5em;
	color: var(--color-gray-medium);
	margin: 0 0 1em;
	padding: 0;
}

.form-row--required > label::after {
	content: ' *';
	color: var(--color-accent);
}
/***** END FORMS *****/

/***** HEADER *****/
.main_header_wrapper {
	border: 2px solid var(--color-gold);
	border-width: 2px 2px 0;
}

.main-header {
	background: #fff;
	padding-top: calc(0.5 * var(--container-padding));
	z-index: 5;
}

.main-header__top {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	border-bottom: 2px solid var(--color-gold);
}

.site-branding {
	display: flex;
	align-items: center;
	border-style: solid;
	border-color: var(--color-gold);
	border-width: 0 2px;
	padding: 0 1rem;
	position: relative;
}

.site-branding img {
	width: 12rem;
}

/* .site-branding::after {
	content: "By Jose Garces";
	position: absolute;
	line-height: 1em;
	bottom: 0;
	left: 50%;
	translate: -50% 50%;
	font-size: 1rem;
	background: #fff;
	padding: 0 0.4em;
	white-space: nowrap;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	font-family: var(--font-secondary);
} */

.header-navigation-top {
	display: flex;
	flex-wrap: wrap;
}

.header-navigation-top::before {
	content: '';
	display: block;
	height: 1.5rem;
	border-bottom: 2px solid var(--color-gold);
	background: url("../img/icon-dot-red.svg") space center / 8px auto;
	flex: 0 0 100%;
}

.header-navigation-top::after {
	content: '';
	display: block;
	height: 1.5rem;
	border-top: 2px solid var(--color-gold);
	flex: 0 0 100%;
}

.header-navigation-top .menu-container {
	margin: 0 auto;
	position: relative;
	display: flex;
}

.header-navigation-top .menu {
	display: flex;
	justify-content: center;
	margin: 0 auto;
	position: relative;
	align-items: center;
}

.header-navigation-top > .menu-container,
.header-navigation-top > .menu {
	padding: 0 3rem;
}

.social-nav {
	display: flex;
	align-items: center;
	position: relative;
	padding: 0 2rem;
}

.social-nav img {
	width: 2.5rem;
	height: 3rem;
	padding: 0.7rem 0;
}

.header-navigation-top > .menu-container::before,
.header-navigation-top > .menu-container::after,
.header-navigation-top > .menu::before,
.header-navigation-top > .menu::after {
	content: '';
	width: 3.5rem;
	height: 1rem;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	left: 0;
	background: url("../img/icon-dot-gold.svg") space center / 1rem auto;
}

.header-navigation-top > .menu::after,
.header-navigation-top > .menu-container::after {
	right: 0;
	left: auto;
}

.social-nav__label,
.header-navigation-top .menu a {
	padding: 0.5rem 2rem;
	display: block;
	font-family: var(--font-secondary);
	text-transform: uppercase;
	color: var(--color-accent);
	letter-spacing: .07em;
	font-size: 1.6rem;
	position: relative;
}

.social-nav__label {
	padding: 0;
	margin-right: 1rem;
}

.header-navigation-top .social-nav::before,
.header-navigation-top .menu li:not(:first-child) a::before {
	content: '';
	width: 0.4rem;
	height: 0.4rem;
	position: absolute;
	left: 0;
	top: 50%;
	translate: -50% -20%;
	background: var(--color-dark);
	border-radius: 50%;
}

.header-navigation__text {
	font-size: 1rem;
	font-family: var(--font-secondary);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	justify-content: center;
	display: flex;
	align-items: center;
	padding: 0 1rem;
}

.header-navigation__text:last-child {
	border-left: 2px solid var(--color-gold);
}

.header-navigation__text:first-child {
	border-right: 2px solid var(--color-gold);
}

#main-navigation {
	/* margin-top: 1.5rem; */
	border-bottom: 2px solid var(--color-gold);
	display: flex;
	justify-content: center;
}

#main-navigation .menu {
	border: 0;
	color: inherit;
	display: flex;
	gap: 0;
}

#main-navigation .menu a {
	display: flex;
	font-family: var(--font-body);
	align-items: center;
	height: 100%;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding: 0 1rem;
	font-size: 1.6rem;
	position: relative;
	color: inherit;
}

#main-navigation .current-menu-item a {
	color: var(--color-accent);
}

#main-navigation li:last-child {
	margin-right: 1rem;
}

#main-navigation li:first-child {
	margin-left: 1rem;
}

#main-navigation .menu li:not(:first-child) a::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: var(--color-accent);
	translate: -50% -50%;
}

.mobile-menu-activator {
	width: 4rem;
	height: 4rem;
	padding: 0;
	text-indent: -200rem;
	overflow: hidden;
	display: none;
	border: 0;
	position: relative;
}

.mobile-menu-activator::before,
.mobile-menu-activator::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	width: 2.5rem;
	border: solid var(--color-dark);
	border-width: 2px 0 0;
}

.mobile-menu-activator::after {
	height: 1.6rem;
	border-width: 2px 0;
}

.header-call-button {
	height: auto;
	border: 0;
	width: 4rem;
	height: 4rem;
	text-indent: -200rem;
	overflow: hidden;
	background: url("../img/icon-phone.svg") no-repeat center / 20px auto;
}

@media (min-width: 901px) {
	.extra-mobile-menu,
	#main-navigation .social-nav,
	#main-navigation .separator,
	.header-navigation__mobile {
		display: none;	
	}
	
	.header-navigation-top .header-call-button {
		display: none;
	}
}

@media (max-width: 900px) {
	html {
		margin: 0 !important;
	}
	
	html #wpadminbar {
		display: none;
	}
	
	.main-header {
		position: sticky;
		top: 0;
	}
	
	.header-navigation__mobile {
		margin: calc(0.5 * var(--container-padding)) 0;
		border-top: 2px solid var(--color-gold);
		border-bottom: 2px solid var(--color-gold);
		display: flex;
		flex-wrap: wrap;
	}
	
	.header-navigation__mobile::before {
		content: '';
		display: block;
		height: 1.2rem;
		border-bottom: 2px solid var(--color-gold);
		background: url("../img/icon-dot-red.svg") space center / 8px auto;
		flex: 0 0 100%;
	}
	
	.header-navigation__mobile .mobile-menu-activator {
		border-right: 2px solid var(--color-gold);
	}
	
	.header-navigation__mobile .header-call-button {
		border-left: 2px solid var(--color-gold);
	}
	
	.header-navigation__mobile .mobile-logo {
		flex: 1;
		text-transform: uppercase;
		display: flex;
		align-items: center;
		text-align: center;
		justify-content: center;
	}
	
	.header-navigation-top > .menu-container,
	.header-navigation-top > .menu {
		display: none;
	}

	#main-navigation {
		display: flex;
		flex-direction: column;
		position: fixed;
		border: 0;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #fff;
		z-index: 5;
		pointer-events: none;
		translate: 0 -100%;
		transition: translate 0.3s;
		justify-content: flex-start;
	}
	
	.mobile-menu-active #main-navigation {
		translate: 0 0;
		pointer-events: all;
	}
	
	#main-navigation .menu {
		flex-direction: column;
		align-items: center;
		margin: 1.5rem 0;
	}
	
	#main-navigation .menu a {
		padding: 1rem;
	}
	
	#main-navigation .menu li:not(:first-child) a::before {
		top: 0;
		left: 50%;
	}
	
	#main-navigation li:last-child,
	#main-navigation li:first-child {
		margin: 0;
	}
	
	#main-navigation .menu::before,
	#main-navigation .menu::after {
		display: none;
	}

	.mobile-menu-activator {
		display: block;
	}
	
	.header-navigation__mobile .mobile-menu-activator::before {
		rotate: -45deg;
	}
	
	.header-navigation__mobile .mobile-menu-activator::after {
		rotate: 45deg;
		border-bottom: 0;
		height: 0;
	}
	
	.extra-mobile-menu {
		border: 2px solid var(--color-gold);
		border-width: 2px 0;
		display: flex;
		justify-content: center;
		text-align: center;
		align-items: center;
		flex-wrap: wrap;
	}
	
	.extra-mobile-menu::before,
	.extra-mobile-menu::after {
		content: '';
		width: 3rem;
		height: 1rem;
		background: url("../img/icon-dot-gold.svg") space center / 1rem auto;
	}
	
	.extra-mobile-menu a {
		color: var(--color-accent);
		font-size: 1.7rem;
		padding: 0.25rem 1.5rem;
		display: block;
		text-transform: uppercase;
		letter-spacing: 0.06em;
		font-family: var(--font-secondary);
		position: relative;
	}
	
	.extra-mobile-menu li:not(:first-child) a::before {
		content: '';
		position: absolute;
		top: 50%;
		left: 0;
		width: 4px;
		height: 4px;
		border-radius: 50%;
		translate: -50% -50%;
		background: var(--color-dark);
	}
	
	#main-navigation .social-nav {
		justify-content: center;
		flex-wrap: wrap;
		text-align: center;
		gap: 1rem 0;
		margin: 3rem 0;
	}
	
	#main-navigation .social-nav__label {
		flex: 0 0 100%;
		color: inherit;
		font-size: 2rem;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 1rem;
		
		&::before,
		&::after {
			content: '';
			width: 3rem;
			height: 1rem;
			background: url("../img/icon-dot-gold.svg") space center / 1rem auto;
		}
	}
	
	#main-navigation .social-nav img {
		padding: 0.8rem;
		width: 3.5rem;
		height: 3.5rem;
	}
	
	.header-navigation__text {
		padding: 0 0.5rem;
		flex: 1;
	}
}

@media (max-width: 768px) {
	.site-branding img {
		width: 10rem;
	}

	.main_header_wrapper {
		border-width: 2px 0 0;
		margin: 0 calc(-1 * var(--container-padding));
	}

	.header-navigation-top::before,
	.header-navigation-top::after {
		height: 1.2rem;
	}
}
/***** END HEADER *****/



/***** HERO *****/
.slider--hero {
	border-radius: 0.5rem;
	--slides-per-page: 1;
	--gap: 0px;
}

.slider--hero .slider__slide {
	display: flex;
	position: relative;

	&::after {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: url("../img/slider-frame.svg") no-repeat center / contain;
	}
}

.slider--hero .hero__image {
	flex: 0 0 100%;
	aspect-ratio: 6/2.9;
}

.slider__slider--overlay .hero__image {
	position: relative;
}


.slider__slider--overlay .hero__image::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--overlay-color);
	opacity: var(--overlay-opacity);
}

.hero__content {
	flex: 0 0 100%;
	translate: -100% 0;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	position: relative;
	text-align: center;
	padding: 4rem 2rem;
	align-self: flex-end;
	margin-bottom: 7rem;
	color: #fff;
	z-index: 2;
	--text-accent: var(--color-red);
}

.hero__content--color-dark {
	--text-accent: var(--color-gold);
}

.page-section--hero .slider__dots {
	display: flex;
	position: absolute;
	bottom: 5rem;
	left: 50%;
	translate: -50% 0;
}

.page-section--hero .slider__dot {
	border: 0;
	--color-accent: #fff;
	padding: 0;
}

@media (max-width: 900px) {
	.slider--hero .slider__slide::after {
		display: none;
	}
	
	.hero__content {
		margin-bottom: 3rem;
	}
	
	.page-section--hero .slider__dots {
		bottom: 2.5rem;
	}
}
/***** END HERO *****/


/***** HEADING *****/
.page-section--heading {
	text-align: center;
	margin: calc(var(--section-space) * 1.5) 0;
}

.group_nav,
.heading__description {
	max-width: 80rem;
	margin: 1.5rem auto 0;
	padding-bottom: 1.5rem;
	border-bottom: 2px solid var(--color-gold);
}

.group_nav {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.group_nav button {
	border: 0;
	padding: 1rem 1.5rem;
	height: auto;
	font-family: var(--font-secondary);
	text-transform: uppercase;
	font-size: 1.4em;
	color: inherit;
	letter-spacing: 0.03em;
}

.group_nav button[aria-selected="true"] {
	color: var(--color-accent);
}

[role="tabpanel"]:not([aria-selected="true"]) {
	display: none;
}

@media(max-width: 768px) {
	.page-section--heading {
		margin: var(--section-space) 0;
	}
}
/***** END HEADING *****/

/***** COLUMNS *****/
.page-section--columns {
	display: flex;
	flex-wrap: wrap;
	--section-border-color: var(--color-gold);
}

.page-section--color-dark {
	background: var(--color-dark);
	color: #fff;
	--text-accent: var(--color-gold);
	--section-border-color: var(--color-red);
}

.columns-container {
	display: flex;
	min-width: 0;
	flex: 1;
	min-width: 50%;
}

.columns-container:has(.page-column:nth-child(4):last-child) {
	display: grid;
	grid-template-columns: 1fr 1fr;
}

.columns-container:has(.page-column:nth-child(4):last-child) .page-column:nth-child(3) {
	border: 0;
}

.page-column {
	flex: 1;
	padding: 4rem 2.5rem;
	display: flex;
	justify-content: center;
	min-width: 24rem;
	position: relative;
}

.page-column--decoration-red-dots::before,
.page-column--decoration-red-dots::after {
	content: '';
	left: 0;
	width: 100%;
	top: 0;
	height: 1.6rem;
	position: absolute;
	border-width: 0 0 2px;
	border-color: var(--color-gold);
	border-style: solid;
	background: url("../img/icon-dot-red.svg") space center / 8px auto;
}

.page-column--decoration-red-dots::after {
	top: auto;
	border-width: 2px 0 0;
	bottom: 0;
}

.page-column__inner {
	display: flex;
	flex-direction: column;
	margin: 0 auto;
	gap: 2rem;
	width: 100%;
}

.columns-sep-col--line .page-column {
	padding-top: 0;
	padding-bottom: 0;
	margin-top: 3rem;
	margin-bottom: 3rem;
}

.page-column .heading {
	width: 100%;
}

.page-column--width-small {
	flex: 0;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.page-column--align-middle {
	align-items: center;
}

.page-column--align-bottom {
	align-items: flex-end;
}

.columns-sep-col--icon .page-column {
	&:first-child::after,
	&:last-child::after {
		content: '';
		position: absolute;
		right: -1px;
		top: 50%;
		translate: 0 -50%;
		width: 14px;
		height: 20px;
		background: url("../img/icon-gold-hook.svg") no-repeat center right / contain;
	}
	
	&:only-child::before,
	&:only-child::after {
		display: none;
	}

	&:last-child::after {
		right: auto;
		left: -1px;
		transform: scaleX(-1);
	}
}

.page-column .menu {
	display: flex;
	justify-content: center;
	padding: 0 3rem;
	flex-wrap: wrap;
	margin: 0 auto;
}

.page-column .menu a {
	font-family: var(--font-secondary);
	color: var(--text-accent);
	text-transform: uppercase;
	letter-spacing: .08em;
	font-size: 2rem;
	padding: 1rem 2rem;
	display: block;
}

.columns-sep-top--line,
.columns-sep-top--dots,
.columns-sep-top--gold {
	border-top: 2px solid var(--section-border-color);
}

.separator-dots {
	height: 1.6rem;
	border-style: solid;
	border-color: var(--section-border-color);
	position: relative;
	flex: 0 0 100%;

	&::after {
		content: '';
		position: absolute;
		width: 30rem;
		height: 1rem;
		top: 50%;
		left: 50%;
		translate: -50% -50%;
		max-width: 100%;
		background: url("../img/icon-dot-dark.svg") space center / 7px auto;
	}
}

.columns-sep-top--gold .separator-dots {
	height: 3rem;
}

.columns-sep-top--gold .separator-dots::after {
	width: 100%;
	translate: 0 -50%;
	left: 0;
	background: url("../img/icon-dot-gold.svg") space center / 14px auto;
}

.page-section--color-dark .separator-dots::after {
	background-image: url("../img/icon-dot-gold.svg");
}

.separator-dots:first-child {
	border-width: 0 0 2px;
}

.separator-dots:last-child {
	border-width: 2px 0 0;
}

.columns-sep-bottom--line,
.columns-sep-bottom--dots,
.columns-sep-bottom--gold {
	border-bottom: 2px solid var(--section-border-color);
}

.columns-sep-sides--lines,
.columns-sep-sides--dots,
.columns-sep-sides--line {
	border-left: 2px solid var(--section-border-color);
	border-right: 2px solid var(--section-border-color);
}

.separator-sides {
	width: 1.2rem;
	border: 2px solid var(--section-border-color);
	border-width: 0 2px;
	margin: 0 0 0 3rem;
	position: relative;
}

.columns-sep-sides--dots .separator-sides::before {
	content: '';
	position: absolute;
	top: 0.5rem;
	bottom: 0.5rem;
	right: 2rem;
	width: 1rem;
	background: url("../img/icon-dot-gold.svg") space center / 14px auto;
}

.columns-container ~ .separator-sides {
	margin: 0 3rem 0 0;
}

.columns-sep-sides--dots .columns-container ~ .separator-sides::before {
	right: auto;
	left: 2rem;
}

.page-column__row--description {
	text-align: center;
	text-wrap: balance;
	max-width: 64rem;
	margin: 0 auto;
	width: 100%;
}

.page-column__row--description:has(iframe) {
	max-width: none;
	background: var(--color-dark);
	
	iframe {
		width: 100%;
		mix-blend-mode: screen;
		display: block;
		filter: saturate(0%) contrast(110%) brightness(0.75);
	}
}

.page-column__row--button {
	text-align: center;
	margin-top: auto;
}

@media (min-width: 901px) {
	.columns-sep-col--line .page-column:not(:first-child),
	.columns-sep-col--lines .page-column:not(:first-child),
	.columns-sep-col--icon .page-column:not(:first-child) {
		border-left: 2px solid var(--color-gold);
	}

	.columns-sep-col--lines,
	.columns-sep-col--icon {
		.columns-container {
			gap: 0.8rem;
		}

		.page-column:not(:last-child) {
			border-right: 2px solid var(--color-gold);
		}
	}
}

@media (max-width: 1100px) {
	.page-section .page-column--empty {
		display: none;
	}
	
	.columns-sep-col--icon:has(.page-column--empty:first-child):has(.page-column--empty:last-child) .page-column--empty {
		display: block;
		flex: 0 0 3rem;
		min-width: 0;
	}
}

@media (max-width: 900px) {
	.columns-container {
		flex-direction: column;
	}
	
	.columns-sep-col--icon:has(.page-column--empty:first-child):has(.page-column--empty:last-child) {
		.page-column:not(.page-column--empty) {
			border-left: 2px solid var(--color-gold);
			border-right: 2px solid var(--color-gold);
			margin: 0 0.8rem;
		}
		
		.columns-container {
			flex-direction: row;
		}
	}
	
	.columns-sep-col--icon .page-column--empty:first-child {
		border-right: 2px solid var(--color-gold);
	}
	
	.columns-sep-col--icon .page-column--empty:last-child {
		border-left: 2px solid var(--color-gold);
	}
	
	.separator-sides {
		display: none;
	}
	
	.page-column .menu {
		flex-direction: column;
		align-items: center;
		padding: 1rem 0;
	}

	.page-section--mobile-one-two .columns-container {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}
	
	.page-section--mobile-stack-reorder .page-column:nth-child(2),
	.page-section--mobile-one-two .page-column:nth-child(2) {
		order: -1;
		grid-column: 1 / -1;
	}
	
	.page-section--mobile-one-two .page-column:first-child {
		border: 2px solid var(--color-gold);
		border-width: 2px 2px 0 0;
	}
	
	.page-section--mobile-one-two .page-column:nth-child(2) {
		border-bottom: 2px solid var(--color-gold);
		margin-bottom: 1.6rem;
	}
	
	.page-section--mobile-one-two .page-column:last-child {
		border: 2px solid var(--color-gold);
		border-width: 2px 0 0;
	}
	
	.page-column--decoration-red-dots:first-child::before,
	.page-column--decoration-red-dots:last-child::after {
/* 		display: none; */
	}
	
	.columns-sep-col--line .page-column,
	.page-column {
		min-width: 0;
/* 		padding: 2rem 2.5rem; */
		padding: 2rem 0;
		margin: 0;
	}
	
	.page-column__row--button,
	.page-column__row--description {
		padding: 0 2rem;
	}
	
	.columns-container:has(.page-column:nth-child(4):last-child) {
		display: flex;
	}
	
	.group_nav button {
		padding: 0.5rem 1rem;
	}
	
	.group_nav li:not(:first-child) button::before {
		display: none;
	}
	
	.page-column--decoration-red-dots::before {
		border-width: 2px 0;
	}
	
	.page-column--decoration-red-dots {
		padding-top: 3.5rem;
	}
	
	.page-column--decoration-red-dots:last-child {
		padding-bottom: 3.5rem;
	}
	
	.page-column--decoration-red-dots:first-child::after {
		display: none;
	}
	
	.page-column:has(.page-column__row--image:only-child) {
		padding: 0;
		
		&:not(:first-child) {
			border-top: 2px solid var(--color-gold);
		}
	}
	
	.separator-dots::after {
		background-size: 9px auto;
		width: 18rem;
	}
	
	.page-section--mobile-stack-reorder.columns-sep-col--lines .page-column:not(.page-column--decoration-red-dots):first-child {
		border-top: 2px solid var(--color-gold);
		border-bottom: 2px solid var(--color-gold)
	}
}
/***** END COLUMNS *****/

/***** POPUPS *****/
.promo-popup {
	background: var(--color-dark);
	color: #fff;
	border: 0;
	padding: 0;
}

.promo-popup::backdrop {
	background: #fff;
	opacity: 0.5;
}

.popup-content {
	padding: 4rem 4rem 8rem;
	text-align: center;
	position: relative;
}

.popup-content::after {
	content: '';
	position: absolute;
	bottom: 1.5rem;
	height: 1.5rem;
	border: 2px solid var(--color-gold);
	border-width: 2px 0;
	left: 0;
	width: 100%;
}

.popup-content .page-section__header {
	margin-bottom: 1.5rem;
}

.popup-close-button {
	width: 4.5rem;
	height: 4.5rem;
	background: #fff;
	text-indent: -300rem;
	overflow: hidden;
	position: absolute;
	top: 2rem;
	right: 2rem;
	border: 0;
	border-radius: 0;
	padding: 0;
}

.popup-close-button::before,
.popup-close-button::after {
	content: '';
	width: 1.5rem;
	border-top: 2px solid var(--color-accent);
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
	rotate: 45deg;
}

.popup-close-button::after {
	rotate: -45deg;
}

.promo-popup h2,
.promo-popup h3,
.promo-popup h4 {
	color: #fff;
}

@media (max-width: 768px) {
	.popup-content {
		padding: 2rem 2rem 5rem;
	}
	
	.popup-content::after {
		height: 1rem;
	}
}
/***** END POPUPS *****/

/***** FOOTER *****/
.site-footer--bottom .page-column {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	min-height: 25rem;
	margin: 0;
}

.site-footer .social-nav {
	justify-content: center;
	
	img {
		width: 3rem;
	}
}

.site-footer .button {
	color: var(--color-gold);
	text-transform: none;
	letter-spacing: 0.01em;
	font-size: 1.6rem;
}

.site-footer .button::before,
.site-footer .button::after {
	background: var(--color-gold);
}

.site-footer--bottom .page-column img {
	max-width: min(30rem, 100%);
	max-height: 12rem;
	object-fit: contain;
}

.site-footer--bottom .page-column__inner {
	justify-content: center;
	flex-direction: row;
}

.page-column--decorated {
	font-family: var(--font-secondary);
	text-transform: uppercase;
	font-size: 1.3em;
	letter-spacing: 0.05em;
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 0;
}

.page-column--decorated a {
	color: inherit;
}

.page-column--decorated small {
	color: var(--color-accent);
	font-size: 0.7em;
}

.page-column--decorated .separator {
	margin: 2rem auto;
}

.footer-logo {
	margin: 0 0 2rem;
	width: 150px;
}

.page-column--decorated::before,
.page-column--decorated::after {
	content: '';
	top: 0;
	height: 100%;
	left: 1rem;
	position: absolute;
	width: 50%;
	z-index: -1;
	background: url("../img/footer-lines.svg") no-repeat left center / contain;
}

.page-column--decorated::after {
	rotate: 180deg;
	left: auto;
	right: 1rem;
}

@media (max-width: 900px) {
	.page-column--decorated {
		padding: 24vw 2rem 31vw;
	}
	
	.page-column--decorated::before,
	.page-column--decorated::after {
		left: 0;
		top: 1rem;
		width: 100%;
		height: 50%;
		background-image: url("../img/footer-lines-top.svg");
		background-position: top center;
	}
	
	.page-column--decorated::after {
		top: auto;
		bottom: 1rem;
	}
}

@media (max-width: 768px) {
	.site-footer--bottom .page-column {
		min-height: 17rem;	
	}
}
/***** END FOOTER *****/